]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blob - server/types/plugins/register-server-auth.model.ts
Bumped to version v5.2.1
[github/Chocobozzz/PeerTube.git] / server / types / plugins / register-server-auth.model.ts
1 import express from 'express'
2 import { UserAdminFlag, UserRole } from '@shared/models'
3 import { MOAuthToken, MUser } from '../models'
4
5 export type RegisterServerAuthOptions = RegisterServerAuthPassOptions | RegisterServerAuthExternalOptions
6
7 export type AuthenticatedResultUpdaterFieldName = 'displayName' | 'role' | 'adminFlags' | 'videoQuota' | 'videoQuotaDaily'
8
9 export 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
33 export interface RegisterServerExternalAuthenticatedResult extends RegisterServerAuthenticatedResult {
34 req: express.Request
35 res: express.Response
36 }
37
38 interface 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
51 export 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
63 export 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
70 export interface RegisterServerAuthExternalResult {
71 userAuthenticated (options: RegisterServerExternalAuthenticatedResult): void
72 }