SessionService
SessionService
Contains methods relating to Session entities.
Sessions are neither automatically deleted when expired nor cleaned up periodically by Vendure. The How-to guide Expired Session Cleanup demonstrates how to create a Stand-alone CLI Script which calls the cleanupExpiredSessions method to automate this process.
class SessionService implements EntitySubscriberInterface {
constructor(connection: TransactionalConnection, configService: ConfigService, orderService: OrderService)
createNewAuthenticatedSession(ctx: RequestContext, user: User, authenticationStrategyName: string) => Promise<AuthenticatedSession>;
createAnonymousSession() => Promise<CachedSession>;
getSessionFromToken(sessionToken: string) => Promise<CachedSession | undefined>;
serializeSession(session: AuthenticatedSession | AnonymousSession) => CachedSession;
setActiveOrder(ctx: RequestContext, serializedSession: CachedSession, order: Order) => Promise<CachedSession>;
unsetActiveOrder(ctx: RequestContext, serializedSession: CachedSession) => Promise<CachedSession>;
setActiveChannel(serializedSession: CachedSession, channel: Channel) => Promise<CachedSession>;
deleteSessionsByUser(ctx: RequestContext, user: User) => Promise<void>;
deleteSessionsByActiveOrderId(ctx: RequestContext, activeOrderId: ID) => Promise<void>;
cleanupExpiredSessions(ctx: RequestContext) => Promise<void>;
}
- Implements:
EntitySubscriberInterface
constructor
(connection: TransactionalConnection, configService: ConfigService, orderService: OrderService) => SessionService
createNewAuthenticatedSession
(ctx: RequestContext, user: User, authenticationStrategyName: string) => Promise<AuthenticatedSession>
Creates a new AuthenticatedSession. To be used after successful authentication.
createAnonymousSession
() => Promise<CachedSession>
Create an AnonymousSession and caches it using the configured SessionCacheStrategy, and returns the cached session object.
getSessionFromToken
(sessionToken: string) => Promise<CachedSession | undefined>
Returns the cached session object matching the given session token.
serializeSession
(session: AuthenticatedSession | AnonymousSession) => CachedSession
Serializes a Session instance into a simplified plain object suitable for caching.
setActiveOrder
(ctx: RequestContext, serializedSession: CachedSession, order: Order) => Promise<CachedSession>
Sets the activeOrder
on the given cached session object and updates the cache.
unsetActiveOrder
(ctx: RequestContext, serializedSession: CachedSession) => Promise<CachedSession>
Clears the activeOrder
on the given cached session object and updates the cache.
setActiveChannel
(serializedSession: CachedSession, channel: Channel) => Promise<CachedSession>
Sets the activeChannel
on the given cached session object and updates the cache.
deleteSessionsByUser
(ctx: RequestContext, user: User) => Promise<void>
Deletes all existing sessions for the given user.
deleteSessionsByActiveOrderId
(ctx: RequestContext, activeOrderId: ID) => Promise<void>
Deletes all existing sessions with the given activeOrder.
cleanupExpiredSessions
Deletes all expired sessions.