-import * as express from 'express'
-
-import { CONFIG } from '../../initializers'
-import { logger } from '../../helpers'
-import { database as db } from '../../initializers/database'
-import { OAuthClientLocal } from '../../../shared'
+import express from 'express'
+import { OAuthClientModel } from '@server/models/oauth/oauth-client'
+import { HttpStatusCode, OAuthClientLocal } from '@shared/models'
+import { logger } from '../../helpers/logger'
+import { CONFIG } from '../../initializers/config'
+import { asyncMiddleware, openapiOperationDoc } from '../../middlewares'
const oauthClientsRouter = express.Router()
-oauthClientsRouter.get('/local', getLocalClient)
+oauthClientsRouter.get('/local',
+ openapiOperationDoc({ operationId: 'getOAuthClient' }),
+ asyncMiddleware(getLocalClient)
+)
// Get the client credentials for the PeerTube front end
-function getLocalClient (req: express.Request, res: express.Response, next: express.NextFunction) {
+async function getLocalClient (req: express.Request, res: express.Response, next: express.NextFunction) {
const serverHostname = CONFIG.WEBSERVER.HOSTNAME
const serverPort = CONFIG.WEBSERVER.PORT
let headerHostShouldBe = serverHostname
// Don't make this check if this is a test instance
if (process.env.NODE_ENV !== 'test' && req.get('host') !== headerHostShouldBe) {
logger.info('Getting client tokens for host %s is forbidden (expected %s).', req.get('host'), headerHostShouldBe)
- return res.type('json').status(403).end()
+ return res.fail({
+ status: HttpStatusCode.FORBIDDEN_403,
+ message: `Getting client tokens for host ${req.get('host')} is forbidden`
+ })
}
- db.OAuthClient.loadFirstClient()
- .then(client => {
- if (!client) throw new Error('No client available.')
+ const client = await OAuthClientModel.loadFirstClient()
+ if (!client) throw new Error('No client available.')
- const json: OAuthClientLocal = {
- client_id: client.clientId,
- client_secret: client.clientSecret
- }
- res.json(json)
- })
- .catch(err => next(err))
+ const json: OAuthClientLocal = {
+ client_id: client.clientId,
+ client_secret: client.clientSecret
+ }
+ return res.json(json)
}
// ---------------------------------------------------------------------------