]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/controllers/api/v1/users.js
Server: implement refresh token
[github/Chocobozzz/PeerTube.git] / server / controllers / api / v1 / users.js
CommitLineData
9457bf88
C
1'use strict'
2
23a5a916 3const config = require('config')
69b0a27c 4const mongoose = require('mongoose')
0c1cbbfe 5const express = require('express')
fc51fde0 6
69b0a27c 7const oAuth = require('../../../middlewares').oauth
9457bf88 8
69b0a27c 9const Client = mongoose.model('OAuthClient')
9457bf88
C
10
11const router = express.Router()
12
5dda52c9 13router.get('/client', getAngularClient)
69b0a27c 14router.post('/token', oAuth.token, success)
2f372a86 15// TODO: Once https://github.com/oauthjs/node-oauth2-server/pull/289 is merged,, implement revoke token route
9457bf88
C
16
17// ---------------------------------------------------------------------------
18
19module.exports = router
20
21// ---------------------------------------------------------------------------
22
23a5a916 23function getAngularClient (req, res, next) {
bc503c2a
C
24 const serverHost = config.get('webserver.host')
25 const serverPort = config.get('webserver.port')
26 let headerHostShouldBe = serverHost
27 if (serverPort !== 80 && serverPort !== 443) {
28 headerHostShouldBe += ':' + serverPort
23a5a916
C
29 }
30
f9f5478c
C
31 // Don't make this check if this is a test instance
32 if (process.env.NODE_ENV !== 'test' && req.get('host') !== headerHostShouldBe) {
33 return res.type('json').status(403).end()
34 }
23a5a916 35
69b0a27c 36 Client.loadFirstClient(function (err, client) {
23a5a916
C
37 if (err) return next(err)
38 if (!client) return next(new Error('No client available.'))
39
40 res.json({
41 client_id: client._id,
42 client_secret: client.clientSecret
43 })
44 })
45}
46
9457bf88
C
47function success (req, res, next) {
48 res.end()
49}