mirror of
https://github.com/superseriousbusiness/gotosocial
synced 2025-06-05 21:59:39 +02:00
[feature] add TOTP two-factor authentication (2FA) (#3960)
* [feature] add TOTP two-factor authentication (2FA) * use byteutil.S2B to avoid allocations when comparing + generating password hashes * don't bother with string conversion for consts * use io.ReadFull * use MustGenerateSecret for backup codes * rename util functions
This commit is contained in:
@ -22,13 +22,13 @@ type OAuthAuthorize struct {
|
||||
// Forces the user to re-login, which is necessary for authorizing with multiple accounts from the same instance.
|
||||
ForceLogin string `form:"force_login" json:"force_login"`
|
||||
// Should be set equal to `code`.
|
||||
ResponseType string `form:"response_type" json:"response_type"`
|
||||
ResponseType string `form:"response_type" json:"response_type" validate:"required"`
|
||||
// Client ID, obtained during app registration.
|
||||
ClientID string `form:"client_id" json:"client_id"`
|
||||
ClientID string `form:"client_id" json:"client_id" validate:"required"`
|
||||
// Set a URI to redirect the user to.
|
||||
// If this parameter is set to urn:ietf:wg:oauth:2.0:oob then the authorization code will be shown instead.
|
||||
// Must match one of the redirect URIs declared during app registration.
|
||||
RedirectURI string `form:"redirect_uri" json:"redirect_uri"`
|
||||
RedirectURI string `form:"redirect_uri" json:"redirect_uri" validate:"required"`
|
||||
// List of requested OAuth scopes, separated by spaces (or by pluses, if using query parameters).
|
||||
// Must be a subset of scopes declared during app registration. If not provided, defaults to read.
|
||||
Scope string `form:"scope" json:"scope"`
|
||||
|
Reference in New Issue
Block a user