X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=shared%2Fmodels%2Fserver%2Fserver-config.model.ts;h=49bb01708cbae88876d9a7d7d5e549741044869c;hb=93cae47925e4dd68b7d34a41927b2740b4fab1b4;hp=2cafedbbc7a59bf065088f0d716a37e14821c241;hpb=9a12f169c15b638fe78cf6e85a1993550a25e404;p=github%2FChocobozzz%2FPeerTube.git diff --git a/shared/models/server/server-config.model.ts b/shared/models/server/server-config.model.ts index 2cafedbbc..49bb01708 100644 --- a/shared/models/server/server-config.model.ts +++ b/shared/models/server/server-config.model.ts @@ -1,12 +1,27 @@ import { NSFWPolicyType } from '../videos/nsfw-policy.type' +import { ClientScript } from '../plugins/plugin-package-json.model' +import { PluginClientScope } from '../plugins/plugin-scope.type' + +export interface ServerConfigPlugin { + name: string + version: string + description: string + clientScripts: { [name in PluginClientScope]: ClientScript } +} + +export interface ServerConfigTheme extends ServerConfigPlugin { + css: string[] +} export interface ServerConfig { serverVersion: string + serverCommit?: string instance: { name: string shortDescription: string defaultClientRoute: string + isNSFW: boolean defaultNSFWPolicy: NSFWPolicyType customizations: { javascript: string @@ -14,12 +29,34 @@ export interface ServerConfig { } } + plugin: { + registered: ServerConfigPlugin[] + } + + theme: { + registered: ServerConfigTheme[] + default: string + } + + email: { + enabled: boolean + } + + contactForm: { + enabled: boolean + } + signup: { allowed: boolean, allowedForCurrentIP: boolean + requiresEmailVerification: boolean } transcoding: { + hls: { + enabled: boolean + } + enabledResolutions: number[] } @@ -28,6 +65,17 @@ export interface ServerConfig { http: { enabled: boolean } + torrent: { + enabled: boolean + } + } + } + + autoBlacklist: { + videos: { + ofUsers: { + enabled: boolean + } } } @@ -35,7 +83,7 @@ export interface ServerConfig { file: { size: { max: number - }, + } extensions: string[] } } @@ -63,5 +111,16 @@ export interface ServerConfig { user: { videoQuota: number + videoQuotaDaily: number + } + + trending: { + videos: { + intervalDays: number + } + } + + tracker: { + enabled: boolean } }