1
0
Fork 0
peertube/server/controllers/api/v1/users.js

50 lines
1.4 KiB
JavaScript
Raw Normal View History

2016-03-21 10:56:33 +00:00
'use strict'
const config = require('config')
const mongoose = require('mongoose')
const express = require('express')
2016-07-01 14:16:40 +00:00
const oAuth = require('../../../middlewares').oauth
2016-03-21 10:56:33 +00:00
const Client = mongoose.model('OAuthClient')
2016-03-21 10:56:33 +00:00
const router = express.Router()
2016-05-13 14:13:00 +00:00
router.get('/client', getAngularClient)
router.post('/token', oAuth.token, success)
2016-07-20 14:23:58 +00:00
// TODO: Once https://github.com/oauthjs/node-oauth2-server/pull/289 is merged,, implement revoke token route
2016-03-21 10:56:33 +00:00
// ---------------------------------------------------------------------------
module.exports = router
// ---------------------------------------------------------------------------
function getAngularClient (req, res, next) {
const serverHost = config.get('webserver.host')
const serverPort = config.get('webserver.port')
let headerHostShouldBe = serverHost
if (serverPort !== 80 && serverPort !== 443) {
headerHostShouldBe += ':' + serverPort
}
// Don't make this check if this is a test instance
if (process.env.NODE_ENV !== 'test' && req.get('host') !== headerHostShouldBe) {
return res.type('json').status(403).end()
}
Client.loadFirstClient(function (err, client) {
if (err) return next(err)
if (!client) return next(new Error('No client available.'))
res.json({
client_id: client._id,
client_secret: client.clientSecret
})
})
}
2016-03-21 10:56:33 +00:00
function success (req, res, next) {
res.end()
}