summaryrefslogtreecommitdiff
path: root/vendor/github.com/superseriousbusiness/oauth2/v4/manage.go
diff options
context:
space:
mode:
authorLibravatar Tobi Smethurst <31960611+tsmethurst@users.noreply.github.com>2021-08-12 21:03:24 +0200
committerLibravatar GitHub <noreply@github.com>2021-08-12 21:03:24 +0200
commit98263a7de64269898a2f81207e38943b5c8e8653 (patch)
tree743c90f109a6c5d27832d1dcef2388d939f0f77a /vendor/github.com/superseriousbusiness/oauth2/v4/manage.go
parentText duplication fix (#137) (diff)
downloadgotosocial-98263a7de64269898a2f81207e38943b5c8e8653.tar.xz
Grand test fixup (#138)
* start fixing up tests * fix up tests + automate with drone * fiddle with linting * messing about with drone.yml * some more fiddling * hmmm * add cache * add vendor directory * verbose * ci updates * update some little things * update sig
Diffstat (limited to 'vendor/github.com/superseriousbusiness/oauth2/v4/manage.go')
-rw-r--r--vendor/github.com/superseriousbusiness/oauth2/v4/manage.go50
1 files changed, 50 insertions, 0 deletions
diff --git a/vendor/github.com/superseriousbusiness/oauth2/v4/manage.go b/vendor/github.com/superseriousbusiness/oauth2/v4/manage.go
new file mode 100644
index 000000000..5c0bdf871
--- /dev/null
+++ b/vendor/github.com/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)
+}