aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--client/src/app/+admin/config/edit-custom-config/edit-custom-config.component.ts2
-rw-r--r--client/src/app/+admin/config/edit-custom-config/edit-vod-transcoding.component.html4
-rw-r--r--client/src/app/+admin/config/edit-custom-config/edit-vod-transcoding.component.ts14
-rw-r--r--config/default.yaml2
-rw-r--r--config/production.yaml.example2
-rw-r--r--config/test.yaml2
-rw-r--r--server/controllers/api/config.ts4
-rw-r--r--server/controllers/misc.ts4
-rw-r--r--server/initializers/checker-after-init.ts38
-rw-r--r--server/initializers/checker-before-init.ts4
-rw-r--r--server/initializers/config.ts25
-rw-r--r--server/lib/server-config-manager.ts4
-rw-r--r--server/lib/transcoding/shared/job-builders/transcoding-job-queue-builder.ts4
-rw-r--r--server/lib/transcoding/shared/job-builders/transcoding-runner-job-builder.ts4
-rw-r--r--server/middlewares/validators/config.ts6
-rw-r--r--server/tests/api/check-params/config.ts4
-rw-r--r--server/tests/api/redundancy/redundancy.ts2
-rw-r--r--server/tests/api/server/config.ts6
-rw-r--r--server/tests/api/server/stats.ts2
-rw-r--r--server/tests/api/transcoding/audio-only.ts2
-rw-r--r--server/tests/api/transcoding/create-transcoding.ts4
-rw-r--r--server/tests/api/transcoding/hls.ts2
-rw-r--r--server/tests/api/transcoding/transcoder.ts10
-rw-r--r--server/tests/api/transcoding/update-while-transcoding.ts2
-rw-r--r--server/tests/api/transcoding/video-studio.ts2
-rw-r--r--server/tests/api/users/user-videos.ts2
-rw-r--r--server/tests/api/videos/video-imports.ts2
-rw-r--r--server/tests/feeds/feeds.ts2
-rw-r--r--server/tests/plugins/filter-hooks.ts2
-rw-r--r--server/tests/plugins/plugin-transcoding.ts2
-rw-r--r--server/tests/shared/videos.ts2
-rw-r--r--shared/models/server/custom-config.model.ts2
-rw-r--r--shared/models/server/server-config.model.ts2
-rw-r--r--shared/server-commands/server/config-command.ts6
-rw-r--r--support/doc/api/openapi.yaml4
-rw-r--r--support/docker/production/config/custom-environment-variables.yaml8
36 files changed, 108 insertions, 81 deletions
diff --git a/client/src/app/+admin/config/edit-custom-config/edit-custom-config.component.ts b/client/src/app/+admin/config/edit-custom-config/edit-custom-config.component.ts
index 9219d608b..b381473d6 100644
--- a/client/src/app/+admin/config/edit-custom-config/edit-custom-config.component.ts
+++ b/client/src/app/+admin/config/edit-custom-config/edit-custom-config.component.ts
@@ -190,7 +190,7 @@ export class EditCustomConfigComponent extends FormReactive implements OnInit {
190 hls: { 190 hls: {
191 enabled: null 191 enabled: null
192 }, 192 },
193 webtorrent: { 193 webVideos: {
194 enabled: null 194 enabled: null
195 }, 195 },
196 remoteRunners: { 196 remoteRunners: {
diff --git a/client/src/app/+admin/config/edit-custom-config/edit-vod-transcoding.component.html b/client/src/app/+admin/config/edit-custom-config/edit-vod-transcoding.component.html
index 7218511a9..accf2c28c 100644
--- a/client/src/app/+admin/config/edit-custom-config/edit-vod-transcoding.component.html
+++ b/client/src/app/+admin/config/edit-custom-config/edit-vod-transcoding.component.html
@@ -67,10 +67,10 @@
67 <div class="callout callout-light pt-2 mt-2 pb-0"> 67 <div class="callout callout-light pt-2 mt-2 pb-0">
68 <h3 class="callout-title" i18n>Output formats</h3> 68 <h3 class="callout-title" i18n>Output formats</h3>
69 69
70 <ng-container formGroupName="webtorrent"> 70 <ng-container formGroupName="webVideos">
71 <div class="form-group" [ngClass]="getTranscodingDisabledClass()"> 71 <div class="form-group" [ngClass]="getTranscodingDisabledClass()">
72 <my-peertube-checkbox 72 <my-peertube-checkbox
73 inputName="transcodingWebTorrentEnabled" formControlName="enabled" 73 inputName="transcodingWebVideosEnabled" formControlName="enabled"
74 i18n-labelText labelText="Web Videos enabled" 74 i18n-labelText labelText="Web Videos enabled"
75 > 75 >
76 <ng-template ptTemplate="help"> 76 <ng-template ptTemplate="help">
diff --git a/client/src/app/+admin/config/edit-custom-config/edit-vod-transcoding.component.ts b/client/src/app/+admin/config/edit-custom-config/edit-vod-transcoding.component.ts
index c5f4ecddb..6496e8753 100644
--- a/client/src/app/+admin/config/edit-custom-config/edit-vod-transcoding.component.ts
+++ b/client/src/app/+admin/config/edit-custom-config/edit-vod-transcoding.component.ts
@@ -90,9 +90,9 @@ export class EditVODTranscodingComponent implements OnInit, OnChanges {
90 const transcodingControl = this.form.get('transcoding.enabled') 90 const transcodingControl = this.form.get('transcoding.enabled')
91 const videoStudioControl = this.form.get('videoStudio.enabled') 91 const videoStudioControl = this.form.get('videoStudio.enabled')
92 const hlsControl = this.form.get('transcoding.hls.enabled') 92 const hlsControl = this.form.get('transcoding.hls.enabled')
93 const webtorrentControl = this.form.get('transcoding.webtorrent.enabled') 93 const webVideosControl = this.form.get('transcoding.webVideos.enabled')
94 94
95 webtorrentControl.valueChanges 95 webVideosControl.valueChanges
96 .subscribe(newValue => { 96 .subscribe(newValue => {
97 if (newValue === false && !hlsControl.disabled) { 97 if (newValue === false && !hlsControl.disabled) {
98 hlsControl.disable() 98 hlsControl.disable()
@@ -105,12 +105,12 @@ export class EditVODTranscodingComponent implements OnInit, OnChanges {
105 105
106 hlsControl.valueChanges 106 hlsControl.valueChanges
107 .subscribe(newValue => { 107 .subscribe(newValue => {
108 if (newValue === false && !webtorrentControl.disabled) { 108 if (newValue === false && !webVideosControl.disabled) {
109 webtorrentControl.disable() 109 webVideosControl.disable()
110 } 110 }
111 111
112 if (newValue === true && !webtorrentControl.enabled) { 112 if (newValue === true && !webVideosControl.enabled) {
113 webtorrentControl.enable() 113 webVideosControl.enable()
114 } 114 }
115 }) 115 })
116 116
@@ -122,7 +122,7 @@ export class EditVODTranscodingComponent implements OnInit, OnChanges {
122 }) 122 })
123 123
124 transcodingControl.updateValueAndValidity() 124 transcodingControl.updateValueAndValidity()
125 webtorrentControl.updateValueAndValidity() 125 webVideosControl.updateValueAndValidity()
126 videoStudioControl.updateValueAndValidity() 126 videoStudioControl.updateValueAndValidity()
127 hlsControl.updateValueAndValidity() 127 hlsControl.updateValueAndValidity()
128 } 128 }
diff --git a/config/default.yaml b/config/default.yaml
index 6f78fb7e9..a9e74095e 100644
--- a/config/default.yaml
+++ b/config/default.yaml
@@ -483,7 +483,7 @@ transcoding:
483 # Generate videos in a web compatible format 483 # Generate videos in a web compatible format
484 # If you also enabled the hls format, it will multiply videos storage by 2 484 # If you also enabled the hls format, it will multiply videos storage by 2
485 # If disabled, breaks federation with PeerTube instances < 2.1 485 # If disabled, breaks federation with PeerTube instances < 2.1
486 webtorrent: 486 web_videos:
487 enabled: false 487 enabled: false
488 488
489 # /!\ Requires ffmpeg >= 4.1 489 # /!\ Requires ffmpeg >= 4.1
diff --git a/config/production.yaml.example b/config/production.yaml.example
index 2898a45ac..8fccaa517 100644
--- a/config/production.yaml.example
+++ b/config/production.yaml.example
@@ -493,7 +493,7 @@ transcoding:
493 # Generate videos in a web compatible format 493 # Generate videos in a web compatible format
494 # If you also enabled the hls format, it will multiply videos storage by 2 494 # If you also enabled the hls format, it will multiply videos storage by 2
495 # If disabled, breaks federation with PeerTube instances < 2.1 495 # If disabled, breaks federation with PeerTube instances < 2.1
496 webtorrent: 496 web_videos:
497 enabled: false 497 enabled: false
498 498
499 # /!\ Requires ffmpeg >= 4.1 499 # /!\ Requires ffmpeg >= 4.1
diff --git a/config/test.yaml b/config/test.yaml
index 41ec0917e..cc642327c 100644
--- a/config/test.yaml
+++ b/config/test.yaml
@@ -97,7 +97,7 @@ transcoding:
97 1080p: true 97 1080p: true
98 1440p: true 98 1440p: true
99 2160p: true 99 2160p: true
100 webtorrent: 100 web_videos:
101 enabled: true 101 enabled: true
102 hls: 102 hls:
103 enabled: true 103 enabled: true
diff --git a/server/controllers/api/config.ts b/server/controllers/api/config.ts
index c1f6756de..0980ec10a 100644
--- a/server/controllers/api/config.ts
+++ b/server/controllers/api/config.ts
@@ -242,8 +242,8 @@ function customConfig (): CustomConfig {
242 '2160p': CONFIG.TRANSCODING.RESOLUTIONS['2160p'] 242 '2160p': CONFIG.TRANSCODING.RESOLUTIONS['2160p']
243 }, 243 },
244 alwaysTranscodeOriginalResolution: CONFIG.TRANSCODING.ALWAYS_TRANSCODE_ORIGINAL_RESOLUTION, 244 alwaysTranscodeOriginalResolution: CONFIG.TRANSCODING.ALWAYS_TRANSCODE_ORIGINAL_RESOLUTION,
245 webtorrent: { 245 webVideos: {
246 enabled: CONFIG.TRANSCODING.WEBTORRENT.ENABLED 246 enabled: CONFIG.TRANSCODING.WEB_VIDEOS.ENABLED
247 }, 247 },
248 hls: { 248 hls: {
249 enabled: CONFIG.TRANSCODING.HLS.ENABLED 249 enabled: CONFIG.TRANSCODING.HLS.ENABLED
diff --git a/server/controllers/misc.ts b/server/controllers/misc.ts
index 4c8af2adc..163352ac5 100644
--- a/server/controllers/misc.ts
+++ b/server/controllers/misc.ts
@@ -120,8 +120,8 @@ async function generateNodeinfo (req: express.Request, res: express.Response) {
120 hls: { 120 hls: {
121 enabled: CONFIG.TRANSCODING.HLS.ENABLED 121 enabled: CONFIG.TRANSCODING.HLS.ENABLED
122 }, 122 },
123 webtorrent: { 123 web_videos: {
124 enabled: CONFIG.TRANSCODING.WEBTORRENT.ENABLED 124 enabled: CONFIG.TRANSCODING.WEB_VIDEOS.ENABLED
125 }, 125 },
126 enabledResolutions: ServerConfigManager.Instance.getEnabledResolutions('vod') 126 enabledResolutions: ServerConfigManager.Instance.getEnabledResolutions('vod')
127 }, 127 },
diff --git a/server/initializers/checker-after-init.ts b/server/initializers/checker-after-init.ts
index 21bc5911c..906a918e3 100644
--- a/server/initializers/checker-after-init.ts
+++ b/server/initializers/checker-after-init.ts
@@ -1,4 +1,5 @@
1import config from 'config' 1import config from 'config'
2import { readFileSync, writeFileSync } from 'fs-extra'
2import { URL } from 'url' 3import { URL } from 'url'
3import { uniqify } from '@shared/core-utils' 4import { uniqify } from '@shared/core-utils'
4import { getFFmpegVersion } from '@shared/ffmpeg' 5import { getFFmpegVersion } from '@shared/ffmpeg'
@@ -10,7 +11,7 @@ import { logger } from '../helpers/logger'
10import { ApplicationModel, getServerActor } from '../models/application/application' 11import { ApplicationModel, getServerActor } from '../models/application/application'
11import { OAuthClientModel } from '../models/oauth/oauth-client' 12import { OAuthClientModel } from '../models/oauth/oauth-client'
12import { UserModel } from '../models/user/user' 13import { UserModel } from '../models/user/user'
13import { CONFIG, isEmailEnabled } from './config' 14import { CONFIG, getLocalConfigFilePath, isEmailEnabled, reloadConfig } from './config'
14import { WEBSERVER } from './constants' 15import { WEBSERVER } from './constants'
15 16
16async function checkActivityPubUrls () { 17async function checkActivityPubUrls () {
@@ -37,10 +38,7 @@ function checkConfig () {
37 const configFiles = config.util.getConfigSources().map(s => s.name).join(' -> ') 38 const configFiles = config.util.getConfigSources().map(s => s.name).join(' -> ')
38 logger.info('Using following configuration file hierarchy: %s.', configFiles) 39 logger.info('Using following configuration file hierarchy: %s.', configFiles)
39 40
40 // Moved configuration keys 41 checkRemovedConfigKeys()
41 if (config.has('services.csp-logger')) {
42 logger.warn('services.csp-logger configuration has been renamed to csp.report_uri. Please update your configuration file.')
43 }
44 42
45 checkSecretsConfig() 43 checkSecretsConfig()
46 checkEmailConfig() 44 checkEmailConfig()
@@ -104,6 +102,34 @@ export {
104 102
105// --------------------------------------------------------------------------- 103// ---------------------------------------------------------------------------
106 104
105function checkRemovedConfigKeys () {
106 // Moved configuration keys
107 if (config.has('services.csp-logger')) {
108 logger.warn('services.csp-logger configuration has been renamed to csp.report_uri. Please update your configuration file.')
109 }
110
111 if (config.has('transcoding.webtorrent.enabled')) {
112 const localConfigPath = getLocalConfigFilePath()
113
114 const content = readFileSync(localConfigPath, { encoding: 'utf-8' })
115 if (!content.includes('"webtorrent"')) {
116 throw new Error('Please rename transcoding.webtorrent.enabled key to transcoding.web_videos.enabled in your configuration file')
117 }
118
119 try {
120 logger.info(
121 'Replacing "transcoding.webtorrent.enabled" key to "transcoding.web_videos.enabled" in your local configuration ' + localConfigPath
122 )
123
124 writeFileSync(localConfigPath, content.replace('"webtorrent"', '"web_videos"'), { encoding: 'utf-8' })
125
126 reloadConfig()
127 } catch (err) {
128 logger.error('Cannot write new configuration to file ' + localConfigPath, { err })
129 }
130 }
131}
132
107function checkSecretsConfig () { 133function checkSecretsConfig () {
108 if (!CONFIG.SECRETS.PEERTUBE) { 134 if (!CONFIG.SECRETS.PEERTUBE) {
109 throw new Error('secrets.peertube is missing in config. Generate one using `openssl rand -hex 32`') 135 throw new Error('secrets.peertube is missing in config. Generate one using `openssl rand -hex 32`')
@@ -198,7 +224,7 @@ function checkStorageConfig () {
198 224
199function checkTranscodingConfig () { 225function checkTranscodingConfig () {
200 if (CONFIG.TRANSCODING.ENABLED) { 226 if (CONFIG.TRANSCODING.ENABLED) {
201 if (CONFIG.TRANSCODING.WEBTORRENT.ENABLED === false && CONFIG.TRANSCODING.HLS.ENABLED === false) { 227 if (CONFIG.TRANSCODING.WEB_VIDEOS.ENABLED === false && CONFIG.TRANSCODING.HLS.ENABLED === false) {
202 throw new Error('You need to enable at least Web Video transcoding or HLS transcoding.') 228 throw new Error('You need to enable at least Web Video transcoding or HLS transcoding.')
203 } 229 }
204 230
diff --git a/server/initializers/checker-before-init.ts b/server/initializers/checker-before-init.ts
index 939b73344..3d117d1b9 100644
--- a/server/initializers/checker-before-init.ts
+++ b/server/initializers/checker-before-init.ts
@@ -34,8 +34,8 @@ function checkMissedConfig () {
34 'signup.enabled', 'signup.limit', 'signup.requires_approval', 'signup.requires_email_verification', 'signup.minimum_age', 34 'signup.enabled', 'signup.limit', 'signup.requires_approval', 'signup.requires_email_verification', 'signup.minimum_age',
35 'signup.filters.cidr.whitelist', 'signup.filters.cidr.blacklist', 35 'signup.filters.cidr.whitelist', 'signup.filters.cidr.blacklist',
36 'redundancy.videos.strategies', 'redundancy.videos.check_interval', 36 'redundancy.videos.strategies', 'redundancy.videos.check_interval',
37 'transcoding.enabled', 'transcoding.threads', 'transcoding.allow_additional_extensions', 'transcoding.hls.enabled', 37 'transcoding.enabled', 'transcoding.threads', 'transcoding.allow_additional_extensions', 'transcoding.web_videos.enabled',
38 'transcoding.profile', 'transcoding.concurrency', 38 'transcoding.hls.enabled', 'transcoding.profile', 'transcoding.concurrency',
39 'transcoding.resolutions.0p', 'transcoding.resolutions.144p', 'transcoding.resolutions.240p', 'transcoding.resolutions.360p', 39 'transcoding.resolutions.0p', 'transcoding.resolutions.144p', 'transcoding.resolutions.240p', 'transcoding.resolutions.360p',
40 'transcoding.resolutions.480p', 'transcoding.resolutions.720p', 'transcoding.resolutions.1080p', 'transcoding.resolutions.1440p', 40 'transcoding.resolutions.480p', 'transcoding.resolutions.720p', 'transcoding.resolutions.1080p', 'transcoding.resolutions.1440p',
41 'transcoding.resolutions.2160p', 'transcoding.always_transcode_original_resolution', 'transcoding.remote_runners.enabled', 41 'transcoding.resolutions.2160p', 'transcoding.always_transcode_original_resolution', 'transcoding.remote_runners.enabled',
diff --git a/server/initializers/config.ts b/server/initializers/config.ts
index 60ab6e204..5301a1708 100644
--- a/server/initializers/config.ts
+++ b/server/initializers/config.ts
@@ -371,8 +371,8 @@ const CONFIG = {
371 HLS: { 371 HLS: {
372 get ENABLED () { return config.get<boolean>('transcoding.hls.enabled') } 372 get ENABLED () { return config.get<boolean>('transcoding.hls.enabled') }
373 }, 373 },
374 WEBTORRENT: { 374 WEB_VIDEOS: {
375 get ENABLED () { return config.get<boolean>('transcoding.webtorrent.enabled') } 375 get ENABLED () { return config.get<boolean>('transcoding.web_videos.enabled') }
376 }, 376 },
377 REMOTE_RUNNERS: { 377 REMOTE_RUNNERS: {
378 get ENABLED () { return config.get<boolean>('transcoding.remote_runners.enabled') } 378 get ENABLED () { return config.get<boolean>('transcoding.remote_runners.enabled') }
@@ -584,16 +584,6 @@ function isEmailEnabled () {
584 return false 584 return false
585} 585}
586 586
587// ---------------------------------------------------------------------------
588
589export {
590 CONFIG,
591 registerConfigChangedHandler,
592 isEmailEnabled
593}
594
595// ---------------------------------------------------------------------------
596
597function getLocalConfigFilePath () { 587function getLocalConfigFilePath () {
598 const localConfigDir = getLocalConfigDir() 588 const localConfigDir = getLocalConfigDir()
599 589
@@ -604,6 +594,17 @@ function getLocalConfigFilePath () {
604 return join(localConfigDir, filename + '.json') 594 return join(localConfigDir, filename + '.json')
605} 595}
606 596
597// ---------------------------------------------------------------------------
598
599export {
600 CONFIG,
601 getLocalConfigFilePath,
602 registerConfigChangedHandler,
603 isEmailEnabled
604}
605
606// ---------------------------------------------------------------------------
607
607function getLocalConfigDir () { 608function getLocalConfigDir () {
608 if (process.env.PEERTUBE_LOCAL_CONFIG) return process.env.PEERTUBE_LOCAL_CONFIG 609 if (process.env.PEERTUBE_LOCAL_CONFIG) return process.env.PEERTUBE_LOCAL_CONFIG
609 610
diff --git a/server/lib/server-config-manager.ts b/server/lib/server-config-manager.ts
index 924adb337..5ce89b16d 100644
--- a/server/lib/server-config-manager.ts
+++ b/server/lib/server-config-manager.ts
@@ -132,8 +132,8 @@ class ServerConfigManager {
132 hls: { 132 hls: {
133 enabled: CONFIG.TRANSCODING.ENABLED && CONFIG.TRANSCODING.HLS.ENABLED 133 enabled: CONFIG.TRANSCODING.ENABLED && CONFIG.TRANSCODING.HLS.ENABLED
134 }, 134 },
135 webtorrent: { 135 web_videos: {
136 enabled: CONFIG.TRANSCODING.ENABLED && CONFIG.TRANSCODING.WEBTORRENT.ENABLED 136 enabled: CONFIG.TRANSCODING.ENABLED && CONFIG.TRANSCODING.WEB_VIDEOS.ENABLED
137 }, 137 },
138 enabledResolutions: this.getEnabledResolutions('vod'), 138 enabledResolutions: this.getEnabledResolutions('vod'),
139 profile: CONFIG.TRANSCODING.PROFILE, 139 profile: CONFIG.TRANSCODING.PROFILE,
diff --git a/server/lib/transcoding/shared/job-builders/transcoding-job-queue-builder.ts b/server/lib/transcoding/shared/job-builders/transcoding-job-queue-builder.ts
index 2ecd57249..0505c2b2f 100644
--- a/server/lib/transcoding/shared/job-builders/transcoding-job-queue-builder.ts
+++ b/server/lib/transcoding/shared/job-builders/transcoding-job-queue-builder.ts
@@ -60,7 +60,7 @@ export class TranscodingJobQueueBuilder extends AbstractJobBuilder {
60 if (CONFIG.TRANSCODING.HLS.ENABLED === true) { 60 if (CONFIG.TRANSCODING.HLS.ENABLED === true) {
61 nextTranscodingSequentialJobPayloads.push([ 61 nextTranscodingSequentialJobPayloads.push([
62 this.buildHLSJobPayload({ 62 this.buildHLSJobPayload({
63 deleteWebVideoFiles: CONFIG.TRANSCODING.WEBTORRENT.ENABLED === false, 63 deleteWebVideoFiles: CONFIG.TRANSCODING.WEB_VIDEOS.ENABLED === false,
64 64
65 // We had some issues with a web video quick transcoded while producing a HLS version of it 65 // We had some issues with a web video quick transcoded while producing a HLS version of it
66 copyCodecs: !quickTranscode, 66 copyCodecs: !quickTranscode,
@@ -208,7 +208,7 @@ export class TranscodingJobQueueBuilder extends AbstractJobBuilder {
208 for (const resolution of resolutionsEnabled) { 208 for (const resolution of resolutionsEnabled) {
209 const fps = computeOutputFPS({ inputFPS: inputVideoFPS, resolution }) 209 const fps = computeOutputFPS({ inputFPS: inputVideoFPS, resolution })
210 210
211 if (CONFIG.TRANSCODING.WEBTORRENT.ENABLED) { 211 if (CONFIG.TRANSCODING.WEB_VIDEOS.ENABLED) {
212 const payloads: (NewWebVideoResolutionTranscodingPayload | HLSTranscodingPayload)[] = [ 212 const payloads: (NewWebVideoResolutionTranscodingPayload | HLSTranscodingPayload)[] = [
213 this.buildWebVideoJobPayload({ 213 this.buildWebVideoJobPayload({
214 videoUUID: video.uuid, 214 videoUUID: video.uuid,
diff --git a/server/lib/transcoding/shared/job-builders/transcoding-runner-job-builder.ts b/server/lib/transcoding/shared/job-builders/transcoding-runner-job-builder.ts
index b98172c2d..c0a45f40e 100644
--- a/server/lib/transcoding/shared/job-builders/transcoding-runner-job-builder.ts
+++ b/server/lib/transcoding/shared/job-builders/transcoding-runner-job-builder.ts
@@ -62,7 +62,7 @@ export class TranscodingRunnerJobBuilder extends AbstractJobBuilder {
62 if (CONFIG.TRANSCODING.HLS.ENABLED === true) { 62 if (CONFIG.TRANSCODING.HLS.ENABLED === true) {
63 await new VODHLSTranscodingJobHandler().create({ 63 await new VODHLSTranscodingJobHandler().create({
64 video, 64 video,
65 deleteWebVideoFiles: CONFIG.TRANSCODING.WEBTORRENT.ENABLED === false, 65 deleteWebVideoFiles: CONFIG.TRANSCODING.WEB_VIDEOS.ENABLED === false,
66 resolution: maxResolution, 66 resolution: maxResolution,
67 fps, 67 fps,
68 isNewVideo, 68 isNewVideo,
@@ -169,7 +169,7 @@ export class TranscodingRunnerJobBuilder extends AbstractJobBuilder {
169 for (const resolution of resolutionsEnabled) { 169 for (const resolution of resolutionsEnabled) {
170 const fps = computeOutputFPS({ inputFPS: inputVideoFPS, resolution }) 170 const fps = computeOutputFPS({ inputFPS: inputVideoFPS, resolution })
171 171
172 if (CONFIG.TRANSCODING.WEBTORRENT.ENABLED) { 172 if (CONFIG.TRANSCODING.WEB_VIDEOS.ENABLED) {
173 await new VODWebVideoTranscodingJobHandler().create({ 173 await new VODWebVideoTranscodingJobHandler().create({
174 video, 174 video,
175 resolution, 175 resolution,
diff --git a/server/middlewares/validators/config.ts b/server/middlewares/validators/config.ts
index 7029a857f..a6dbba524 100644
--- a/server/middlewares/validators/config.ts
+++ b/server/middlewares/validators/config.ts
@@ -59,7 +59,7 @@ const customConfigUpdateValidator = [
59 59
60 body('transcoding.alwaysTranscodeOriginalResolution').isBoolean(), 60 body('transcoding.alwaysTranscodeOriginalResolution').isBoolean(),
61 61
62 body('transcoding.webtorrent.enabled').isBoolean(), 62 body('transcoding.webVideos.enabled').isBoolean(),
63 body('transcoding.hls.enabled').isBoolean(), 63 body('transcoding.hls.enabled').isBoolean(),
64 64
65 body('videoStudio.enabled').isBoolean(), 65 body('videoStudio.enabled').isBoolean(),
@@ -153,8 +153,8 @@ function checkInvalidConfigIfEmailDisabled (customConfig: CustomConfig, res: exp
153function checkInvalidTranscodingConfig (customConfig: CustomConfig, res: express.Response) { 153function checkInvalidTranscodingConfig (customConfig: CustomConfig, res: express.Response) {
154 if (customConfig.transcoding.enabled === false) return true 154 if (customConfig.transcoding.enabled === false) return true
155 155
156 if (customConfig.transcoding.webtorrent.enabled === false && customConfig.transcoding.hls.enabled === false) { 156 if (customConfig.transcoding.webVideos.enabled === false && customConfig.transcoding.hls.enabled === false) {
157 res.fail({ message: 'You need to enable at least webtorrent transcoding or hls transcoding' }) 157 res.fail({ message: 'You need to enable at least web_videos transcoding or hls transcoding' })
158 return false 158 return false
159 } 159 }
160 160
diff --git a/server/tests/api/check-params/config.ts b/server/tests/api/check-params/config.ts
index 7f825f79e..80b616ccf 100644
--- a/server/tests/api/check-params/config.ts
+++ b/server/tests/api/check-params/config.ts
@@ -126,7 +126,7 @@ describe('Test config API validators', function () {
126 '2160p': false 126 '2160p': false
127 }, 127 },
128 alwaysTranscodeOriginalResolution: false, 128 alwaysTranscodeOriginalResolution: false,
129 webtorrent: { 129 webVideos: {
130 enabled: true 130 enabled: true
131 }, 131 },
132 hls: { 132 hls: {
@@ -353,7 +353,7 @@ describe('Test config API validators', function () {
353 hls: { 353 hls: {
354 enabled: false 354 enabled: false
355 }, 355 },
356 webtorrent: { 356 web_videos: {
357 enabled: false 357 enabled: false
358 } 358 }
359 } 359 }
diff --git a/server/tests/api/redundancy/redundancy.ts b/server/tests/api/redundancy/redundancy.ts
index b35059c29..9a8cb4f51 100644
--- a/server/tests/api/redundancy/redundancy.ts
+++ b/server/tests/api/redundancy/redundancy.ts
@@ -60,7 +60,7 @@ async function createServers (strategy: VideoRedundancyStrategy | null, addition
60 60
61 const config = { 61 const config = {
62 transcoding: { 62 transcoding: {
63 webtorrent: { 63 web_videos: {
64 enabled: withWebVideo 64 enabled: withWebVideo
65 }, 65 },
66 hls: { 66 hls: {
diff --git a/server/tests/api/server/config.ts b/server/tests/api/server/config.ts
index efa7b50e3..0e700eddb 100644
--- a/server/tests/api/server/config.ts
+++ b/server/tests/api/server/config.ts
@@ -79,7 +79,7 @@ function checkInitialConfig (server: PeerTubeServer, data: CustomConfig) {
79 expect(data.transcoding.resolutions['1440p']).to.be.true 79 expect(data.transcoding.resolutions['1440p']).to.be.true
80 expect(data.transcoding.resolutions['2160p']).to.be.true 80 expect(data.transcoding.resolutions['2160p']).to.be.true
81 expect(data.transcoding.alwaysTranscodeOriginalResolution).to.be.true 81 expect(data.transcoding.alwaysTranscodeOriginalResolution).to.be.true
82 expect(data.transcoding.webtorrent.enabled).to.be.true 82 expect(data.transcoding.webVideos.enabled).to.be.true
83 expect(data.transcoding.hls.enabled).to.be.true 83 expect(data.transcoding.hls.enabled).to.be.true
84 84
85 expect(data.live.enabled).to.be.false 85 expect(data.live.enabled).to.be.false
@@ -192,7 +192,7 @@ function checkUpdatedConfig (data: CustomConfig) {
192 expect(data.transcoding.resolutions['2160p']).to.be.false 192 expect(data.transcoding.resolutions['2160p']).to.be.false
193 expect(data.transcoding.alwaysTranscodeOriginalResolution).to.be.false 193 expect(data.transcoding.alwaysTranscodeOriginalResolution).to.be.false
194 expect(data.transcoding.hls.enabled).to.be.false 194 expect(data.transcoding.hls.enabled).to.be.false
195 expect(data.transcoding.webtorrent.enabled).to.be.true 195 expect(data.transcoding.webVideos.enabled).to.be.true
196 196
197 expect(data.live.enabled).to.be.true 197 expect(data.live.enabled).to.be.true
198 expect(data.live.allowReplay).to.be.true 198 expect(data.live.allowReplay).to.be.true
@@ -344,7 +344,7 @@ const newCustomConfig: CustomConfig = {
344 '2160p': false 344 '2160p': false
345 }, 345 },
346 alwaysTranscodeOriginalResolution: false, 346 alwaysTranscodeOriginalResolution: false,
347 webtorrent: { 347 webVideos: {
348 enabled: true 348 enabled: true
349 }, 349 },
350 hls: { 350 hls: {
diff --git a/server/tests/api/server/stats.ts b/server/tests/api/server/stats.ts
index aad0d231a..a1bf189fa 100644
--- a/server/tests/api/server/stats.ts
+++ b/server/tests/api/server/stats.ts
@@ -194,7 +194,7 @@ describe('Test stats (excluding redundancy)', function () {
194 newConfig: { 194 newConfig: {
195 transcoding: { 195 transcoding: {
196 enabled: true, 196 enabled: true,
197 webtorrent: { 197 webVideos: {
198 enabled: true 198 enabled: true
199 }, 199 },
200 hls: { 200 hls: {
diff --git a/server/tests/api/transcoding/audio-only.ts b/server/tests/api/transcoding/audio-only.ts
index aa1113fc1..f4cc012ef 100644
--- a/server/tests/api/transcoding/audio-only.ts
+++ b/server/tests/api/transcoding/audio-only.ts
@@ -37,7 +37,7 @@ describe('Test audio only video transcoding', function () {
37 hls: { 37 hls: {
38 enabled: true 38 enabled: true
39 }, 39 },
40 webtorrent: { 40 web_videos: {
41 enabled: true 41 enabled: true
42 } 42 }
43 } 43 }
diff --git a/server/tests/api/transcoding/create-transcoding.ts b/server/tests/api/transcoding/create-transcoding.ts
index 21a63f547..9a891043c 100644
--- a/server/tests/api/transcoding/create-transcoding.ts
+++ b/server/tests/api/transcoding/create-transcoding.ts
@@ -165,7 +165,7 @@ function runTests (enableObjectStorage: boolean) {
165 enabled: true, 165 enabled: true,
166 resolutions: ConfigCommand.getCustomConfigResolutions(false), 166 resolutions: ConfigCommand.getCustomConfigResolutions(false),
167 167
168 webtorrent: { 168 webVideos: {
169 enabled: true 169 enabled: true
170 }, 170 },
171 hls: { 171 hls: {
@@ -201,7 +201,7 @@ function runTests (enableObjectStorage: boolean) {
201 enabled: true, 201 enabled: true,
202 resolutions: ConfigCommand.getCustomConfigResolutions(true), 202 resolutions: ConfigCommand.getCustomConfigResolutions(true),
203 203
204 webtorrent: { 204 webVideos: {
205 enabled: true 205 enabled: true
206 }, 206 },
207 hls: { 207 hls: {
diff --git a/server/tests/api/transcoding/hls.ts b/server/tests/api/transcoding/hls.ts
index ba889e718..0d2fc0fba 100644
--- a/server/tests/api/transcoding/hls.ts
+++ b/server/tests/api/transcoding/hls.ts
@@ -136,7 +136,7 @@ describe('Test HLS videos', function () {
136 hls: { 136 hls: {
137 enabled: true 137 enabled: true
138 }, 138 },
139 webtorrent: { 139 webVideos: {
140 enabled: false 140 enabled: false
141 } 141 }
142 } 142 }
diff --git a/server/tests/api/transcoding/transcoder.ts b/server/tests/api/transcoding/transcoder.ts
index 36e1d90f4..b899b736d 100644
--- a/server/tests/api/transcoding/transcoder.ts
+++ b/server/tests/api/transcoding/transcoder.ts
@@ -31,7 +31,7 @@ function updateConfigForTranscoding (server: PeerTubeServer) {
31 allowAdditionalExtensions: true, 31 allowAdditionalExtensions: true,
32 allowAudioFiles: true, 32 allowAudioFiles: true,
33 hls: { enabled: true }, 33 hls: { enabled: true },
34 webtorrent: { enabled: true }, 34 webVideos: { enabled: true },
35 resolutions: { 35 resolutions: {
36 '0p': false, 36 '0p': false,
37 '144p': true, 37 '144p': true,
@@ -333,7 +333,7 @@ describe('Test video transcoding', function () {
333 newConfig: { 333 newConfig: {
334 transcoding: { 334 transcoding: {
335 hls: { enabled: true }, 335 hls: { enabled: true },
336 webtorrent: { enabled: true }, 336 webVideos: { enabled: true },
337 resolutions: { 337 resolutions: {
338 '0p': false, 338 '0p': false,
339 '144p': false, 339 '144p': false,
@@ -405,7 +405,7 @@ describe('Test video transcoding', function () {
405 newConfig: { 405 newConfig: {
406 transcoding: { 406 transcoding: {
407 hls: { enabled: true }, 407 hls: { enabled: true },
408 webtorrent: { enabled: true }, 408 webVideos: { enabled: true },
409 resolutions: { 409 resolutions: {
410 '0p': true, 410 '0p': true,
411 '144p': false, 411 '144p': false,
@@ -586,7 +586,7 @@ describe('Test video transcoding', function () {
586 '1440p': true, 586 '1440p': true,
587 '2160p': true 587 '2160p': true
588 }, 588 },
589 webtorrent: { enabled: true }, 589 web_videos: { enabled: true },
590 hls: { enabled: true } 590 hls: { enabled: true }
591 } 591 }
592 } 592 }
@@ -728,7 +728,7 @@ describe('Test video transcoding', function () {
728 transcoding: { 728 transcoding: {
729 enabled: true, 729 enabled: true,
730 hls: { enabled: true }, 730 hls: { enabled: true },
731 webtorrent: { enabled: true }, 731 webVideos: { enabled: true },
732 resolutions: { 732 resolutions: {
733 '0p': false, 733 '0p': false,
734 '144p': false, 734 '144p': false,
diff --git a/server/tests/api/transcoding/update-while-transcoding.ts b/server/tests/api/transcoding/update-while-transcoding.ts
index 2e0edc770..cfb4fa0cc 100644
--- a/server/tests/api/transcoding/update-while-transcoding.ts
+++ b/server/tests/api/transcoding/update-while-transcoding.ts
@@ -121,7 +121,7 @@ describe('Test update video privacy while transcoding', function () {
121 hls: { 121 hls: {
122 enabled: true 122 enabled: true
123 }, 123 },
124 webtorrent: { 124 webVideos: {
125 enabled: false 125 enabled: false
126 } 126 }
127 } 127 }
diff --git a/server/tests/api/transcoding/video-studio.ts b/server/tests/api/transcoding/video-studio.ts
index 2595d3cdb..ba68f8e24 100644
--- a/server/tests/api/transcoding/video-studio.ts
+++ b/server/tests/api/transcoding/video-studio.ts
@@ -277,7 +277,7 @@ describe('Test video studio', function () {
277 await servers[0].config.updateExistingSubConfig({ 277 await servers[0].config.updateExistingSubConfig({
278 newConfig: { 278 newConfig: {
279 transcoding: { 279 transcoding: {
280 webtorrent: { 280 webVideos: {
281 enabled: false 281 enabled: false
282 } 282 }
283 } 283 }
diff --git a/server/tests/api/users/user-videos.ts b/server/tests/api/users/user-videos.ts
index 70f22e2eb..77226e48e 100644
--- a/server/tests/api/users/user-videos.ts
+++ b/server/tests/api/users/user-videos.ts
@@ -189,7 +189,7 @@ describe('Test user videos', function () {
189 189
190 { 190 {
191 const config = await server.config.getCustomConfig() 191 const config = await server.config.getCustomConfig()
192 config.transcoding.webtorrent.enabled = false 192 config.transcoding.webVideos.enabled = false
193 config.transcoding.hls.enabled = true 193 config.transcoding.hls.enabled = true
194 config.transcoding.enabled = true 194 config.transcoding.enabled = true
195 await server.config.updateCustomSubConfig({ newConfig: config }) 195 await server.config.updateCustomSubConfig({ newConfig: config })
diff --git a/server/tests/api/videos/video-imports.ts b/server/tests/api/videos/video-imports.ts
index 4f3149d52..b78b4f344 100644
--- a/server/tests/api/videos/video-imports.ts
+++ b/server/tests/api/videos/video-imports.ts
@@ -328,7 +328,7 @@ describe('Test video imports', function () {
328 '1440p': false, 328 '1440p': false,
329 '2160p': false 329 '2160p': false
330 }, 330 },
331 webtorrent: { enabled: true }, 331 webVideos: { enabled: true },
332 hls: { enabled: false } 332 hls: { enabled: false }
333 } 333 }
334 } 334 }
diff --git a/server/tests/feeds/feeds.ts b/server/tests/feeds/feeds.ts
index 83a85be58..1754ac466 100644
--- a/server/tests/feeds/feeds.ts
+++ b/server/tests/feeds/feeds.ts
@@ -47,7 +47,7 @@ describe('Test syndication feeds', () => {
47 serverHLSOnly = await createSingleServer(3, { 47 serverHLSOnly = await createSingleServer(3, {
48 transcoding: { 48 transcoding: {
49 enabled: true, 49 enabled: true,
50 webtorrent: { enabled: false }, 50 web_videos: { enabled: false },
51 hls: { enabled: true } 51 hls: { enabled: true }
52 } 52 }
53 }) 53 })
diff --git a/server/tests/plugins/filter-hooks.ts b/server/tests/plugins/filter-hooks.ts
index a02a53c50..a75a8c8fa 100644
--- a/server/tests/plugins/filter-hooks.ts
+++ b/server/tests/plugins/filter-hooks.ts
@@ -493,7 +493,7 @@ describe('Test plugin filter hooks', function () {
493 await servers[0].config.updateCustomSubConfig({ 493 await servers[0].config.updateCustomSubConfig({
494 newConfig: { 494 newConfig: {
495 transcoding: { 495 transcoding: {
496 webtorrent: { 496 webVideos: {
497 enabled: true 497 enabled: true
498 }, 498 },
499 hls: { 499 hls: {
diff --git a/server/tests/plugins/plugin-transcoding.ts b/server/tests/plugins/plugin-transcoding.ts
index f3d929426..21f82fbac 100644
--- a/server/tests/plugins/plugin-transcoding.ts
+++ b/server/tests/plugins/plugin-transcoding.ts
@@ -35,7 +35,7 @@ function updateConf (server: PeerTubeServer, vodProfile: string, liveProfile: st
35 hls: { 35 hls: {
36 enabled: true 36 enabled: true
37 }, 37 },
38 webtorrent: { 38 webVideos: {
39 enabled: true 39 enabled: true
40 }, 40 },
41 resolutions: { 41 resolutions: {
diff --git a/server/tests/shared/videos.ts b/server/tests/shared/videos.ts
index 6cba5b14c..b7f7a1613 100644
--- a/server/tests/shared/videos.ts
+++ b/server/tests/shared/videos.ts
@@ -28,7 +28,7 @@ async function completeWebVideoFilesCheck (options: {
28 const serverConfig = await originServer.config.getConfig() 28 const serverConfig = await originServer.config.getConfig()
29 const requiresAuth = video.privacy.id === VideoPrivacy.PRIVATE || video.privacy.id === VideoPrivacy.INTERNAL 29 const requiresAuth = video.privacy.id === VideoPrivacy.PRIVATE || video.privacy.id === VideoPrivacy.INTERNAL
30 30
31 const transcodingEnabled = serverConfig.transcoding.webtorrent.enabled 31 const transcodingEnabled = serverConfig.transcoding.web_videos.enabled
32 32
33 for (const attributeFile of files) { 33 for (const attributeFile of files) {
34 const file = video.files.find(f => f.resolution.id === attributeFile.resolution) 34 const file = video.files.find(f => f.resolution.id === attributeFile.resolution)
diff --git a/shared/models/server/custom-config.model.ts b/shared/models/server/custom-config.model.ts
index 1012312f3..9aa66f2b8 100644
--- a/shared/models/server/custom-config.model.ts
+++ b/shared/models/server/custom-config.model.ts
@@ -133,7 +133,7 @@ export interface CustomConfig {
133 133
134 alwaysTranscodeOriginalResolution: boolean 134 alwaysTranscodeOriginalResolution: boolean
135 135
136 webtorrent: { 136 webVideos: {
137 enabled: boolean 137 enabled: boolean
138 } 138 }
139 139
diff --git a/shared/models/server/server-config.model.ts b/shared/models/server/server-config.model.ts
index 024ed35bf..288cf84cd 100644
--- a/shared/models/server/server-config.model.ts
+++ b/shared/models/server/server-config.model.ts
@@ -140,7 +140,7 @@ export interface ServerConfig {
140 enabled: boolean 140 enabled: boolean
141 } 141 }
142 142
143 webtorrent: { 143 web_videos: {
144 enabled: boolean 144 enabled: boolean
145 } 145 }
146 146
diff --git a/shared/server-commands/server/config-command.ts b/shared/server-commands/server/config-command.ts
index 00dc8e11c..7f1e9d977 100644
--- a/shared/server-commands/server/config-command.ts
+++ b/shared/server-commands/server/config-command.ts
@@ -142,7 +142,7 @@ export class ConfigCommand extends AbstractCommand {
142 142
143 resolutions: ConfigCommand.getCustomConfigResolutions(true, with0p), 143 resolutions: ConfigCommand.getCustomConfigResolutions(true, with0p),
144 144
145 webtorrent: { 145 webVideos: {
146 enabled: webVideo 146 enabled: webVideo
147 }, 147 },
148 hls: { 148 hls: {
@@ -169,7 +169,7 @@ export class ConfigCommand extends AbstractCommand {
169 '240p': true 169 '240p': true
170 }, 170 },
171 171
172 webtorrent: { 172 webVideos: {
173 enabled: webVideo 173 enabled: webVideo
174 }, 174 },
175 hls: { 175 hls: {
@@ -424,7 +424,7 @@ export class ConfigCommand extends AbstractCommand {
424 '2160p': false 424 '2160p': false
425 }, 425 },
426 alwaysTranscodeOriginalResolution: true, 426 alwaysTranscodeOriginalResolution: true,
427 webtorrent: { 427 webVideos: {
428 enabled: true 428 enabled: true
429 }, 429 },
430 hls: { 430 hls: {
diff --git a/support/doc/api/openapi.yaml b/support/doc/api/openapi.yaml
index e1a21fb5c..b2303bdd1 100644
--- a/support/doc/api/openapi.yaml
+++ b/support/doc/api/openapi.yaml
@@ -7768,7 +7768,7 @@ components:
7768 properties: 7768 properties:
7769 enabled: 7769 enabled:
7770 type: boolean 7770 type: boolean
7771 webtorrent: 7771 web_videos:
7772 type: object 7772 type: object
7773 properties: 7773 properties:
7774 enabled: 7774 enabled:
@@ -8134,7 +8134,7 @@ components:
8134 type: boolean 8134 type: boolean
8135 2160p: 8135 2160p:
8136 type: boolean 8136 type: boolean
8137 webtorrent: 8137 web_videos:
8138 type: object 8138 type: object
8139 description: Web Video specific settings 8139 description: Web Video specific settings
8140 properties: 8140 properties:
diff --git a/support/docker/production/config/custom-environment-variables.yaml b/support/docker/production/config/custom-environment-variables.yaml
index 8fff54229..8c1231bfc 100644
--- a/support/docker/production/config/custom-environment-variables.yaml
+++ b/support/docker/production/config/custom-environment-variables.yaml
@@ -1,7 +1,7 @@
1# 1#
2# This file will be read by node-config 2# This file will be read by node-config
3# See https://github.com/node-config/node-config/wiki/Environment-Variables#custom-environment-variables 3# See https://github.com/node-config/node-config/wiki/Environment-Variables#custom-environment-variables
4# 4#
5 5
6webserver: 6webserver:
7 hostname: "PEERTUBE_WEBSERVER_HOSTNAME" 7 hostname: "PEERTUBE_WEBSERVER_HOSTNAME"
@@ -177,9 +177,9 @@ transcoding:
177 2160p: 177 2160p:
178 __name: "PEERTUBE_TRANSCODING_2160P" 178 __name: "PEERTUBE_TRANSCODING_2160P"
179 __format: "json" 179 __format: "json"
180 webtorrent: 180 web_videos:
181 enabled: 181 enabled:
182 __name: "PEERTUBE_TRANSCODING_WEBTORRENT_ENABLED" 182 __name: "PEERTUBE_TRANSCODING_WEB_VIDEOS_ENABLED"
183 __format: "json" 183 __format: "json"
184 hls: 184 hls:
185 enabled: 185 enabled: