oauth.go (2136B)
1 // GoToSocial 2 // Copyright (C) GoToSocial Authors admin@gotosocial.org 3 // SPDX-License-Identifier: AGPL-3.0-or-later 4 // 5 // This program is free software: you can redistribute it and/or modify 6 // it under the terms of the GNU Affero General Public License as published by 7 // the Free Software Foundation, either version 3 of the License, or 8 // (at your option) any later version. 9 // 10 // This program is distributed in the hope that it will be useful, 11 // but WITHOUT ANY WARRANTY; without even the implied warranty of 12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 // GNU Affero General Public License for more details. 14 // 15 // You should have received a copy of the GNU Affero General Public License 16 // along with this program. If not, see <http://www.gnu.org/licenses/>. 17 18 package model 19 20 // OAuthAuthorize represents a request sent to https://example.org/oauth/authorize 21 type OAuthAuthorize struct { 22 // Forces the user to re-login, which is necessary for authorizing with multiple accounts from the same instance. 23 ForceLogin string `form:"force_login" json:"force_login"` 24 // Should be set equal to `code`. 25 ResponseType string `form:"response_type" json:"response_type"` 26 // Client ID, obtained during app registration. 27 ClientID string `form:"client_id" json:"client_id"` 28 // Set a URI to redirect the user to. 29 // If this parameter is set to urn:ietf:wg:oauth:2.0:oob then the authorization code will be shown instead. 30 // Must match one of the redirect URIs declared during app registration. 31 RedirectURI string `form:"redirect_uri" json:"redirect_uri"` 32 // List of requested OAuth scopes, separated by spaces (or by pluses, if using query parameters). 33 // Must be a subset of scopes declared during app registration. If not provided, defaults to read. 34 Scope string `form:"scope" json:"scope"` 35 // State is used by the application to store request-specific data and/or prevent CSRF attacks. 36 // The authorization server must return the unmodified state value back to the application. 37 // See https://www.oauth.com/oauth2-servers/authorization/the-authorization-request/ 38 State string `form:"state" json:"state"` 39 }