2022-07-10 12:46:25 +00:00
|
|
|
const { Router } = require('hyper-express')
|
|
|
|
const routes = new Router()
|
2022-08-04 14:59:06 +00:00
|
|
|
const albums = require('./../controllers/albumsController')
|
|
|
|
const auth = require('./../controllers/authController')
|
|
|
|
const tokens = require('./../controllers/tokenController')
|
|
|
|
const upload = require('./../controllers/uploadController')
|
|
|
|
const utils = require('./../controllers/utilsController')
|
Updates (very important to read)
Client-side CSS & JS files will now be processed with Gulp.
Gulp tasks are configured in gulpfile.js file.
CSS files will be optimized with postcss-preset-env, which will
auto-add vendor prefixes and convert any parts necessary for browsers
compatibility.
Afterwards they will be minified with cssnano.
JS files will be optimized with bublé,
likewise for browsers compatibility.
Afterwards they will be minified with terser.
Unprocessed CSS & JS files will now be located at src directory, while
the processed results will be located at dist directory.
Due to bublé, the JS files should now be compatible up to IE 11
at the minimum.
Previously the safe would not work in IE 11 due to extensive usage of
template literals.
Due to that as well, JS files in src directory will now extensively use
arrow functions for my personal comfort (as they will be converted too).
The server will use the processed files at dist directory by default.
If you want to rebuild the files by your own, you can run "yarn build".
Gulp is a development dependency, so make sure you have installed all
development dependencies (e.i. NOT using "yarn install --production").
---
yarn lint -> gulp lint
yarn build -> gulp default
yarn watch -> gulp watch
yarn develop -> env NODE_ENV=development yarn watch
---
Fixed not being able to demote staff into normal users.
/api/token/verify will no longer respond with 401 HTTP error code,
unless an error occurred (which will be 500 HTTP error code).
Fixed /nojs route not displaying file's original name when a duplicate
is found on the server.
Removed is-breeze CSS class name, in favor of Bulma's is-info.
Removed custom styling from auth page, in favor of global styling.
Removed all usage of style HTML attribute in favor of CSS classes.
Renamed js/s/ to js/misc/.
Use loading spinners on dashboard's sidebar menus.
Disable all other sidebar menus when something is loading.
Changed title HTML attribute of disabled control buttons in
uploads & users list.
Hid checkboxes and WIP controls from users list.
Better error messages handling.
Especially homepage will now support CF's HTTP error codes.
Updated various icons.
Also, added fontello config file at public/libs/fontello/config.json.
This should let you edit them more easily with fontello.
Use Gatsby icon for my blog's link in homepage's footer.
A bunch of other improvements here & there.
2019-09-15 06:20:11 +00:00
|
|
|
const config = require('./../config')
|
2017-01-15 01:36:24 +00:00
|
|
|
|
2022-09-13 20:18:30 +00:00
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* components:
|
|
|
|
* schemas:
|
|
|
|
* Username:
|
|
|
|
* type: string
|
|
|
|
* minLength: 4
|
|
|
|
* maxLength: 32
|
|
|
|
* Password:
|
|
|
|
* type: string
|
|
|
|
* format: password
|
|
|
|
* minLength: 6
|
|
|
|
* maxLength: 64
|
|
|
|
* Result:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - success
|
|
|
|
* properties:
|
|
|
|
* success:
|
|
|
|
* type: boolean
|
|
|
|
* Error:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - success
|
|
|
|
* - description
|
|
|
|
* properties:
|
|
|
|
* success:
|
|
|
|
* type: boolean
|
|
|
|
* description:
|
|
|
|
* type: string
|
|
|
|
* code:
|
|
|
|
* description: Helper error code. Currently very sparsely used.
|
|
|
|
* type: number
|
|
|
|
* responses:
|
|
|
|
* Success:
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* $ref: "#/components/schemas/Result"
|
|
|
|
* example:
|
|
|
|
* success: true
|
|
|
|
* BadRequest:
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* $ref: "#/components/schemas/Error"
|
|
|
|
* example:
|
|
|
|
* success: false
|
|
|
|
* description: Bad request.
|
|
|
|
* Unauthorized:
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* $ref: "#/components/schemas/Error"
|
|
|
|
* example:
|
|
|
|
* success: false
|
|
|
|
* description: Invalid token.
|
|
|
|
* code: 10001
|
|
|
|
* ServerError:
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* $ref: "#/components/schemas/Error"
|
|
|
|
* example:
|
|
|
|
* success: false
|
|
|
|
* description: An unexpected error occurred. Try again?
|
|
|
|
* securitySchemes:
|
|
|
|
* token:
|
|
|
|
* type: apiKey
|
|
|
|
* name: token
|
|
|
|
* in: header
|
|
|
|
* tags:
|
|
|
|
* - name: General
|
|
|
|
* description: General routes
|
|
|
|
* - name: Uploads
|
|
|
|
* description: Uploads routes
|
|
|
|
* - name: Auth
|
|
|
|
* description: Auth routes
|
|
|
|
* - name: Users
|
|
|
|
* description: Users routes
|
|
|
|
* - name: Album
|
|
|
|
* description: Albums routes
|
|
|
|
* - name: Moderation
|
|
|
|
* description: Moderation routes
|
|
|
|
* - name: Administration
|
|
|
|
* description: Administration routes
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* /api/check:
|
|
|
|
* get:
|
|
|
|
* summary: Get server's partial config
|
|
|
|
* description: This only contains the necessary config to customize the homepage uploader's behavior.
|
|
|
|
* tags:
|
|
|
|
* - General
|
|
|
|
* responses:
|
|
|
|
* 200:
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - private
|
|
|
|
* - enableUserAccounts
|
|
|
|
* - maxSize
|
|
|
|
* - chunkSize
|
|
|
|
* - fileIdentifierLength
|
|
|
|
* - stripTags
|
|
|
|
* properties:
|
|
|
|
* private:
|
|
|
|
* type: boolean
|
|
|
|
* enableUserAccounts:
|
|
|
|
* type: boolean
|
|
|
|
* maxSize:
|
|
|
|
* type: string
|
|
|
|
* chunkSize:
|
|
|
|
* type: object
|
|
|
|
* fileIdentifierLength:
|
|
|
|
* type: object
|
|
|
|
* properties:
|
|
|
|
* min:
|
|
|
|
* type: number
|
|
|
|
* max:
|
|
|
|
* type: number
|
|
|
|
* default:
|
|
|
|
* type: number
|
|
|
|
* force:
|
|
|
|
* type: boolean
|
|
|
|
* stripTags:
|
|
|
|
* oneOf:
|
|
|
|
* - type: object
|
|
|
|
* - type: boolean
|
|
|
|
* temporaryUploadAges:
|
|
|
|
* type: array
|
|
|
|
* items:
|
|
|
|
* type: number
|
|
|
|
* defaultTemporaryUploadAge:
|
|
|
|
* type: number
|
|
|
|
* version:
|
|
|
|
* type: string
|
|
|
|
* 500:
|
|
|
|
* $ref: "#/components/responses/ServerError"
|
|
|
|
*/
|
2022-07-10 12:46:25 +00:00
|
|
|
routes.get('/check', async (req, res) => {
|
2020-04-29 22:56:28 +00:00
|
|
|
const obj = {
|
2018-01-23 20:06:30 +00:00
|
|
|
private: config.private,
|
2018-04-03 18:54:42 +00:00
|
|
|
enableUserAccounts: config.enableUserAccounts,
|
2019-08-20 02:16:34 +00:00
|
|
|
maxSize: config.uploads.maxSize,
|
2019-09-08 01:56:29 +00:00
|
|
|
chunkSize: config.uploads.chunkSize,
|
2019-11-29 13:42:53 +00:00
|
|
|
fileIdentifierLength: config.uploads.fileIdentifierLength,
|
|
|
|
stripTags: config.uploads.stripTags
|
2020-04-29 22:56:28 +00:00
|
|
|
}
|
2022-08-04 14:59:06 +00:00
|
|
|
if (utils.retentions.enabled && utils.retentions.periods._) {
|
|
|
|
obj.temporaryUploadAges = utils.retentions.periods._
|
|
|
|
obj.defaultTemporaryUploadAge = utils.retentions.default._
|
2022-05-06 19:17:31 +00:00
|
|
|
}
|
2022-08-04 14:59:06 +00:00
|
|
|
if (utils.clientVersion) {
|
|
|
|
obj.version = utils.clientVersion
|
2022-05-06 19:17:31 +00:00
|
|
|
}
|
2020-04-29 22:56:28 +00:00
|
|
|
return res.json(obj)
|
2018-01-23 20:06:30 +00:00
|
|
|
})
|
2017-01-17 03:37:54 +00:00
|
|
|
|
2022-08-04 14:59:06 +00:00
|
|
|
/** ./controllers/authController.js */
|
2022-09-13 20:18:30 +00:00
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* components:
|
|
|
|
* schemas:
|
|
|
|
* UsernamePassword:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - username
|
|
|
|
* - password
|
|
|
|
* properties:
|
|
|
|
* username:
|
|
|
|
* $ref: "#/components/schemas/Username"
|
|
|
|
* password:
|
|
|
|
* $ref: "#/components/schemas/Password"
|
|
|
|
* responses:
|
|
|
|
* AuthSuccessful:
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - success
|
|
|
|
* - token
|
|
|
|
* properties:
|
|
|
|
* success:
|
|
|
|
* type: boolean
|
|
|
|
* token:
|
|
|
|
* description: Token that can be used for user authentication in other API routes.
|
|
|
|
* type: string
|
|
|
|
* example:
|
|
|
|
* success: true
|
|
|
|
* token: YOUR_TOKEN_HERE
|
|
|
|
*/
|
2022-08-04 14:59:06 +00:00
|
|
|
|
2022-09-13 20:18:30 +00:00
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* /api/login:
|
|
|
|
* post:
|
|
|
|
* summary: Verify user credentials and get token
|
|
|
|
* tags:
|
|
|
|
* - Auth
|
|
|
|
* requestBody:
|
|
|
|
* required: true
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* $ref: "#/components/schemas/UsernamePassword"
|
|
|
|
* example:
|
|
|
|
* username: ""
|
|
|
|
* password: ""
|
|
|
|
* responses:
|
|
|
|
* 200:
|
|
|
|
* $ref: "#/components/responses/AuthSuccessful"
|
|
|
|
* 400:
|
|
|
|
* $ref: "#/components/responses/BadRequest"
|
|
|
|
* 403:
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* $ref: "#/components/schemas/Error"
|
|
|
|
* example:
|
|
|
|
* success: false
|
|
|
|
* description: Wrong credentials.
|
|
|
|
* 500:
|
|
|
|
* $ref: "#/components/responses/ServerError"
|
|
|
|
*/
|
2022-08-04 14:59:06 +00:00
|
|
|
routes.post('/login', utils.assertJSON, auth.verify)
|
2022-09-13 20:18:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* /api/register:
|
|
|
|
* post:
|
|
|
|
* summary: Register a user
|
|
|
|
* tags:
|
|
|
|
* - Auth
|
|
|
|
* requestBody:
|
|
|
|
* required: true
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* $ref: "#/components/schemas/UsernamePassword"
|
|
|
|
* example:
|
|
|
|
* username: ""
|
|
|
|
* password: ""
|
|
|
|
* responses:
|
|
|
|
* 200:
|
|
|
|
* $ref: "#/components/responses/AuthSuccessful"
|
|
|
|
* 400:
|
|
|
|
* $ref: "#/components/responses/BadRequest"
|
|
|
|
* 403:
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* $ref: "#/components/schemas/Error"
|
|
|
|
* example:
|
|
|
|
* success: false
|
|
|
|
* description: Registration is currently disabled.
|
|
|
|
* 500:
|
|
|
|
* $ref: "#/components/responses/ServerError"
|
|
|
|
*/
|
2022-08-04 14:59:06 +00:00
|
|
|
routes.post('/register', utils.assertJSON, auth.register)
|
2022-09-13 20:18:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* /api/password/change:
|
|
|
|
* post:
|
|
|
|
* summary: Change user's password
|
|
|
|
* tags:
|
|
|
|
* - Auth
|
|
|
|
* requestBody:
|
|
|
|
* required: true
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - password
|
|
|
|
* properties:
|
|
|
|
* password:
|
|
|
|
* $ref: "#/components/schemas/Password"
|
|
|
|
* example:
|
|
|
|
* password: ""
|
|
|
|
* responses:
|
|
|
|
* 200:
|
|
|
|
* $ref: "#/components/responses/Success"
|
|
|
|
* 400:
|
|
|
|
* $ref: "#/components/responses/BadRequest"
|
|
|
|
* 403:
|
|
|
|
* $ref: "#/components/responses/Unauthorized"
|
|
|
|
* 500:
|
|
|
|
* $ref: "#/components/responses/ServerError"
|
|
|
|
* security:
|
|
|
|
* - token: []
|
|
|
|
*/
|
2022-08-04 14:59:06 +00:00
|
|
|
routes.post('/password/change', [auth.requireUser, utils.assertJSON], auth.changePassword)
|
|
|
|
|
2022-09-13 20:18:30 +00:00
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* components:
|
|
|
|
* schemas:
|
|
|
|
* UserID:
|
|
|
|
* description: User's numerical ID in database.
|
|
|
|
* type: number
|
|
|
|
* User:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - id
|
|
|
|
* - username
|
|
|
|
* - enabled
|
|
|
|
* - timestamp
|
|
|
|
* - registration
|
|
|
|
* - groups
|
|
|
|
* - uploads
|
|
|
|
* - usage
|
|
|
|
* properties:
|
|
|
|
* id:
|
|
|
|
* $ref: "#/components/schemas/UserID"
|
|
|
|
* username:
|
|
|
|
* $ref: "#/components/schemas/Username"
|
|
|
|
* enabled:
|
|
|
|
* description: Whether user is enabled or not.
|
|
|
|
* type: boolean
|
|
|
|
* nullable: true
|
|
|
|
* timestamp:
|
|
|
|
* description: Timestamp of user's last token update.
|
|
|
|
* type: number
|
|
|
|
* nullable: true
|
|
|
|
* registration:
|
|
|
|
* description: Timestamp of user's registration date.
|
|
|
|
* type: number
|
|
|
|
* nullable: true
|
|
|
|
* groups:
|
|
|
|
* description: Usergroup(s) information.
|
|
|
|
* type: object
|
|
|
|
* uploads:
|
|
|
|
* description: Amount of uploads associated to this user.
|
|
|
|
* type: number
|
|
|
|
* usage:
|
|
|
|
* description: Amount of disk used by this user in bytes.
|
|
|
|
* type: number
|
|
|
|
* Usergroup:
|
|
|
|
* description: Usergroup name.
|
|
|
|
* type: string
|
|
|
|
* responses:
|
|
|
|
* UsersResponse:
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - success
|
|
|
|
* - users
|
|
|
|
* - usersPerPage
|
|
|
|
* - count
|
|
|
|
* properties:
|
|
|
|
* success:
|
|
|
|
* type: boolean
|
|
|
|
* users:
|
|
|
|
* description: Array of users.
|
|
|
|
* type: array
|
|
|
|
* items:
|
|
|
|
* $ref: "#/components/schemas/User"
|
|
|
|
* usersPerPage:
|
|
|
|
* description: Users per page for pagination.
|
|
|
|
* type: number
|
|
|
|
* count:
|
|
|
|
* description: Total users in database.
|
|
|
|
* type: number
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* /api/users:
|
|
|
|
* get:
|
|
|
|
* summary: Get users at page 1
|
|
|
|
* description: Requires admin permission.
|
|
|
|
* tags:
|
|
|
|
* - Users
|
|
|
|
* - Administration
|
|
|
|
* responses:
|
|
|
|
* 200:
|
|
|
|
* $ref: "#/components/responses/UsersResponse"
|
|
|
|
* 403:
|
|
|
|
* $ref: "#/components/responses/Unauthorized"
|
|
|
|
* 500:
|
|
|
|
* $ref: "#/components/responses/ServerError"
|
|
|
|
* security:
|
|
|
|
* - token: []
|
|
|
|
*/
|
2022-08-04 14:59:06 +00:00
|
|
|
routes.get('/users', auth.requireUser, auth.listUsers)
|
2022-09-13 20:18:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* /api/users/{page}:
|
|
|
|
* get:
|
|
|
|
* summary: Get users at page N
|
|
|
|
* description: Requires admin permission. This allows negative value to navigate backwards.
|
|
|
|
* tags:
|
|
|
|
* - Users
|
|
|
|
* - Administration
|
|
|
|
* parameters:
|
|
|
|
* - in: path
|
|
|
|
* name: page
|
|
|
|
* schema:
|
|
|
|
* type: number
|
|
|
|
* required: true
|
|
|
|
* description: Page of users to get.
|
|
|
|
* responses:
|
|
|
|
* 200:
|
|
|
|
* $ref: "#/components/responses/UsersResponse"
|
|
|
|
* 403:
|
|
|
|
* $ref: "#/components/responses/Unauthorized"
|
|
|
|
* 500:
|
|
|
|
* $ref: "#/components/responses/ServerError"
|
|
|
|
* security:
|
|
|
|
* - token: []
|
|
|
|
*/
|
2022-08-04 14:59:06 +00:00
|
|
|
routes.get('/users/:page', auth.requireUser, auth.listUsers)
|
|
|
|
|
2022-09-13 20:18:30 +00:00
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* /api/users/create:
|
|
|
|
* post:
|
|
|
|
* summary: Create a new user
|
|
|
|
* description: Requires admin permission. If password is omitted, server will generate a random one.
|
|
|
|
* tags:
|
|
|
|
* - Users
|
|
|
|
* - Administration
|
|
|
|
* requestBody:
|
|
|
|
* required: true
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - username
|
|
|
|
* - group
|
|
|
|
* properties:
|
|
|
|
* username:
|
|
|
|
* $ref: "#/components/schemas/Username"
|
|
|
|
* password:
|
|
|
|
* $ref: "#/components/schemas/Password"
|
|
|
|
* group:
|
|
|
|
* $ref: "#/components/schemas/Usergroup"
|
|
|
|
* example:
|
|
|
|
* username: ""
|
|
|
|
* password: ""
|
|
|
|
* group: user
|
|
|
|
* responses:
|
|
|
|
* 200:
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - success
|
|
|
|
* - username
|
|
|
|
* - password
|
|
|
|
* - group
|
|
|
|
* properties:
|
|
|
|
* success:
|
|
|
|
* type: boolean
|
|
|
|
* username:
|
|
|
|
* $ref: "#/components/schemas/Username"
|
|
|
|
* password:
|
|
|
|
* $ref: "#/components/schemas/Password"
|
|
|
|
* group:
|
|
|
|
* $ref: "#/components/schemas/Usergroup"
|
|
|
|
* 403:
|
|
|
|
* $ref: "#/components/responses/Unauthorized"
|
|
|
|
* 500:
|
|
|
|
* $ref: "#/components/responses/ServerError"
|
|
|
|
* security:
|
|
|
|
* - token: []
|
|
|
|
*/
|
2022-08-04 14:59:06 +00:00
|
|
|
routes.post('/users/create', [auth.requireUser, utils.assertJSON], auth.createUser)
|
2022-09-13 20:18:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* /api/users/delete:
|
|
|
|
* post:
|
|
|
|
* summary: Delete a user
|
|
|
|
* description: Requires admin permission.
|
|
|
|
* tags:
|
|
|
|
* - Users
|
|
|
|
* - Administration
|
|
|
|
* requestBody:
|
|
|
|
* required: true
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - id
|
|
|
|
* properties:
|
|
|
|
* id:
|
|
|
|
* $ref: "#/components/schemas/UserID"
|
|
|
|
* purge:
|
|
|
|
* description: Whether to purge the user's uploaded files as well.
|
|
|
|
* type: boolean
|
|
|
|
* example:
|
|
|
|
* id: 69420
|
|
|
|
* purge: false
|
|
|
|
* responses:
|
|
|
|
* 200:
|
|
|
|
* $ref: "#/components/responses/Success"
|
|
|
|
* 403:
|
|
|
|
* $ref: "#/components/responses/Unauthorized"
|
|
|
|
* 500:
|
|
|
|
* $ref: "#/components/responses/ServerError"
|
|
|
|
* security:
|
|
|
|
* - token: []
|
|
|
|
*/
|
2022-08-04 14:59:06 +00:00
|
|
|
routes.post('/users/delete', [auth.requireUser, utils.assertJSON], auth.deleteUser)
|
2022-09-13 20:18:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* /api/users/disable:
|
|
|
|
* post:
|
|
|
|
* summary: Disable a user
|
|
|
|
* description: Requires admin permission.
|
|
|
|
* tags:
|
|
|
|
* - Users
|
|
|
|
* - Administration
|
|
|
|
* requestBody:
|
|
|
|
* required: true
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - id
|
|
|
|
* properties:
|
|
|
|
* id:
|
|
|
|
* $ref: "#/components/schemas/UserID"
|
|
|
|
* example:
|
|
|
|
* id: 69420
|
|
|
|
* responses:
|
|
|
|
* 200:
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - success
|
|
|
|
* - update
|
|
|
|
* properties:
|
|
|
|
* success:
|
|
|
|
* type: boolean
|
|
|
|
* update:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - enabled
|
|
|
|
* properties:
|
|
|
|
* enabled:
|
|
|
|
* description: Whether user is enabled or not.
|
|
|
|
* type: boolean
|
|
|
|
* example:
|
|
|
|
* success: true
|
|
|
|
* update:
|
|
|
|
* enabled: false
|
|
|
|
* 403:
|
|
|
|
* $ref: "#/components/responses/Unauthorized"
|
|
|
|
* 500:
|
|
|
|
* $ref: "#/components/responses/ServerError"
|
|
|
|
* security:
|
|
|
|
* - token: []
|
|
|
|
*/
|
2022-08-04 14:59:06 +00:00
|
|
|
routes.post('/users/disable', [auth.requireUser, utils.assertJSON], auth.disableUser)
|
2022-09-13 20:18:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @openapi
|
|
|
|
* /api/users/edit:
|
|
|
|
* post:
|
|
|
|
* summary: Edit a user
|
|
|
|
* description: Requires admin permission.
|
|
|
|
* tags:
|
|
|
|
* - Users
|
|
|
|
* - Administration
|
|
|
|
* requestBody:
|
|
|
|
* required: true
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - id
|
|
|
|
* properties:
|
|
|
|
* id:
|
|
|
|
* $ref: "#/components/schemas/UserID"
|
|
|
|
* username:
|
|
|
|
* $ref: "#/components/schemas/Username"
|
|
|
|
* group:
|
|
|
|
* $ref: "#/components/schemas/Usergroup"
|
|
|
|
* enabled:
|
|
|
|
* description: Whether to enable or disable user.
|
|
|
|
* type: boolean
|
|
|
|
* resetPassword:
|
|
|
|
* description: Whether to reset user's password with a randomly generated one.
|
|
|
|
* type: boolean
|
|
|
|
* example:
|
|
|
|
* id: 69420
|
|
|
|
* username: ""
|
|
|
|
* group: user
|
|
|
|
* enabled: true
|
|
|
|
* resetPassword: false
|
|
|
|
* responses:
|
|
|
|
* 200:
|
|
|
|
* content:
|
|
|
|
* application/json:
|
|
|
|
* schema:
|
|
|
|
* type: object
|
|
|
|
* required:
|
|
|
|
* - success
|
|
|
|
* - update
|
|
|
|
* properties:
|
|
|
|
* success:
|
|
|
|
* type: boolean
|
|
|
|
* update:
|
|
|
|
* type: object
|
|
|
|
* properties:
|
|
|
|
* username:
|
|
|
|
* $ref: "#/components/schemas/Username"
|
|
|
|
* enabled:
|
|
|
|
* description: Whether user is enabled or not.
|
|
|
|
* type: boolean
|
|
|
|
* permission:
|
|
|
|
* description: Numeric permission according to selected usergroup.
|
|
|
|
* type: number
|
|
|
|
* password:
|
|
|
|
* $ref: "#/components/schemas/Password"
|
|
|
|
* 403:
|
|
|
|
* $ref: "#/components/responses/Unauthorized"
|
|
|
|
* 500:
|
|
|
|
* $ref: "#/components/responses/ServerError"
|
|
|
|
* security:
|
|
|
|
* - token: []
|
|
|
|
*/
|
2022-08-04 14:59:06 +00:00
|
|
|
routes.post('/users/edit', [auth.requireUser, utils.assertJSON], auth.editUser)
|
|
|
|
|
|
|
|
/** ./controllers/uploadController.js */
|
|
|
|
|
2022-08-04 18:12:58 +00:00
|
|
|
// HyperExpress defaults to 250kb
|
|
|
|
// https://github.com/kartikk221/hyper-express/blob/6.4.4/docs/Server.md#server-constructor-options
|
|
|
|
const maxBodyLength = parseInt(config.uploads.maxSize) * 1e6
|
|
|
|
routes.post('/upload', { max_body_length: maxBodyLength }, auth.optionalUser, upload.upload)
|
|
|
|
routes.post('/upload/:albumid', { max_body_length: maxBodyLength }, auth.optionalUser, upload.upload)
|
2022-08-04 14:59:06 +00:00
|
|
|
routes.post('/upload/finishchunks', [auth.optionalUser, utils.assertJSON], upload.finishChunks)
|
|
|
|
|
|
|
|
routes.get('/uploads', auth.requireUser, upload.list)
|
|
|
|
routes.get('/uploads/:page', auth.requireUser, upload.list)
|
|
|
|
routes.get('/album/:albumid/:page', auth.requireUser, upload.list)
|
|
|
|
|
|
|
|
routes.get('/upload/get/:identifier', auth.requireUser, upload.get)
|
|
|
|
routes.post('/upload/delete', [auth.requireUser, utils.assertJSON], upload.delete)
|
|
|
|
routes.post('/upload/bulkdelete', [auth.requireUser, utils.assertJSON], upload.bulkDelete)
|
|
|
|
|
|
|
|
/** ./controllers/albumsController.js */
|
|
|
|
|
|
|
|
routes.get('/albums', auth.requireUser, albums.list)
|
|
|
|
routes.get('/albums/:page', auth.requireUser, albums.list)
|
|
|
|
|
|
|
|
routes.get('/album/get/:identifier', albums.get)
|
|
|
|
routes.get('/album/zip/:identifier', albums.generateZip)
|
|
|
|
routes.get('/album/:identifier', albums.getUpstreamCompat)
|
|
|
|
|
|
|
|
routes.post('/albums', [auth.requireUser, utils.assertJSON], albums.create)
|
|
|
|
routes.post('/albums/addfiles', [auth.requireUser, utils.assertJSON], albums.addFiles)
|
|
|
|
routes.post('/albums/delete', [auth.requireUser, utils.assertJSON], albums.delete)
|
|
|
|
routes.post('/albums/disable', [auth.requireUser, utils.assertJSON], albums.disable)
|
|
|
|
routes.post('/albums/edit', [auth.requireUser, utils.assertJSON], albums.edit)
|
|
|
|
routes.post('/albums/rename', [auth.requireUser, utils.assertJSON], albums.rename)
|
|
|
|
|
|
|
|
/** ./controllers/tokenController.js **/
|
|
|
|
|
|
|
|
routes.get('/tokens', auth.requireUser, tokens.list)
|
2022-08-04 16:09:14 +00:00
|
|
|
routes.post('/tokens/change', (req, res, next) => {
|
2022-08-04 14:59:06 +00:00
|
|
|
// Include user's "token" field into database query
|
2022-08-04 16:09:14 +00:00
|
|
|
auth.requireUser(req, res, next, 'token')
|
2022-08-04 14:59:06 +00:00
|
|
|
}, tokens.change)
|
|
|
|
routes.post('/tokens/verify', utils.assertJSON, tokens.verify)
|
|
|
|
|
|
|
|
/** ./controllers/utilsController.js */
|
|
|
|
|
|
|
|
routes.get('/stats', [auth.requireUser], utils.stats)
|
2017-01-29 07:20:25 +00:00
|
|
|
|
2018-01-23 20:06:30 +00:00
|
|
|
module.exports = routes
|