summaryrefslogtreecommitdiff
path: root/vendor/codeberg.org/superseriousbusiness/oauth2/v4/manage.go
diff options
context:
space:
mode:
authorLibravatar tobi <31960611+tsmethurst@users.noreply.github.com>2025-03-02 16:42:51 +0100
committerLibravatar GitHub <noreply@github.com>2025-03-02 16:42:51 +0100
commit8488ac928651656c6f7bebf5eaabce62c2b9fb66 (patch)
tree94357311026e5ed96862a647400375a4543dd815 /vendor/codeberg.org/superseriousbusiness/oauth2/v4/manage.go
parent[chore] go-swagger -> codeberg (#3856) (diff)
downloadgotosocial-8488ac928651656c6f7bebf5eaabce62c2b9fb66.tar.xz
[chore] migrate oauth2 -> codeberg (#3857)
Diffstat (limited to 'vendor/codeberg.org/superseriousbusiness/oauth2/v4/manage.go')
-rw-r--r--vendor/codeberg.org/superseriousbusiness/oauth2/v4/manage.go50
1 files changed, 50 insertions, 0 deletions
diff --git a/vendor/codeberg.org/superseriousbusiness/oauth2/v4/manage.go b/vendor/codeberg.org/superseriousbusiness/oauth2/v4/manage.go
new file mode 100644
index 000000000..5c0bdf871
--- /dev/null
+++ b/vendor/codeberg.org/superseriousbusiness/oauth2/v4/manage.go
@@ -0,0 +1,50 @@
+package oauth2
+
+import (
+ "context"
+ "net/http"
+ "time"
+)
+
+// TokenGenerateRequest provide to generate the token request parameters
+type TokenGenerateRequest struct {
+ ClientID string
+ ClientSecret string
+ UserID string
+ RedirectURI string
+ Scope string
+ Code string
+ CodeChallenge string
+ CodeChallengeMethod CodeChallengeMethod
+ Refresh string
+ CodeVerifier string
+ AccessTokenExp time.Duration
+ Request *http.Request
+}
+
+// Manager authorization management interface
+type Manager interface {
+ // get the client information
+ GetClient(ctx context.Context, clientID string) (cli ClientInfo, err error)
+
+ // generate the authorization token(code)
+ GenerateAuthToken(ctx context.Context, rt ResponseType, tgr *TokenGenerateRequest) (authToken TokenInfo, err error)
+
+ // generate the access token
+ GenerateAccessToken(ctx context.Context, rt GrantType, tgr *TokenGenerateRequest) (accessToken TokenInfo, err error)
+
+ // refreshing an access token
+ RefreshAccessToken(ctx context.Context, tgr *TokenGenerateRequest) (accessToken TokenInfo, err error)
+
+ // use the access token to delete the token information
+ RemoveAccessToken(ctx context.Context, access string) (err error)
+
+ // use the refresh token to delete the token information
+ RemoveRefreshToken(ctx context.Context, refresh string) (err error)
+
+ // according to the access token for corresponding token information
+ LoadAccessToken(ctx context.Context, access string) (ti TokenInfo, err error)
+
+ // according to the refresh token for corresponding token information
+ LoadRefreshToken(ctx context.Context, refresh string) (ti TokenInfo, err error)
+}