'use strict'
-const each = require('async/each')
const express = require('express')
const waterfall = require('async/waterfall')
const constants = require('../../initializers/constants')
const db = require('../../initializers/database')
-const friends = require('../../lib/friends')
const logger = require('../../helpers/logger')
+const utils = require('../../helpers/utils')
const middlewares = require('../../middlewares')
const admin = middlewares.admin
const oAuth = middlewares.oauth
const router = express.Router()
-router.get('/me', oAuth.authenticate, getUserInformation)
+router.get('/me',
+ oAuth.authenticate,
+ getUserInformation
+)
+
+router.get('/me/videos/:videoId/rating',
+ oAuth.authenticate,
+ validatorsUsers.usersVideoRating,
+ getUserVideoRating
+)
router.get('/',
validatorsPagination.pagination,
createUser
)
+router.post('/register',
+ ensureRegistrationEnabled,
+ validatorsUsers.usersAdd,
+ createUser
+)
+
router.put('/:id',
oAuth.authenticate,
validatorsUsers.usersUpdate,
// ---------------------------------------------------------------------------
+function ensureRegistrationEnabled (req, res, next) {
+ const registrationEnabled = constants.CONFIG.SIGNUP.ENABLED
+
+ if (registrationEnabled === true) {
+ return next()
+ }
+
+ return res.status(400).send('User registration is not enabled.')
+}
+
function createUser (req, res, next) {
const user = db.User.build({
username: req.body.username,
password: req.body.password,
+ email: req.body.email,
+ displayNSFW: false,
role: constants.USER_ROLES.USER
})
})
}
+function getUserVideoRating (req, res, next) {
+ const videoId = req.params.videoId
+ const userId = res.locals.oauth.token.User.id
+
+ db.UserVideoRate.load(userId, videoId, function (err, ratingObj) {
+ if (err) return next(err)
+
+ const rating = ratingObj ? ratingObj.type : 'none'
+
+ res.json({
+ videoId,
+ rating
+ })
+ })
+}
+
function listUsers (req, res, next) {
db.User.listForApi(req.query.start, req.query.count, req.query.sort, function (err, usersList, usersTotal) {
if (err) return next(err)
- res.json(getFormatedUsers(usersList, usersTotal))
+ res.json(utils.getFormatedObjects(usersList, usersTotal))
})
}
function removeUser (req, res, next) {
waterfall([
- function getUser (callback) {
+ function loadUser (callback) {
db.User.loadById(req.params.id, callback)
},
- // TODO: use foreignkey?
- function getVideos (user, callback) {
- db.Video.listOwnedByAuthor(user.username, function (err, videos) {
- return callback(err, user, videos)
- })
- },
-
- function removeVideosFromDB (user, videos, callback) {
- each(videos, function (video, callbackEach) {
- video.destroy().asCallback(callbackEach)
- }, function (err) {
- return callback(err, user, videos)
- })
- },
-
- function sendInformationToFriends (user, videos, callback) {
- videos.forEach(function (video) {
- const params = {
- name: video.name,
- remoteId: video.id
- }
-
- friends.removeVideoToFriends(params)
- })
-
- return callback(null, user)
- },
-
- function removeUserFromDB (user, callback) {
+ function deleteUser (user, callback) {
user.destroy().asCallback(callback)
}
], function andFinally (err) {
db.User.loadByUsername(res.locals.oauth.token.user.username, function (err, user) {
if (err) return next(err)
- user.password = req.body.password
+ if (req.body.password) user.password = req.body.password
+ if (req.body.displayNSFW !== undefined) user.displayNSFW = req.body.displayNSFW
+
user.save().asCallback(function (err) {
if (err) return next(err)
function success (req, res, next) {
res.end()
}
-
-// ---------------------------------------------------------------------------
-
-function getFormatedUsers (users, usersTotal) {
- const formatedUsers = []
-
- users.forEach(function (user) {
- formatedUsers.push(user.toFormatedJSON())
- })
-
- return {
- total: usersTotal,
- data: formatedUsers
- }
-}