mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2025-01-07 15:10:12 +00:00
85 lines
3.8 KiB
Go
85 lines
3.8 KiB
Go
|
package errors
|
||
|
|
||
|
import (
|
||
|
"errors"
|
||
|
"net/http"
|
||
|
)
|
||
|
|
||
|
// Response error response
|
||
|
type Response struct {
|
||
|
Error error
|
||
|
ErrorCode int
|
||
|
Description string
|
||
|
URI string
|
||
|
StatusCode int
|
||
|
Header http.Header
|
||
|
}
|
||
|
|
||
|
// NewResponse create the response pointer
|
||
|
func NewResponse(err error, statusCode int) *Response {
|
||
|
return &Response{
|
||
|
Error: err,
|
||
|
StatusCode: statusCode,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// SetHeader sets the header entries associated with key to
|
||
|
// the single element value.
|
||
|
func (r *Response) SetHeader(key, value string) {
|
||
|
if r.Header == nil {
|
||
|
r.Header = make(http.Header)
|
||
|
}
|
||
|
r.Header.Set(key, value)
|
||
|
}
|
||
|
|
||
|
// https://tools.ietf.org/html/rfc6749#section-5.2
|
||
|
var (
|
||
|
ErrInvalidRequest = errors.New("invalid_request")
|
||
|
ErrUnauthorizedClient = errors.New("unauthorized_client")
|
||
|
ErrAccessDenied = errors.New("access_denied")
|
||
|
ErrUnsupportedResponseType = errors.New("unsupported_response_type")
|
||
|
ErrInvalidScope = errors.New("invalid_scope")
|
||
|
ErrServerError = errors.New("server_error")
|
||
|
ErrTemporarilyUnavailable = errors.New("temporarily_unavailable")
|
||
|
ErrInvalidClient = errors.New("invalid_client")
|
||
|
ErrInvalidGrant = errors.New("invalid_grant")
|
||
|
ErrUnsupportedGrantType = errors.New("unsupported_grant_type")
|
||
|
ErrCodeChallengeRquired = errors.New("invalid_request")
|
||
|
ErrUnsupportedCodeChallengeMethod = errors.New("invalid_request")
|
||
|
ErrInvalidCodeChallengeLen = errors.New("invalid_request")
|
||
|
)
|
||
|
|
||
|
// Descriptions error description
|
||
|
var Descriptions = map[error]string{
|
||
|
ErrInvalidRequest: "The request is missing a required parameter, includes an invalid parameter value, includes a parameter more than once, or is otherwise malformed",
|
||
|
ErrUnauthorizedClient: "The client is not authorized to request an authorization code using this method",
|
||
|
ErrAccessDenied: "The resource owner or authorization server denied the request",
|
||
|
ErrUnsupportedResponseType: "The authorization server does not support obtaining an authorization code using this method",
|
||
|
ErrInvalidScope: "The requested scope is invalid, unknown, or malformed",
|
||
|
ErrServerError: "The authorization server encountered an unexpected condition that prevented it from fulfilling the request",
|
||
|
ErrTemporarilyUnavailable: "The authorization server is currently unable to handle the request due to a temporary overloading or maintenance of the server",
|
||
|
ErrInvalidClient: "Client authentication failed",
|
||
|
ErrInvalidGrant: "The provided authorization grant (e.g., authorization code, resource owner credentials) or refresh token is invalid, expired, revoked, does not match the redirection URI used in the authorization request, or was issued to another client",
|
||
|
ErrUnsupportedGrantType: "The authorization grant type is not supported by the authorization server",
|
||
|
ErrCodeChallengeRquired: "PKCE is required. code_challenge is missing",
|
||
|
ErrUnsupportedCodeChallengeMethod: "Selected code_challenge_method not supported",
|
||
|
ErrInvalidCodeChallengeLen: "Code challenge length must be between 43 and 128 charachters long",
|
||
|
}
|
||
|
|
||
|
// StatusCodes response error HTTP status code
|
||
|
var StatusCodes = map[error]int{
|
||
|
ErrInvalidRequest: 400,
|
||
|
ErrUnauthorizedClient: 401,
|
||
|
ErrAccessDenied: 403,
|
||
|
ErrUnsupportedResponseType: 401,
|
||
|
ErrInvalidScope: 400,
|
||
|
ErrServerError: 500,
|
||
|
ErrTemporarilyUnavailable: 503,
|
||
|
ErrInvalidClient: 401,
|
||
|
ErrInvalidGrant: 401,
|
||
|
ErrUnsupportedGrantType: 401,
|
||
|
ErrCodeChallengeRquired: 400,
|
||
|
ErrUnsupportedCodeChallengeMethod: 400,
|
||
|
ErrInvalidCodeChallengeLen: 400,
|
||
|
}
|