Abstract Token Strategy
If the token strategies that are offered out of the box do not suit your needs you can create your own strategy. Your strategy should match the following interface:
- class allauth.headless.tokens.strategies.base.AbstractTokenStrategy
- create_access_token(request: HttpRequest) str | None
Create an access token.
While session tokens are required to handle the authentication process, depending on your requirements, a different type of token may be needed once authenticated.
For example, your app likely needs access to other APIs as well. These APIs may even be implemented using different technologies, in which case having a stateless token, possibly a JWT encoding the user ID, might be a good fit.
We make no assumptions in this regard. If you need access tokens, you will have to implement a token strategy that returns an access token here.
- create_access_token_payload(request: HttpRequest) dict[str, Any] | None
After authenticating, this method is called to create the access token response payload, exposing the access token and possibly other information such as a
refresh_tokenandexpires_in.
- abstractmethod create_session_token(request: HttpRequest) str
Create a session token for the request.session.
- get_session_token(request: HttpRequest) str | None
Returns the session token, if any.
- abstractmethod lookup_session(session_token: str) SessionBase | None
Looks up the Django session given the session token. Returns None if the session does not / no longer exist.
- refresh_token(refresh_token: str) tuple[str, str] | None
Validates the given refresh token, and if valid, returns a new access token and refresh token pair.