]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/controllers/api/config.ts
feature: IP filtering on signup page
[github/Chocobozzz/PeerTube.git] / server / controllers / api / config.ts
CommitLineData
4d4e5cd4 1import * as express from 'express'
36f9424f 2import { omit } from 'lodash'
fd206f0b 3import { ServerConfig, UserRight } from '../../../shared'
09cababd
C
4import { About } from '../../../shared/models/server/about.model'
5import { CustomConfig } from '../../../shared/models/server/custom-config.model'
fd206f0b 6import { unlinkPromise, writeFilePromise } from '../../helpers/core-utils'
ff2c1fe8 7import { isSignupAllowed, isSignupAllowedForCurrentIP } from '../../helpers/utils'
fd206f0b
C
8import { CONFIG, CONSTRAINTS_FIELDS, reloadConfig } from '../../initializers'
9import { asyncMiddleware, authenticate, ensureUserHasRight } from '../../middlewares'
10import { customConfigUpdateValidator } from '../../middlewares/validators/config'
65fcc311 11
915c5bbe 12const packageJSON = require('../../../../package.json')
65fcc311
C
13const configRouter = express.Router()
14
36f9424f 15configRouter.get('/about', getAbout)
eb080476
C
16configRouter.get('/',
17 asyncMiddleware(getConfig)
18)
36f9424f 19
fd206f0b
C
20configRouter.get('/custom',
21 authenticate,
22 ensureUserHasRight(UserRight.MANAGE_CONFIGURATION),
23 asyncMiddleware(getCustomConfig)
24)
25configRouter.put('/custom',
26 authenticate,
27 ensureUserHasRight(UserRight.MANAGE_CONFIGURATION),
28 asyncMiddleware(customConfigUpdateValidator),
29 asyncMiddleware(updateCustomConfig)
30)
31configRouter.delete('/custom',
32 authenticate,
33 ensureUserHasRight(UserRight.MANAGE_CONFIGURATION),
34 asyncMiddleware(deleteCustomConfig)
35)
65fcc311 36
eb080476
C
37async function getConfig (req: express.Request, res: express.Response, next: express.NextFunction) {
38 const allowed = await isSignupAllowed()
ff2c1fe8 39 const allowedForCurrentIP = isSignupAllowedForCurrentIP(req.ip)
291e8d3e 40
eb080476
C
41 const enabledResolutions = Object.keys(CONFIG.TRANSCODING.RESOLUTIONS)
42 .filter(key => CONFIG.TRANSCODING.RESOLUTIONS[key] === true)
43 .map(r => parseInt(r, 10))
6a84aafd 44
eb080476 45 const json: ServerConfig = {
36f9424f 46 instance: {
00b5556c 47 name: CONFIG.INSTANCE.NAME,
2e3a0215 48 shortDescription: CONFIG.INSTANCE.SHORT_DESCRIPTION,
901637bb 49 defaultClientRoute: CONFIG.INSTANCE.DEFAULT_CLIENT_ROUTE,
0883b324 50 defaultNSFWPolicy: CONFIG.INSTANCE.DEFAULT_NSFW_POLICY,
00b5556c
C
51 customizations: {
52 javascript: CONFIG.INSTANCE.CUSTOMIZATIONS.JAVASCRIPT,
53 css: CONFIG.INSTANCE.CUSTOMIZATIONS.CSS
54 }
36f9424f 55 },
915c5bbe 56 serverVersion: packageJSON.version,
eb080476 57 signup: {
ff2c1fe8
RK
58 allowed,
59 allowedForCurrentIP
eb080476
C
60 },
61 transcoding: {
62 enabledResolutions
01de67b9
C
63 },
64 avatar: {
65 file: {
66 size: {
67 max: CONSTRAINTS_FIELDS.ACTORS.AVATAR.FILE_SIZE.max
68 },
69 extensions: CONSTRAINTS_FIELDS.ACTORS.AVATAR.EXTNAME
70 }
71 },
72 video: {
6de36768
C
73 image: {
74 extensions: CONSTRAINTS_FIELDS.VIDEOS.IMAGE.EXTNAME,
75 size: {
76 max: CONSTRAINTS_FIELDS.VIDEOS.IMAGE.FILE_SIZE.max
77 }
78 },
01de67b9
C
79 file: {
80 extensions: CONSTRAINTS_FIELDS.VIDEOS.EXTNAME
81 }
1869c875
RK
82 },
83 user: {
84 videoQuota: CONFIG.USER.VIDEO_QUOTA
65fcc311 85 }
eb080476 86 }
6a84aafd 87
eb080476 88 return res.json(json)
65fcc311
C
89}
90
36f9424f
C
91function getAbout (req: express.Request, res: express.Response, next: express.NextFunction) {
92 const about: About = {
93 instance: {
94 name: CONFIG.INSTANCE.NAME,
2e3a0215 95 shortDescription: CONFIG.INSTANCE.SHORT_DESCRIPTION,
36f9424f
C
96 description: CONFIG.INSTANCE.DESCRIPTION,
97 terms: CONFIG.INSTANCE.TERMS
98 }
99 }
100
101 return res.json(about).end()
102}
103
fd206f0b
C
104async function getCustomConfig (req: express.Request, res: express.Response, next: express.NextFunction) {
105 const data = customConfig()
106
107 return res.json(data).end()
108}
109
110async function deleteCustomConfig (req: express.Request, res: express.Response, next: express.NextFunction) {
111 await unlinkPromise(CONFIG.CUSTOM_FILE)
112
113 reloadConfig()
114
115 const data = customConfig()
116
117 return res.json(data).end()
118}
119
120async function updateCustomConfig (req: express.Request, res: express.Response, next: express.NextFunction) {
121 const toUpdate: CustomConfig = req.body
122
be1fc4bc
C
123 // Force number conversion
124 toUpdate.cache.previews.size = parseInt('' + toUpdate.cache.previews.size, 10)
125 toUpdate.signup.limit = parseInt('' + toUpdate.signup.limit, 10)
126 toUpdate.user.videoQuota = parseInt('' + toUpdate.user.videoQuota, 10)
127 toUpdate.transcoding.threads = parseInt('' + toUpdate.transcoding.threads, 10)
128
129 // camelCase to snake_case key
130 const toUpdateJSON = omit(toUpdate, 'user.videoQuota', 'instance.defaultClientRoute', 'instance.shortDescription')
fd206f0b 131 toUpdateJSON.user['video_quota'] = toUpdate.user.videoQuota
901637bb 132 toUpdateJSON.instance['default_client_route'] = toUpdate.instance.defaultClientRoute
2e3a0215 133 toUpdateJSON.instance['short_description'] = toUpdate.instance.shortDescription
0883b324 134 toUpdateJSON.instance['default_nsfw_policy'] = toUpdate.instance.defaultNSFWPolicy
fd206f0b 135
2ad42952 136 await writeFilePromise(CONFIG.CUSTOM_FILE, JSON.stringify(toUpdateJSON, undefined, 2))
fd206f0b
C
137
138 reloadConfig()
139
140 const data = customConfig()
141 return res.json(data).end()
142}
143
65fcc311
C
144// ---------------------------------------------------------------------------
145
146export {
147 configRouter
148}
fd206f0b
C
149
150// ---------------------------------------------------------------------------
151
152function customConfig (): CustomConfig {
153 return {
66b16caf
C
154 instance: {
155 name: CONFIG.INSTANCE.NAME,
2e3a0215 156 shortDescription: CONFIG.INSTANCE.SHORT_DESCRIPTION,
66b16caf 157 description: CONFIG.INSTANCE.DESCRIPTION,
00b5556c 158 terms: CONFIG.INSTANCE.TERMS,
901637bb 159 defaultClientRoute: CONFIG.INSTANCE.DEFAULT_CLIENT_ROUTE,
0883b324 160 defaultNSFWPolicy: CONFIG.INSTANCE.DEFAULT_NSFW_POLICY,
00b5556c
C
161 customizations: {
162 css: CONFIG.INSTANCE.CUSTOMIZATIONS.CSS,
163 javascript: CONFIG.INSTANCE.CUSTOMIZATIONS.JAVASCRIPT
164 }
66b16caf 165 },
8be1afa1
C
166 services: {
167 twitter: {
168 username: CONFIG.SERVICES.TWITTER.USERNAME,
169 whitelisted: CONFIG.SERVICES.TWITTER.WHITELISTED
170 }
171 },
fd206f0b
C
172 cache: {
173 previews: {
174 size: CONFIG.CACHE.PREVIEWS.SIZE
175 }
176 },
177 signup: {
178 enabled: CONFIG.SIGNUP.ENABLED,
179 limit: CONFIG.SIGNUP.LIMIT
180 },
181 admin: {
182 email: CONFIG.ADMIN.EMAIL
183 },
184 user: {
185 videoQuota: CONFIG.USER.VIDEO_QUOTA
186 },
187 transcoding: {
188 enabled: CONFIG.TRANSCODING.ENABLED,
189 threads: CONFIG.TRANSCODING.THREADS,
190 resolutions: {
191 '240p': CONFIG.TRANSCODING.RESOLUTIONS[ '240p' ],
192 '360p': CONFIG.TRANSCODING.RESOLUTIONS[ '360p' ],
193 '480p': CONFIG.TRANSCODING.RESOLUTIONS[ '480p' ],
194 '720p': CONFIG.TRANSCODING.RESOLUTIONS[ '720p' ],
195 '1080p': CONFIG.TRANSCODING.RESOLUTIONS[ '1080p' ]
196 }
197 }
198 }
199}