| 
									
										
										
										
											2023-03-12 16:00:57 +01:00
										 |  |  | // GoToSocial | 
					
						
							|  |  |  | // Copyright (C) GoToSocial Authors admin@gotosocial.org | 
					
						
							|  |  |  | // SPDX-License-Identifier: AGPL-3.0-or-later | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  | // it under the terms of the GNU Affero General Public License as published by | 
					
						
							|  |  |  | // the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  | // (at your option) any later version. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  | // GNU Affero General Public License for more details. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  | // along with this program.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2021-03-18 23:27:43 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-08 14:25:55 +02:00
										 |  |  | package model | 
					
						
							| 
									
										
										
										
											2021-03-18 23:27:43 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | // OAuthAuthorize represents a request sent to https://example.org/oauth/authorize | 
					
						
							|  |  |  | type OAuthAuthorize struct { | 
					
						
							|  |  |  | 	// Forces the user to re-login, which is necessary for authorizing with multiple accounts from the same instance. | 
					
						
							| 
									
										
										
										
											2021-07-08 11:32:31 +02:00
										 |  |  | 	ForceLogin string `form:"force_login" json:"force_login"` | 
					
						
							| 
									
										
										
										
											2021-03-18 23:27:43 +01:00
										 |  |  | 	// Should be set equal to `code`. | 
					
						
							| 
									
										
										
										
											2025-04-19 21:57:50 +02:00
										 |  |  | 	ResponseType string `form:"response_type" json:"response_type" binding:"required"` | 
					
						
							| 
									
										
										
										
											2021-03-18 23:27:43 +01:00
										 |  |  | 	// Client ID, obtained during app registration. | 
					
						
							| 
									
										
										
										
											2025-04-19 21:57:50 +02:00
										 |  |  | 	ClientID string `form:"client_id" json:"client_id" binding:"required"` | 
					
						
							| 
									
										
										
										
											2021-03-18 23:27:43 +01:00
										 |  |  | 	// 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. | 
					
						
							| 
									
										
										
										
											2025-04-19 21:57:50 +02:00
										 |  |  | 	RedirectURI string `form:"redirect_uri" json:"redirect_uri" binding:"required"` | 
					
						
							| 
									
										
										
										
											2021-03-18 23:27:43 +01:00
										 |  |  | 	// 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. | 
					
						
							| 
									
										
										
										
											2021-07-08 11:32:31 +02:00
										 |  |  | 	Scope string `form:"scope" json:"scope"` | 
					
						
							| 
									
										
										
										
											2022-07-28 16:43:27 +02:00
										 |  |  | 	// State is used by the application to store request-specific data and/or prevent CSRF attacks. | 
					
						
							|  |  |  | 	// The authorization server must return the unmodified state value back to the application. | 
					
						
							|  |  |  | 	// See https://www.oauth.com/oauth2-servers/authorization/the-authorization-request/ | 
					
						
							|  |  |  | 	State string `form:"state" json:"state"` | 
					
						
							| 
									
										
										
										
											2021-03-18 23:27:43 +01:00
										 |  |  | } |