diff options
author | 2021-08-12 21:03:24 +0200 | |
---|---|---|
committer | 2021-08-12 21:03:24 +0200 | |
commit | 98263a7de64269898a2f81207e38943b5c8e8653 (patch) | |
tree | 743c90f109a6c5d27832d1dcef2388d939f0f77a /vendor/github.com/superseriousbusiness/oauth2/v4/manage.go | |
parent | Text duplication fix (#137) (diff) | |
download | gotosocial-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.go | 50 |
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) +} |