792dbaf07f
* Client: Add list blacklist feature * Server: Add list blacklist feature * Client: Add videoId column * Server: Add some video infos in the REST api * Client: Add video information in the blacklist list * Fix sortable columns :) * Client: Add removeFromBlacklist feature * Server: Add removeFromBlacklist feature * Move to TypeScript * Move to TypeScript and Promises * Server: Fix blacklist list sort * Server: Fetch videos informations * Use common shared interface for client and server * Add check-params remove blacklisted video tests * Add check-params list blacklisted videos tests * Add list blacklist tests * Add remove from blacklist tests * Add video blacklist management tests * Fix rebase onto develop issues * Server: Add sort on blacklist id column * Server: Add blacklists library * Add blacklist id sort test * Add check-params tests for blacklist list pagination, count and sort * Fix coding style * Increase Remote API tests timeout * Increase Request scheduler API tests timeout * Fix typo * Increase video transcoding API tests timeout * Move tests to Typescript * Use lodash orderBy method * Fix typos * Client: Remove optional tests in blacklist model attributes * Move blacklist routes from 'blacklists' to 'blacklist' * CLient: Remove blacklist-list.component.scss * Rename 'blacklists' files to 'blacklist' * Use only BlacklistedVideo interface * Server: Use getFormattedObjects method in listBlacklist method * Client: Use new coding style * Server: Use new sort validator methods * Server: Use new checkParams methods * Client: Fix sortable columns
60 lines
1.4 KiB
TypeScript
60 lines
1.4 KiB
TypeScript
import * as express from 'express'
|
|
import * as Promise from 'bluebird'
|
|
|
|
import { pseudoRandomBytesPromise } from './core-utils'
|
|
import { CONFIG, database as db } from '../initializers'
|
|
import { ResultList } from '../../shared'
|
|
|
|
function badRequest (req: express.Request, res: express.Response, next: express.NextFunction) {
|
|
res.type('json').status(400).end()
|
|
}
|
|
|
|
function generateRandomString (size: number) {
|
|
return pseudoRandomBytesPromise(size).then(raw => raw.toString('hex'))
|
|
}
|
|
|
|
interface FormatableToJSON {
|
|
toFormattedJSON ()
|
|
}
|
|
|
|
function getFormattedObjects<U, T extends FormatableToJSON> (objects: T[], objectsTotal: number) {
|
|
const formattedObjects: U[] = []
|
|
|
|
objects.forEach(object => {
|
|
formattedObjects.push(object.toFormattedJSON())
|
|
})
|
|
|
|
const res: ResultList<U> = {
|
|
total: objectsTotal,
|
|
data: formattedObjects
|
|
}
|
|
|
|
return res
|
|
}
|
|
|
|
function isSignupAllowed () {
|
|
if (CONFIG.SIGNUP.ENABLED === false) {
|
|
return Promise.resolve(false)
|
|
}
|
|
|
|
// No limit and signup is enabled
|
|
if (CONFIG.SIGNUP.LIMIT === -1) {
|
|
return Promise.resolve(true)
|
|
}
|
|
|
|
return db.User.countTotal().then(totalUsers => {
|
|
return totalUsers < CONFIG.SIGNUP.LIMIT
|
|
})
|
|
}
|
|
|
|
type SortType = { sortModel: any, sortValue: string }
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
export {
|
|
badRequest,
|
|
generateRandomString,
|
|
getFormattedObjects,
|
|
isSignupAllowed,
|
|
SortType
|
|
}
|