feat: initiate db connection only once

db is now initiated via utilsController, and gets re-used by main
lolisafe.js script and the other controllers

this should now make sure we only have 1 active db connection pool ever

this is a pretty big refactor due to how we used to reference db,
but it should functionally be identical
This commit is contained in:
Bobby 2022-06-04 04:21:56 +07:00
parent 6768fa46f6
commit 8799189a04
No known key found for this signature in database
GPG Key ID: 941839794CBF5A09
10 changed files with 80 additions and 92 deletions

View File

@ -12,7 +12,6 @@ const ClientError = require('./utils/ClientError')
const ServerError = require('./utils/ServerError') const ServerError = require('./utils/ServerError')
const config = require('./../config') const config = require('./../config')
const logger = require('./../logger') const logger = require('./../logger')
const db = require('knex')(config.database)
const self = { const self = {
// Don't forget to update max length of text inputs in // Don't forget to update max length of text inputs in
@ -56,7 +55,7 @@ self.getUniqueRandomName = async () => {
// Put token on-hold (wait for it to be inserted to DB) // Put token on-hold (wait for it to be inserted to DB)
self.onHold.add(identifier) self.onHold.add(identifier)
const album = await db.table('albums') const album = await utils.db.table('albums')
.where('identifier', identifier) .where('identifier', identifier)
.select('id') .select('id')
.first() .first()
@ -91,7 +90,7 @@ self.list = async (req, res, next) => {
} }
// Query albums count for pagination // Query albums count for pagination
const count = await db.table('albums') const count = await utils.db.table('albums')
.where(filter) .where(filter)
.count('id as count') .count('id as count')
.then(rows => rows[0].count) .then(rows => rows[0].count)
@ -101,7 +100,7 @@ self.list = async (req, res, next) => {
let albums let albums
if (simple) { if (simple) {
albums = await db.table('albums') albums = await utils.db.table('albums')
.where(filter) .where(filter)
.select(fields) .select(fields)
@ -114,7 +113,7 @@ self.list = async (req, res, next) => {
fields.push('identifier', 'enabled', 'timestamp', 'editedAt', 'zipGeneratedAt', 'download', 'public', 'description') fields.push('identifier', 'enabled', 'timestamp', 'editedAt', 'zipGeneratedAt', 'download', 'public', 'description')
if (all) fields.push('userid') if (all) fields.push('userid')
albums = await db.table('albums') albums = await utils.db.table('albums')
.where(filter) .where(filter)
.limit(25) .limit(25)
.offset(25 * offset) .offset(25 * offset)
@ -149,7 +148,7 @@ self.list = async (req, res, next) => {
await Promise.all(albums.map(album => getAlbumZipSize(album))) await Promise.all(albums.map(album => getAlbumZipSize(album)))
const uploads = await db.table('files') const uploads = await utils.db.table('files')
.whereIn('albumid', Object.keys(albumids)) .whereIn('albumid', Object.keys(albumids))
.select('albumid', 'size') .select('albumid', 'size')
@ -174,7 +173,7 @@ self.list = async (req, res, next) => {
if (!userids.length) return res.json({ success: true, albums, count, homeDomain }) if (!userids.length) return res.json({ success: true, albums, count, homeDomain })
// Query usernames of user IDs from currently selected files // Query usernames of user IDs from currently selected files
const usersTable = await db.table('users') const usersTable = await utils.db.table('users')
.whereIn('id', userids) .whereIn('id', userids)
.select('id', 'username') .select('id', 'username')
@ -199,7 +198,7 @@ self.create = async (req, res, next) => {
if (!name) throw new ClientError('No album name specified.') if (!name) throw new ClientError('No album name specified.')
const album = await db.table('albums') const album = await utils.db.table('albums')
.where({ .where({
name, name,
enabled: 1, enabled: 1,
@ -211,7 +210,7 @@ self.create = async (req, res, next) => {
const identifier = await self.getUniqueRandomName() const identifier = await self.getUniqueRandomName()
const ids = await db.table('albums').insert({ const ids = await utils.db.table('albums').insert({
name, name,
enabled: 1, enabled: 1,
userid: user.id, userid: user.id,
@ -263,7 +262,7 @@ self.disable = async (req, res, next) => {
} }
} }
const album = await db.table('albums') const album = await utils.db.table('albums')
.where(filter) .where(filter)
.first() .first()
@ -272,7 +271,7 @@ self.disable = async (req, res, next) => {
} }
if (purge) { if (purge) {
const files = await db.table('files') const files = await utils.db.table('files')
.where({ .where({
albumid: id, albumid: id,
userid: album.userid userid: album.userid
@ -287,12 +286,12 @@ self.disable = async (req, res, next) => {
} }
if (del) { if (del) {
await db.table('albums') await utils.db.table('albums')
.where(filter) .where(filter)
.first() .first()
.del() .del()
} else { } else {
await db.table('albums') await utils.db.table('albums')
.where(filter) .where(filter)
.first() .first()
.update('enabled', 0) .update('enabled', 0)
@ -338,7 +337,7 @@ self.edit = async (req, res, next) => {
} }
} }
const album = await db.table('albums') const album = await utils.db.table('albums')
.where(filter) .where(filter)
.first() .first()
@ -350,7 +349,7 @@ self.edit = async (req, res, next) => {
? Boolean(req.body.enabled) ? Boolean(req.body.enabled)
: null : null
const nameInUse = await db.table('albums') const nameInUse = await utils.db.table('albums')
.where({ .where({
name, name,
enabled: 1, enabled: 1,
@ -385,7 +384,7 @@ self.edit = async (req, res, next) => {
update.identifier = await self.getUniqueRandomName() update.identifier = await self.getUniqueRandomName()
} }
await db.table('albums') await utils.db.table('albums')
.where(filter) .where(filter)
.update(update) .update(update)
utils.invalidateAlbumsCache([id]) utils.invalidateAlbumsCache([id])
@ -429,7 +428,7 @@ self.get = async (req, res, next) => {
throw new ClientError('No identifier provided.') throw new ClientError('No identifier provided.')
} }
const album = await db.table('albums') const album = await utils.db.table('albums')
.where({ .where({
identifier, identifier,
enabled: 1 enabled: 1
@ -441,7 +440,7 @@ self.get = async (req, res, next) => {
} }
const title = album.name const title = album.name
const files = await db.table('files') const files = await utils.db.table('files')
.select('name') .select('name')
.where('albumid', album.id) .where('albumid', album.id)
.orderBy('id', 'desc') .orderBy('id', 'desc')
@ -486,7 +485,7 @@ self.generateZip = async (req, res, next) => {
throw new ClientError('ZIP generation disabled.', { statusCode: 403 }) throw new ClientError('ZIP generation disabled.', { statusCode: 403 })
} }
const album = await db.table('albums') const album = await utils.db.table('albums')
.where({ .where({
identifier, identifier,
enabled: 1 enabled: 1
@ -530,7 +529,7 @@ self.generateZip = async (req, res, next) => {
logger.log(`Starting zip task for album: ${identifier}.`) logger.log(`Starting zip task for album: ${identifier}.`)
const files = await db.table('files') const files = await utils.db.table('files')
.select('name', 'size') .select('name', 'size')
.where('albumid', album.id) .where('albumid', album.id)
if (files.length === 0) { if (files.length === 0) {
@ -574,7 +573,7 @@ self.generateZip = async (req, res, next) => {
logger.log(`Finished zip task for album: ${identifier} (success).`) logger.log(`Finished zip task for album: ${identifier} (success).`)
await db.table('albums') await utils.db.table('albums')
.where('id', album.id) .where('id', album.id)
.update('zipGeneratedAt', Math.floor(Date.now() / 1000)) .update('zipGeneratedAt', Math.floor(Date.now() / 1000))
utils.invalidateStatsCache('albums') utils.invalidateStatsCache('albums')
@ -641,7 +640,7 @@ self.addFiles = async (req, res, next) => {
failed = [] failed = []
albumids = [] albumids = []
if (albumid !== null) { if (albumid !== null) {
const album = await db.table('albums') const album = await utils.db.table('albums')
.where('id', albumid) .where('id', albumid)
.where(function () { .where(function () {
if (user.username !== 'root') { if (user.username !== 'root') {
@ -657,13 +656,13 @@ self.addFiles = async (req, res, next) => {
albumids.push(albumid) albumids.push(albumid)
} }
const files = await db.table('files') const files = await utils.db.table('files')
.whereIn('id', ids) .whereIn('id', ids)
.where('userid', user.id) .where('userid', user.id)
failed = ids.filter(id => !files.find(file => file.id === id)) failed = ids.filter(id => !files.find(file => file.id === id))
await db.table('files') await utils.db.table('files')
.whereIn('id', files.map(file => file.id)) .whereIn('id', files.map(file => file.id))
.update('albumid', albumid) .update('albumid', albumid)
utils.invalidateStatsCache('albums') utils.invalidateStatsCache('albums')
@ -674,7 +673,7 @@ self.addFiles = async (req, res, next) => {
} }
}) })
await db.table('albums') await utils.db.table('albums')
.whereIn('id', albumids) .whereIn('id', albumids)
.update('editedAt', Math.floor(Date.now() / 1000)) .update('editedAt', Math.floor(Date.now() / 1000))
utils.invalidateAlbumsCache(albumids) utils.invalidateAlbumsCache(albumids)

View File

@ -9,7 +9,6 @@ const apiErrorsHandler = require('./handlers/apiErrorsHandler.js')
const ClientError = require('./utils/ClientError') const ClientError = require('./utils/ClientError')
const ServerError = require('./utils/ServerError') const ServerError = require('./utils/ServerError')
const config = require('./../config') const config = require('./../config')
const db = require('knex')(config.database)
// Don't forget to update min/max length of text inputs in auth.njk // Don't forget to update min/max length of text inputs in auth.njk
// when changing these values. // when changing these values.
@ -44,7 +43,7 @@ self.verify = async (req, res, next) => {
: '' : ''
if (!password) throw new ClientError('No password provided.') if (!password) throw new ClientError('No password provided.')
const user = await db.table('users') const user = await utils.db.table('users')
.where('username', username) .where('username', username)
.first() .first()
@ -85,7 +84,7 @@ self.register = async (req, res, next) => {
throw new ClientError(`Password must have ${self.pass.min}-${self.pass.max} characters.`) throw new ClientError(`Password must have ${self.pass.min}-${self.pass.max} characters.`)
} }
const user = await db.table('users') const user = await utils.db.table('users')
.where('username', username) .where('username', username)
.first() .first()
@ -98,7 +97,7 @@ self.register = async (req, res, next) => {
throw new ServerError('Failed to allocate a unique token. Try again?') throw new ServerError('Failed to allocate a unique token. Try again?')
} }
await db.table('users') await utils.db.table('users')
.insert({ .insert({
username, username,
password: hash, password: hash,
@ -129,7 +128,7 @@ self.changePassword = async (req, res, next) => {
const hash = await bcrypt.hash(password, saltRounds) const hash = await bcrypt.hash(password, saltRounds)
await db.table('users') await utils.db.table('users')
.where('id', user.id) .where('id', user.id)
.update('password', hash) .update('password', hash)
@ -184,7 +183,7 @@ self.createUser = async (req, res, next) => {
} }
} }
const exists = await db.table('users') const exists = await utils.db.table('users')
.where('username', username) .where('username', username)
.first() .first()
@ -197,7 +196,7 @@ self.createUser = async (req, res, next) => {
throw new ServerError('Failed to allocate a unique token. Try again?') throw new ServerError('Failed to allocate a unique token. Try again?')
} }
await db.table('users') await utils.db.table('users')
.insert({ .insert({
username, username,
password: hash, password: hash,
@ -225,7 +224,7 @@ self.editUser = async (req, res, next) => {
const id = parseInt(req.body.id) const id = parseInt(req.body.id)
if (isNaN(id)) throw new ClientError('No user specified.') if (isNaN(id)) throw new ClientError('No user specified.')
const target = await db.table('users') const target = await utils.db.table('users')
.where('id', id) .where('id', id)
.first() .first()
self.assertPermission(user, target) self.assertPermission(user, target)
@ -256,7 +255,7 @@ self.editUser = async (req, res, next) => {
update.password = await bcrypt.hash(password, saltRounds) update.password = await bcrypt.hash(password, saltRounds)
} }
await db.table('users') await utils.db.table('users')
.where('id', id) .where('id', id)
.update(update) .update(update)
utils.invalidateStatsCache('users') utils.invalidateStatsCache('users')
@ -285,12 +284,12 @@ self.deleteUser = async (req, res, next) => {
const purge = req.body.purge const purge = req.body.purge
if (isNaN(id)) throw new ClientError('No user specified.') if (isNaN(id)) throw new ClientError('No user specified.')
const target = await db.table('users') const target = await utils.db.table('users')
.where('id', id) .where('id', id)
.first() .first()
self.assertPermission(user, target) self.assertPermission(user, target)
const files = await db.table('files') const files = await utils.db.table('files')
.where('userid', id) .where('userid', id)
.select('id') .select('id')
@ -302,20 +301,20 @@ self.deleteUser = async (req, res, next) => {
utils.invalidateStatsCache('uploads') utils.invalidateStatsCache('uploads')
} else { } else {
// Clear out userid attribute from the files // Clear out userid attribute from the files
await db.table('files') await utils.db.table('files')
.whereIn('id', fileids) .whereIn('id', fileids)
.update('userid', null) .update('userid', null)
} }
} }
const albums = await db.table('albums') const albums = await utils.db.table('albums')
.where('userid', id) .where('userid', id)
.where('enabled', 1) .where('enabled', 1)
.select('id', 'identifier') .select('id', 'identifier')
if (albums.length) { if (albums.length) {
const albumids = albums.map(album => album.id) const albumids = albums.map(album => album.id)
await db.table('albums') await utils.db.table('albums')
.whereIn('id', albumids) .whereIn('id', albumids)
.del() .del()
utils.invalidateAlbumsCache(albumids) utils.invalidateAlbumsCache(albumids)
@ -331,7 +330,7 @@ self.deleteUser = async (req, res, next) => {
})) }))
} }
await db.table('users') await utils.db.table('users')
.where('id', id) .where('id', id)
.del() .del()
utils.invalidateStatsCache('users') utils.invalidateStatsCache('users')
@ -353,7 +352,7 @@ self.listUsers = async (req, res, next) => {
const isadmin = perms.is(user, 'admin') const isadmin = perms.is(user, 'admin')
if (!isadmin) throw new ClientError('', { statusCode: 403 }) if (!isadmin) throw new ClientError('', { statusCode: 403 })
const count = await db.table('users') const count = await utils.db.table('users')
.count('id as count') .count('id as count')
.then(rows => rows[0].count) .then(rows => rows[0].count)
if (!count) return res.json({ success: true, users: [], count }) if (!count) return res.json({ success: true, users: [], count })
@ -362,7 +361,7 @@ self.listUsers = async (req, res, next) => {
if (isNaN(offset)) offset = 0 if (isNaN(offset)) offset = 0
else if (offset < 0) offset = Math.max(0, Math.ceil(count / 25) + offset) else if (offset < 0) offset = Math.max(0, Math.ceil(count / 25) + offset)
const users = await db.table('users') const users = await utils.db.table('users')
.limit(25) .limit(25)
.offset(25 * offset) .offset(25 * offset)
.select('id', 'username', 'enabled', 'timestamp', 'permission', 'registration') .select('id', 'username', 'enabled', 'timestamp', 'permission', 'registration')
@ -376,7 +375,7 @@ self.listUsers = async (req, res, next) => {
pointers[user.id] = user pointers[user.id] = user
} }
const uploads = await db.table('files') const uploads = await utils.db.table('files')
.whereIn('userid', Object.keys(pointers)) .whereIn('userid', Object.keys(pointers))
.select('userid', 'size') .select('userid', 'size')

View File

@ -4,8 +4,6 @@ const utils = require('./utilsController')
const apiErrorsHandler = require('./handlers/apiErrorsHandler') const apiErrorsHandler = require('./handlers/apiErrorsHandler')
const ClientError = require('./utils/ClientError') const ClientError = require('./utils/ClientError')
const ServerError = require('./utils/ServerError') const ServerError = require('./utils/ServerError')
const config = require('./../config')
const db = require('knex')(config.database)
const self = { const self = {
tokenLength: 64, tokenLength: 64,
@ -21,7 +19,7 @@ self.generateUniqueToken = async () => {
// Put token on-hold (wait for it to be inserted to DB) // Put token on-hold (wait for it to be inserted to DB)
self.onHold.add(token) self.onHold.add(token)
const user = await db.table('users') const user = await utils.db.table('users')
.where('token', token) .where('token', token)
.select('id') .select('id')
.first() .first()
@ -44,7 +42,7 @@ self.verify = async (req, res, next) => {
if (!token) throw new ClientError('No token provided.', { statusCode: 403 }) if (!token) throw new ClientError('No token provided.', { statusCode: 403 })
const user = await db.table('users') const user = await utils.db.table('users')
.where('token', token) .where('token', token)
.select('username', 'permission') .select('username', 'permission')
.first() .first()
@ -96,7 +94,7 @@ self.change = async (req, res, next) => {
throw new ServerError('Failed to allocate a unique token. Try again?') throw new ServerError('Failed to allocate a unique token. Try again?')
} }
await db.table('users') await utils.db.table('users')
.where('token', user.token) .where('token', user.token)
.update({ .update({
token: newToken, token: newToken,

View File

@ -14,7 +14,6 @@ const multerStorage = require('./utils/multerStorage')
const ServerError = require('./utils/ServerError') const ServerError = require('./utils/ServerError')
const config = require('./../config') const config = require('./../config')
const logger = require('./../logger') const logger = require('./../logger')
const db = require('knex')(config.database)
const self = { const self = {
onHold: new Set(), onHold: new Set(),
@ -213,7 +212,7 @@ self.getUniqueRandomName = async (length, extension) => {
// Put token on-hold (wait for it to be inserted to DB) // Put token on-hold (wait for it to be inserted to DB)
self.onHold.add(identifier) self.onHold.add(identifier)
const file = await db.table('files') const file = await utils.db.table('files')
.whereRaw('?? like ?', ['name', `${identifier}.%`]) .whereRaw('?? like ?', ['name', `${identifier}.%`])
.select('id') .select('id')
.first() .first()
@ -827,7 +826,7 @@ self.storeFilesToDb = async (req, res, user, infoMap) => {
await Promise.all(infoMap.map(async info => { await Promise.all(infoMap.map(async info => {
// Check if the file exists by checking its hash and size // Check if the file exists by checking its hash and size
const dbFile = await db.table('files') const dbFile = await utils.db.table('files')
.where(function () { .where(function () {
if (user === undefined) { if (user === undefined) {
this.whereNull('userid') this.whereNull('userid')
@ -892,7 +891,7 @@ self.storeFilesToDb = async (req, res, user, infoMap) => {
if (files.length) { if (files.length) {
let authorizedIds = [] let authorizedIds = []
if (albumids.length) { if (albumids.length) {
authorizedIds = await db.table('albums') authorizedIds = await utils.db.table('albums')
.where({ userid: user.id }) .where({ userid: user.id })
.whereIn('id', albumids) .whereIn('id', albumids)
.select('id') .select('id')
@ -907,7 +906,7 @@ self.storeFilesToDb = async (req, res, user, infoMap) => {
} }
// Insert new files to DB // Insert new files to DB
await db.table('files').insert(files) await utils.db.table('files').insert(files)
utils.invalidateStatsCache('uploads') utils.invalidateStatsCache('uploads')
if (config.uploads.queryDbForFileCollisions) { if (config.uploads.queryDbForFileCollisions) {
@ -920,7 +919,7 @@ self.storeFilesToDb = async (req, res, user, infoMap) => {
// Update albums' timestamp // Update albums' timestamp
if (authorizedIds.length) { if (authorizedIds.length) {
await db.table('albums') await utils.db.table('albums')
.whereIn('id', authorizedIds) .whereIn('id', authorizedIds)
.update('editedAt', Math.floor(Date.now() / 1000)) .update('editedAt', Math.floor(Date.now() / 1000))
utils.invalidateAlbumsCache(authorizedIds) utils.invalidateAlbumsCache(authorizedIds)
@ -1253,7 +1252,7 @@ self.list = async (req, res, next) => {
usernames.push(...filterObj.queries.exclude.user) usernames.push(...filterObj.queries.exclude.user)
} }
const uploaders = await db.table('users') const uploaders = await utils.db.table('users')
.whereIn('username', usernames) .whereIn('username', usernames)
.select('id', 'username') .select('id', 'username')
@ -1490,7 +1489,7 @@ self.list = async (req, res, next) => {
} }
// Query uploads count for pagination // Query uploads count for pagination
const count = await db.table('files') const count = await utils.db.table('files')
.where(filter) .where(filter)
.count('id as count') .count('id as count')
.then(rows => rows[0].count) .then(rows => rows[0].count)
@ -1516,16 +1515,16 @@ self.list = async (req, res, next) => {
orderByRaw = sortObj.parsed.map(sort => { orderByRaw = sortObj.parsed.map(sort => {
// Use Knex.raw() to sanitize user inputs // Use Knex.raw() to sanitize user inputs
if (sort.cast) { if (sort.cast) {
return db.raw(`cast (?? as ${sort.cast}) ${sort.order} ${sort.clause}`.trim(), sort.column) return utils.db.raw(`cast (?? as ${sort.cast}) ${sort.order} ${sort.clause}`.trim(), sort.column)
} else { } else {
return db.raw(`?? ${sort.order} ${sort.clause}`.trim(), sort.column) return utils.db.raw(`?? ${sort.order} ${sort.clause}`.trim(), sort.column)
} }
}).join(', ') }).join(', ')
} else { } else {
orderByRaw = '`id` desc' orderByRaw = '`id` desc'
} }
const files = await db.table('files') const files = await utils.db.table('files')
.where(filter) .where(filter)
.orderByRaw(orderByRaw) .orderByRaw(orderByRaw)
.limit(25) .limit(25)
@ -1549,7 +1548,7 @@ self.list = async (req, res, next) => {
.filter((v, i, a) => { .filter((v, i, a) => {
return v !== null && v !== undefined && v !== '' && a.indexOf(v) === i return v !== null && v !== undefined && v !== '' && a.indexOf(v) === i
}) })
albums = await db.table('albums') albums = await utils.db.table('albums')
.whereIn('id', albumids) .whereIn('id', albumids)
.where('enabled', 1) .where('enabled', 1)
.select('id', 'name') .select('id', 'name')
@ -1579,7 +1578,7 @@ self.list = async (req, res, next) => {
if (!userids.length) return res.json({ success: true, files, count, albums, basedomain }) if (!userids.length) return res.json({ success: true, files, count, albums, basedomain })
// Query usernames of user IDs from currently selected files // Query usernames of user IDs from currently selected files
usersTable = await db.table('users') usersTable = await utils.db.table('users')
.whereIn('id', userids) .whereIn('id', userids)
.select('id', 'username') .select('id', 'username')
} }

View File

@ -2,6 +2,7 @@ const { promisify } = require('util')
const fetch = require('node-fetch') const fetch = require('node-fetch')
const ffmpeg = require('fluent-ffmpeg') const ffmpeg = require('fluent-ffmpeg')
const MarkdownIt = require('markdown-it') const MarkdownIt = require('markdown-it')
const knex = require('knex')
const path = require('path') const path = require('path')
const sharp = require('sharp') const sharp = require('sharp')
const si = require('systeminformation') const si = require('systeminformation')
@ -12,9 +13,9 @@ const ClientError = require('./utils/ClientError')
const ServerError = require('./utils/ServerError') const ServerError = require('./utils/ServerError')
const config = require('./../config') const config = require('./../config')
const logger = require('./../logger') const logger = require('./../logger')
const db = require('knex')(config.database)
const self = { const self = {
db: knex(config.database),
scan: { scan: {
instance: null, instance: null,
version: null, version: null,
@ -296,7 +297,7 @@ self.assertUser = async (token, fields) => {
_fields.push(...fields) _fields.push(...fields)
} }
const user = await db.table('users') const user = await self.db.table('users')
.where('token', token) .where('token', token)
.select(_fields) .select(_fields)
.first() .first()
@ -539,7 +540,7 @@ self.bulkDeleteFromDb = async (field, values, user) => {
const albumids = [] const albumids = []
await Promise.all(chunks.map(async chunk => { await Promise.all(chunks.map(async chunk => {
const files = await db.table('files') const files = await self.db.table('files')
.whereIn(field, chunk) .whereIn(field, chunk)
.where(function () { .where(function () {
if (!ismoderator) { if (!ismoderator) {
@ -566,7 +567,7 @@ self.bulkDeleteFromDb = async (field, values, user) => {
if (!unlinked.length) return if (!unlinked.length) return
// Delete all unlinked files from db // Delete all unlinked files from db
await db.table('files') await self.db.table('files')
.whereIn('id', unlinked.map(file => file.id)) .whereIn('id', unlinked.map(file => file.id))
.del() .del()
self.invalidateStatsCache('uploads') self.invalidateStatsCache('uploads')
@ -593,7 +594,7 @@ self.bulkDeleteFromDb = async (field, values, user) => {
if (unlinkeds.length) { if (unlinkeds.length) {
// Update albums if necessary, but do not wait // Update albums if necessary, but do not wait
if (albumids.length) { if (albumids.length) {
db.table('albums') self.db.table('albums')
.whereIn('id', albumids) .whereIn('id', albumids)
.update('editedAt', Math.floor(Date.now() / 1000)) .update('editedAt', Math.floor(Date.now() / 1000))
.catch(logger.error) .catch(logger.error)
@ -735,7 +736,7 @@ self.bulkDeleteExpired = async (dryrun, verbose) => {
const sudo = { username: 'root' } const sudo = { username: 'root' }
const result = {} const result = {}
result.expired = await db.table('files') result.expired = await self.db.table('files')
.where('expirydate', '<=', timestamp) .where('expirydate', '<=', timestamp)
.select(fields) .select(fields)
@ -904,14 +905,14 @@ self.stats = async (req, res, next) => {
} }
const getTotalCountAndSize = async () => { const getTotalCountAndSize = async () => {
const uploads = await db.table('files') const uploads = await self.db.table('files')
.select('size') .select('size')
stats[data.title].Total = uploads.length stats[data.title].Total = uploads.length
stats[data.title]['Size in DB'].value = uploads.reduce((acc, upload) => acc + parseInt(upload.size), 0) stats[data.title]['Size in DB'].value = uploads.reduce((acc, upload) => acc + parseInt(upload.size), 0)
} }
const getImagesCount = async () => { const getImagesCount = async () => {
stats[data.title].Images = await db.table('files') stats[data.title].Images = await self.db.table('files')
.where(function () { .where(function () {
for (const ext of self.imageExts) { for (const ext of self.imageExts) {
this.orWhere('name', 'like', `%${ext}`) this.orWhere('name', 'like', `%${ext}`)
@ -922,7 +923,7 @@ self.stats = async (req, res, next) => {
} }
const getVideosCount = async () => { const getVideosCount = async () => {
stats[data.title].Videos = await db.table('files') stats[data.title].Videos = await self.db.table('files')
.where(function () { .where(function () {
for (const ext of self.videoExts) { for (const ext of self.videoExts) {
this.orWhere('name', 'like', `%${ext}`) this.orWhere('name', 'like', `%${ext}`)
@ -933,7 +934,7 @@ self.stats = async (req, res, next) => {
} }
const getAudiosCount = async () => { const getAudiosCount = async () => {
stats[data.title].Audios = await db.table('files') stats[data.title].Audios = await self.db.table('files')
.where(function () { .where(function () {
for (const ext of self.audioExts) { for (const ext of self.audioExts) {
this.orWhere('name', 'like', `%${ext}`) this.orWhere('name', 'like', `%${ext}`)
@ -944,7 +945,7 @@ self.stats = async (req, res, next) => {
} }
const getOthersCount = async () => { const getOthersCount = async () => {
stats[data.title].Temporary = await db.table('files') stats[data.title].Temporary = await self.db.table('files')
.whereNotNull('expirydate') .whereNotNull('expirydate')
.count('id as count') .count('id as count')
.then(rows => rows[0].count) .then(rows => rows[0].count)
@ -991,7 +992,7 @@ self.stats = async (req, res, next) => {
stats[data.title][p] = 0 stats[data.title][p] = 0
}) })
const users = await db.table('users') const users = await self.db.table('users')
stats[data.title].Total = users.length stats[data.title].Total = users.length
for (const user of users) { for (const user of users) {
if (user.enabled === false || user.enabled === 0) { if (user.enabled === false || user.enabled === 0) {
@ -1033,7 +1034,7 @@ self.stats = async (req, res, next) => {
'ZIP Generated': 0 'ZIP Generated': 0
} }
const albums = await db.table('albums') const albums = await self.db.table('albums')
stats[data.title].Total = albums.length stats[data.title].Total = albums.length
const activeAlbums = [] const activeAlbums = []
@ -1051,7 +1052,7 @@ self.stats = async (req, res, next) => {
stats[data.title]['ZIP Generated'] = files.length stats[data.title]['ZIP Generated'] = files.length
}).catch(() => {}) }).catch(() => {})
stats[data.title]['Files in albums'] = await db.table('files') stats[data.title]['Files in albums'] = await self.db.table('files')
.whereIn('albumid', activeAlbums) .whereIn('albumid', activeAlbums)
.count('id as count') .count('id as count')
.then(rows => rows[0].count) .then(rows => rows[0].count)

View File

@ -48,7 +48,6 @@ const api = require('./routes/api')
const nojs = require('./routes/nojs') const nojs = require('./routes/nojs')
const player = require('./routes/player') const player = require('./routes/player')
const db = require('knex')(config.database)
const isDevMode = process.env.NODE_ENV === 'development' const isDevMode = process.env.NODE_ENV === 'development'
// Helmet security headers // Helmet security headers
@ -144,7 +143,7 @@ const initServeStaticUploads = (opts = {}) => {
const relpath = path.replace(paths.uploads, '') const relpath = path.replace(paths.uploads, '')
if (relpath.indexOf('/', 1) === -1 && req.method === 'GET') { if (relpath.indexOf('/', 1) === -1 && req.method === 'GET') {
const name = relpath.substring(1) const name = relpath.substring(1)
const file = await db.table('files') const file = await utils.db.table('files')
.where('name', name) .where('name', name)
.select('original') .select('original')
.first() .first()
@ -250,7 +249,7 @@ safe.use('/api', api)
;(async () => { ;(async () => {
try { try {
// Init database // Init database
await require('./database/db.js')(db) await require('./database/db.js')(utils.db)
// Verify paths, create missing ones, clean up temp ones // Verify paths, create missing ones, clean up temp ones
await paths.init() await paths.init()
@ -335,7 +334,7 @@ safe.use('/api', api)
// Cache file identifiers // Cache file identifiers
if (config.uploads.cacheFileIdentifiers) { if (config.uploads.cacheFileIdentifiers) {
utils.idSet = await db.table('files') utils.idSet = await utils.db.table('files')
.select('name') .select('name')
.then(rows => { .then(rows => {
return new Set(rows.map(row => row.name.split('.')[0])) return new Set(rows.map(row => row.name.split('.')[0]))

View File

@ -3,7 +3,6 @@ const path = require('path')
const paths = require('./../controllers/pathsController') const paths = require('./../controllers/pathsController')
const utils = require('./../controllers/utilsController') const utils = require('./../controllers/utilsController')
const config = require('./../config') const config = require('./../config')
const db = require('knex')(config.database)
routes.get('/a/:identifier', async (req, res, next) => { routes.get('/a/:identifier', async (req, res, next) => {
const identifier = req.params.identifier const identifier = req.params.identifier
@ -11,7 +10,7 @@ routes.get('/a/:identifier', async (req, res, next) => {
res.status(404).sendFile(path.join(paths.errorRoot, config.errorPages[404])) res.status(404).sendFile(path.join(paths.errorRoot, config.errorPages[404]))
} }
const album = await db.table('albums') const album = await utils.db.table('albums')
.where({ .where({
identifier, identifier,
enabled: 1 enabled: 1
@ -51,7 +50,7 @@ routes.get('/a/:identifier', async (req, res, next) => {
utils.albumsCache[cacheid].generating = true utils.albumsCache[cacheid].generating = true
} }
const files = await db.table('files') const files = await utils.db.table('files')
.select('name', 'size') .select('name', 'size')
.where('albumid', album.id) .where('albumid', album.id)
.orderBy('id', 'desc') .orderBy('id', 'desc')

View File

@ -1,8 +1,6 @@
const path = require('path') const path = require('path')
const paths = require('../controllers/pathsController') const paths = require('../controllers/pathsController')
const utils = require('../controllers/utilsController') const utils = require('../controllers/utilsController')
const config = require('./../config')
const db = require('knex')(config.database)
const self = { const self = {
getFiles: async directory => { getFiles: async directory => {
@ -43,7 +41,7 @@ const self = {
const uploads = await self.getFiles(paths.uploads) const uploads = await self.getFiles(paths.uploads)
console.log(`Uploads: ${uploads.length}`) console.log(`Uploads: ${uploads.length}`)
const uploadsDb = await db.table('files') const uploadsDb = await utils.db.table('files')
.select('name') .select('name')
.then(rows => rows.map(row => row.name)) .then(rows => rows.map(row => row.name))
console.log(`- In DB: ${uploadsDb.length}`) console.log(`- In DB: ${uploadsDb.length}`)

View File

@ -3,8 +3,6 @@ const fs = require('fs')
const path = require('path') const path = require('path')
const paths = require('../controllers/pathsController') const paths = require('../controllers/pathsController')
const utils = require('../controllers/utilsController') const utils = require('../controllers/utilsController')
const config = require('./../config')
const db = require('knex')(config.database)
;(async () => { ;(async () => {
const location = process.argv[1].replace(process.cwd() + '/', '') const location = process.argv[1].replace(process.cwd() + '/', '')
@ -33,7 +31,7 @@ const db = require('knex')(config.database)
console.log('Querying uploads\u2026') console.log('Querying uploads\u2026')
const hrstart = process.hrtime() const hrstart = process.hrtime()
const uploads = await db.table('files') const uploads = await utils.db.table('files')
.select('id', 'name', 'hash') .select('id', 'name', 'hash')
console.log(`Uploads : ${uploads.length}`) console.log(`Uploads : ${uploads.length}`)
@ -56,7 +54,7 @@ const db = require('knex')(config.database)
const hash = source.toString('hex') const hash = source.toString('hex')
if (verbose) console.log(`${upload.name}: ${hash}`) if (verbose) console.log(`${upload.name}: ${hash}`)
if (!dryrun && upload.hash !== hash) { if (!dryrun && upload.hash !== hash) {
await db.table('files') await utils.db.table('files')
.update('hash', hash) .update('hash', hash)
.where('id', upload.id) .where('id', upload.id)
} }

View File

@ -1,8 +1,6 @@
const path = require('path') const path = require('path')
const paths = require('../controllers/pathsController') const paths = require('../controllers/pathsController')
const utils = require('../controllers/utilsController') const utils = require('../controllers/utilsController')
const config = require('./../config')
const db = require('knex')(config.database)
const self = { const self = {
mode: null, mode: null,
@ -53,7 +51,7 @@ const self = {
console.log('Looking through existing thumbnails\u2026') console.log('Looking through existing thumbnails\u2026')
const hrstart = process.hrtime() const hrstart = process.hrtime()
const uploads = await db.table('files') const uploads = await utils.db.table('files')
.select('id', 'name') .select('id', 'name')
const thumbs = await self.getFiles(paths.thumbs) const thumbs = await self.getFiles(paths.thumbs)
.then(thumbs => thumbs.map(thumb => { .then(thumbs => thumbs.map(thumb => {