]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame_incremental - server/types/plugins/register-server-auth.model.ts
Merge branch 'release/5.0.0' into develop
[github/Chocobozzz/PeerTube.git] / server / types / plugins / register-server-auth.model.ts
... / ...
CommitLineData
1import express from 'express'
2import { UserAdminFlag, UserRole } from '@shared/models'
3import { MOAuthToken, MUser } from '../models'
4
5export type RegisterServerAuthOptions = RegisterServerAuthPassOptions | RegisterServerAuthExternalOptions
6
7export type AuthenticatedResultUpdaterFieldName = 'displayName' | 'role' | 'adminFlags' | 'videoQuota' | 'videoQuotaDaily'
8
9export interface RegisterServerAuthenticatedResult {
10 // Update the user profile if it already exists
11 // Default behaviour is no update
12 // Introduced in PeerTube >= 5.1
13 userUpdater?: <T> (options: {
14 fieldName: AuthenticatedResultUpdaterFieldName
15 currentValue: T
16 newValue: T
17 }) => T
18
19 username: string
20 email: string
21 role?: UserRole
22 displayName?: string
23
24 // PeerTube >= 5.1
25 adminFlags?: UserAdminFlag
26
27 // PeerTube >= 5.1
28 videoQuota?: number
29 // PeerTube >= 5.1
30 videoQuotaDaily?: number
31}
32
33export interface RegisterServerExternalAuthenticatedResult extends RegisterServerAuthenticatedResult {
34 req: express.Request
35 res: express.Response
36}
37
38interface RegisterServerAuthBase {
39 // Authentication name (a plugin can register multiple auth strategies)
40 authName: string
41
42 // Called by PeerTube when a user from your plugin logged out
43 // Returns a redirectUrl sent to the client or nothing
44 onLogout?(user: MUser, req: express.Request): Promise<string>
45
46 // Your plugin can hook PeerTube access/refresh token validity
47 // So you can control for your plugin the user session lifetime
48 hookTokenValidity?(options: { token: MOAuthToken, type: 'access' | 'refresh' }): Promise<{ valid: boolean }>
49}
50
51export interface RegisterServerAuthPassOptions extends RegisterServerAuthBase {
52 // Weight of this authentication so PeerTube tries the auth methods in DESC weight order
53 getWeight(): number
54
55 // Used by PeerTube to login a user
56 // Returns null if the login failed, or { username, email } on success
57 login(body: {
58 id: string
59 password: string
60 }): Promise<RegisterServerAuthenticatedResult | null>
61}
62
63export interface RegisterServerAuthExternalOptions extends RegisterServerAuthBase {
64 // Will be displayed in a block next to the login form
65 authDisplayName: () => string
66
67 onAuthRequest: (req: express.Request, res: express.Response) => void
68}
69
70export interface RegisterServerAuthExternalResult {
71 userAuthenticated (options: RegisterServerExternalAuthenticatedResult): void
72}