X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=shared%2Fmodels%2Fserver%2Fcustom-config.model.ts;h=7d9d570b1047e4966161f196da122ae7ebb12ec7;hb=2a491182e483b97afb1b65c908b23cb48d591807;hp=4cc379b2a89bb93373b279ff2d53238a872271c0;hpb=73b3aa6429dfb2e31628fa09a479dce318289d7d;p=github%2FChocobozzz%2FPeerTube.git diff --git a/shared/models/server/custom-config.model.ts b/shared/models/server/custom-config.model.ts index 4cc379b2a..7d9d570b1 100644 --- a/shared/models/server/custom-config.model.ts +++ b/shared/models/server/custom-config.model.ts @@ -1,4 +1,16 @@ import { NSFWPolicyType } from '../videos/nsfw-policy.type' +import { BroadcastMessageLevel } from './broadcast-message-level.type' + +export type ConfigResolutions = { + '144p': boolean + '240p': boolean + '360p': boolean + '480p': boolean + '720p': boolean + '1080p': boolean + '1440p': boolean + '2160p': boolean +} export interface CustomConfig { instance: { @@ -6,15 +18,33 @@ export interface CustomConfig { shortDescription: string description: string terms: string + codeOfConduct: string + + creationReason: string + moderationInformation: string + administrator: string + maintenanceLifetime: string + businessModel: string + hardwareInformation: string + + languages: string[] + categories: number[] + isNSFW: boolean - defaultClientRoute: string defaultNSFWPolicy: NSFWPolicyType + + defaultClientRoute: string + customizations: { javascript?: string css?: string } } + theme: { + default: string + } + services: { twitter: { username: string @@ -22,6 +52,20 @@ export interface CustomConfig { } } + client: { + videos: { + miniature: { + preferAuthorDisplayName: boolean + } + } + + menu: { + login: { + redirectOnSingleExternalAuth: boolean + } + } + } + cache: { previews: { size: number @@ -30,12 +74,17 @@ export interface CustomConfig { captions: { size: number } + + torrents: { + size: number + } } signup: { enabled: boolean limit: number requiresEmailVerification: boolean + minimumAge: number } admin: { @@ -51,32 +100,84 @@ export interface CustomConfig { videoQuotaDaily: number } + videoChannels: { + maxPerUser: number + } + transcoding: { enabled: boolean + allowAdditionalExtensions: boolean allowAudioFiles: boolean + threads: number - resolutions: { - '240p': boolean - '360p': boolean - '480p': boolean - '720p': boolean - '1080p': boolean + concurrency: number + + profile: string + + resolutions: ConfigResolutions & { '0p': boolean } + + alwaysTranscodeOriginalResolution: boolean + + webtorrent: { + enabled: boolean } + hls: { enabled: boolean } } + live: { + enabled: boolean + + allowReplay: boolean + + latencySetting: { + enabled: boolean + } + + maxDuration: number + maxInstanceLives: number + maxUserLives: number + + transcoding: { + enabled: boolean + threads: number + profile: string + resolutions: ConfigResolutions + alwaysTranscodeOriginalResolution: boolean + } + } + + videoStudio: { + enabled: boolean + } + import: { videos: { + concurrency: number + http: { enabled: boolean - }, + } torrent: { enabled: boolean } } + videoChannelSynchronization: { + enabled: boolean + maxPerUser: number + } + } + + trending: { + videos: { + algorithms: { + enabled: string[] + default: string + } + } } autoBlacklist: { @@ -89,9 +190,42 @@ export interface CustomConfig { followers: { instance: { - enabled: boolean, + enabled: boolean manualApproval: boolean } } + followings: { + instance: { + autoFollowBack: { + enabled: boolean + } + + autoFollowIndex: { + enabled: boolean + indexUrl: string + } + } + } + + broadcastMessage: { + enabled: boolean + message: string + level: BroadcastMessageLevel + dismissable: boolean + } + + search: { + remoteUri: { + users: boolean + anonymous: boolean + } + + searchIndex: { + enabled: boolean + url: string + disableLocalSearch: boolean + isDefaultSearch: boolean + } + } }