X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=shared%2Fmodels%2Fserver%2Fcustom-config.model.ts;h=75d04423ada0be2d8035d49850107fd67e46d09c;hb=276250f0a36e00373166d91d539e5220d6f158c7;hp=851bf1854d31a33748dc9acd68609b7fcd2807cd;hpb=b763f88dd0f455ce0ccae9cb81182c985a47c101;p=github%2FChocobozzz%2FPeerTube.git diff --git a/shared/models/server/custom-config.model.ts b/shared/models/server/custom-config.model.ts index 851bf1854..75d04423a 100644 --- a/shared/models/server/custom-config.model.ts +++ b/shared/models/server/custom-config.model.ts @@ -1,6 +1,16 @@ import { NSFWPolicyType } from '../videos/nsfw-policy.type' import { BroadcastMessageLevel } from './broadcast-message-level.type' +export type ConfigResolutions = { + '240p': boolean + '360p': boolean + '480p': boolean + '720p': boolean + '1080p': boolean + '1440p': boolean + '2160p': boolean +} + export interface CustomConfig { instance: { name: string @@ -20,8 +30,10 @@ export interface CustomConfig { categories: number[] isNSFW: boolean - defaultClientRoute: string defaultNSFWPolicy: NSFWPolicyType + + defaultClientRoute: string + customizations: { javascript?: string css?: string @@ -47,12 +59,17 @@ export interface CustomConfig { captions: { size: number } + + torrents: { + size: number + } } signup: { enabled: boolean limit: number requiresEmailVerification: boolean + minimumAge: number } admin: { @@ -75,15 +92,11 @@ export interface CustomConfig { allowAudioFiles: boolean threads: number - resolutions: { - '0p': boolean - '240p': boolean - '360p': boolean - '480p': boolean - '720p': boolean - '1080p': boolean - '2160p': boolean - } + concurrency: number + + profile: string + + resolutions: ConfigResolutions & { '0p': boolean } webtorrent: { enabled: boolean @@ -94,8 +107,27 @@ export interface CustomConfig { } } + live: { + enabled: boolean + + allowReplay: boolean + + maxDuration: number + maxInstanceLives: number + maxUserLives: number + + transcoding: { + enabled: boolean + threads: number + profile: string + resolutions: ConfigResolutions + } + } + import: { videos: { + concurrency: number + http: { enabled: boolean } @@ -105,6 +137,15 @@ export interface CustomConfig { } } + trending: { + videos: { + algorithms: { + enabled: string[] + default: string + } + } + } + autoBlacklist: { videos: { ofUsers: { @@ -139,4 +180,18 @@ export interface CustomConfig { level: BroadcastMessageLevel dismissable: boolean } + + search: { + remoteUri: { + users: boolean + anonymous: boolean + } + + searchIndex: { + enabled: boolean + url: string + disableLocalSearch: boolean + isDefaultSearch: boolean + } + } }