Coverage for src/kwai/modules/identity/tokens/refresh_token.py: 100%
20 statements
« prev ^ index » next coverage.py v7.6.10, created at 2024-01-01 00:00 +0000
« prev ^ index » next coverage.py v7.6.10, created at 2024-01-01 00:00 +0000
1"""Module for a refresh token entity."""
3from dataclasses import dataclass, field, replace
4from typing import ClassVar, Self, Type
6from kwai.core.domain.entity import DataclassEntity
7from kwai.core.domain.value_objects.identifier import IntIdentifier
8from kwai.core.domain.value_objects.timestamp import Timestamp
9from kwai.modules.identity.tokens.access_token import AccessTokenEntity
10from kwai.modules.identity.tokens.token_identifier import TokenIdentifier
13class RefreshTokenIdentifier(IntIdentifier):
14 """Identifier for a refresh token."""
17@dataclass(kw_only=True, eq=False, slots=True, frozen=True)
18class RefreshTokenEntity(DataclassEntity):
19 """A refresh token entity.
21 Attributes:
22 access_token: The access token associated with this refresh token.
23 identifier: The actual token.
24 expiration: The expiration timestamp of the token.
25 revoked: Whether the token has been revoked.
26 """
28 ID: ClassVar[Type] = RefreshTokenIdentifier
30 access_token: AccessTokenEntity
31 identifier: TokenIdentifier = field(default_factory=TokenIdentifier.generate)
32 expiration: Timestamp = field(default_factory=Timestamp.create_now)
33 revoked: bool = field(default=False)
35 @property
36 def expired(self) -> bool:
37 """Return True when the token is expired."""
38 return self.expiration.is_past
40 def revoke(self) -> Self:
41 """Revoke the refresh token.
43 Returns:
44 A revoked refresh token.
45 """
46 return replace(
47 self, revoked=True, traceable_time=self.traceable_time.mark_for_update()
48 )