Token
final class Token : Model, @unchecked Sendable
extension Token: ModelTokenAuthenticatable
A Token
model associates a randomly generated string with a User
.
A Token is generated upon each login, and revoked by deletion upon each logout.
The .token
value is used in between those events in an HTTP Bearer Authorization
header field to authenticate the user sending API requests. There is no
identifying user info in a .token
; the association to a specific User
is
done internally on the API server through this model.
-
Declaration
Swift
static let schema: String
-
The Token’s ID, provisioned automatically.
Declaration
Swift
@Token .ID var id: UUID? { get set }
-
The generated token value.
Declaration
Swift
@Token .Field var token: String { get set }
-
Timestamp of the model’s creation, set automatically.
Declaration
Swift
@Token .Timestamp var createdAt: Date? { get set }
-
Declaration
Swift
init()
-
Initializes a new Token.
Declaration
Swift
init(token: String, userID: UUID)
Parameters
token
The generated token string.
userID
The
User
associated to the token. -
Required key for HTTP Bearer Authorization token.
Declaration
Swift
static let valueKey: KeyPath<Token, Field<String>>
-
Declaration
Swift
static let userKey: KeyPath<Token, Parent<User>>
-
Declaration
Swift
var isValid: Bool { get }