Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support for stateless refresh token and new openapi definition. #42

Conversation

danforero
Copy link

Problem

There is no way to refresh the token when this is read from a database (offline.access) there is a way to set the stored token in the client but the refresh token function does not send the code verification parameter.

Solution

I added two optional parameters to the OAuth2User constructor, also code_verifier is added as a class property.

generateUrlOptions: its type is GenerateAuthUrlOptions, if used it generates code_verifier.
token: its type is Token, it can be used with a token read from a database.

Token type is exported to be used outside of the client.

This PR also includes a test for this feature /examples/oauth2-offline_pkce_s256.ts, this example uses ../dist instead of the npm twitter library because this feature is not included yet in npm

Result

You will be able to create a client using a stored token for offline access.

@CLAassistant
Copy link

CLAassistant commented Sep 28, 2022

CLA assistant check
All committers have signed the CLA.

@danforero danforero changed the title new openapi definition, support for stateless refresh token Support for stateless refresh token and new openapi definition. Sep 28, 2022
@Monneraldo
Copy link

Monneraldo commented Dec 18, 2022 via email

@kochie
Copy link

kochie commented Dec 19, 2022

@danforero I opened your PR in my fork kochie#1

@Monneraldo
Copy link

Monneraldo commented Dec 19, 2022 via email

@Monneraldo
Copy link

Monneraldo commented Jan 1, 2023 via email

@Monneraldo
Copy link

Monneraldo commented Jan 7, 2023 via email

@maied12
Copy link

maied12 commented Jan 29, 2023

Problem

There is no way to refresh the token when this is read from a database (offline.access) there is a way to set the stored token in the client but the refresh token function does not send the code verification parameter.

Solution

I added two optional parameters to the OAuth2User constructor, also code_verifier is added as a class property.

generateUrlOptions: its type is GenerateAuthUrlOptions, if used it generates code_verifier.
token: its type is Token, it can be used with a token read from a database.

Token type is exported to be used outside of the client.

This PR also includes a test for this feature /examples/oauth2-offline_pkce_s256.ts, this example uses ../dist instead of the npm twitter library because this feature is not included yet in npm

Result

You will be able to create a client using a stored token for offline access.

@Monneraldo
Copy link

Monneraldo commented Jan 29, 2023 via email

@danforero
Copy link
Author

Twitter API v2 seems to have several problems with Tokens expiring before time, it's being almost a year and the problem is still there:

https://twittercommunity.com/t/refresh-token-expiring-with-offline-access-scope/168899

It looks like twitter API v2 development is abandoned, I'm, closing this PR.

@danforero danforero closed this Jan 30, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants