2017-10-04 02:13:38 +02:00
|
|
|
const config = require('../config.js');
|
|
|
|
const db = require('knex')(config.database);
|
|
|
|
const randomstring = require('randomstring');
|
|
|
|
const utils = require('./utilsController.js');
|
|
|
|
const path = require('path');
|
|
|
|
|
|
|
|
const albumsController = {};
|
|
|
|
|
|
|
|
albumsController.list = async (req, res, next) => {
|
|
|
|
const user = await utils.authorize(req, res);
|
|
|
|
|
|
|
|
const fields = ['id', 'name'];
|
|
|
|
if (req.params.sidebar === undefined) {
|
|
|
|
fields.push('timestamp');
|
|
|
|
fields.push('identifier');
|
|
|
|
}
|
|
|
|
|
|
|
|
const albums = await db.table('albums').select(fields).where({ enabled: 1, userid: user.id });
|
|
|
|
if (req.params.sidebar !== undefined) {
|
|
|
|
return res.json({ success: true, albums });
|
|
|
|
}
|
|
|
|
|
|
|
|
let ids = [];
|
|
|
|
for (let album of albums) {
|
|
|
|
album.date = new Date(album.timestamp * 1000)
|
|
|
|
album.date = utils.getPrettyDate(album.date)
|
|
|
|
|
|
|
|
album.identifier = `${config.domain}/a/${album.identifier}`;
|
|
|
|
ids.push(album.id);
|
|
|
|
}
|
|
|
|
|
|
|
|
const files = await db.table('files').whereIn('albumid', ids).select('albumid');
|
|
|
|
const albumsCount = {};
|
|
|
|
|
|
|
|
for (let id of ids) albumsCount[id] = 0;
|
|
|
|
for (let file of files) albumsCount[file.albumid] += 1;
|
|
|
|
for (let album of albums) album.files = albumsCount[album.id];
|
|
|
|
|
|
|
|
return res.json({ success: true, albums });
|
|
|
|
};
|
|
|
|
|
|
|
|
albumsController.create = async (req, res, next) => {
|
|
|
|
const user = await utils.authorize(req, res);
|
|
|
|
|
|
|
|
const name = req.body.name;
|
|
|
|
if (name === undefined || name === '') {
|
|
|
|
return res.json({ success: false, description: 'No album name specified' });
|
|
|
|
}
|
|
|
|
|
|
|
|
const album = await db.table('albums').where({
|
|
|
|
name: name,
|
|
|
|
enabled: 1,
|
|
|
|
userid: user.id
|
|
|
|
}).first();
|
|
|
|
|
|
|
|
if (album) {
|
|
|
|
return res.json({ success: false, description: 'There\'s already an album with that name' })
|
|
|
|
}
|
|
|
|
|
|
|
|
await db.table('albums').insert({
|
|
|
|
name: name,
|
|
|
|
enabled: 1,
|
|
|
|
userid: user.id,
|
|
|
|
identifier: randomstring.generate(8),
|
|
|
|
timestamp: Math.floor(Date.now() / 1000)
|
|
|
|
});
|
|
|
|
|
|
|
|
return res.json({ success: true });
|
|
|
|
};
|
|
|
|
|
|
|
|
albumsController.delete = async (req, res, next) => {
|
|
|
|
const user = await utils.authorize(req, res);
|
|
|
|
|
|
|
|
const id = req.body.id;
|
|
|
|
if (id === undefined || id === '') {
|
|
|
|
return res.json({ success: false, description: 'No album specified' });
|
|
|
|
}
|
|
|
|
|
|
|
|
await db.table('albums').where({ id: id, userid: user.id }).update({ enabled: 0 });
|
|
|
|
return res.json({ success: true });
|
|
|
|
};
|
|
|
|
|
|
|
|
albumsController.rename = async (req, res, next) => {
|
|
|
|
const user = await utils.authorize(req, res);
|
|
|
|
|
|
|
|
const id = req.body.id;
|
|
|
|
if (id === undefined || id === '') {
|
|
|
|
return res.json({ success: false, description: 'No album specified' });
|
|
|
|
}
|
|
|
|
|
|
|
|
const name = req.body.name;
|
|
|
|
if (name === undefined || name === '') {
|
|
|
|
return res.json({ success: false, description: 'No name specified' });
|
|
|
|
}
|
|
|
|
|
|
|
|
const album = await db.table('albums').where({ name: name, userid: user.id }).first();
|
|
|
|
if (album) {
|
|
|
|
return res.json({ success: false, description: 'Name already in use' })
|
|
|
|
}
|
|
|
|
|
|
|
|
await db.table('albums').where({ id: id, userid: user.id }).update({ name: name })
|
|
|
|
return res.json({ success: true });
|
|
|
|
};
|
|
|
|
|
|
|
|
albumsController.get = async (req, res, next) => {
|
|
|
|
const identifier = req.params.identifier;
|
|
|
|
if (identifier === undefined) return res.status(401).json({ success: false, description: 'No identifier provided' });
|
|
|
|
|
|
|
|
const album = await db.table('albums').where('identifier', identifier).first();
|
|
|
|
if (!album) return res.json({ success: false, description: 'Album not found' });
|
|
|
|
|
|
|
|
const title = album.name;
|
|
|
|
const files = await db.table('files').select('name').where('albumid', album.id).orderBy('id', 'DESC');
|
|
|
|
|
|
|
|
for (let file of files) {
|
|
|
|
file.file = `${config.domain}/${file.name}`;
|
|
|
|
|
|
|
|
const ext = path.extname(file.name).toLowerCase();
|
|
|
|
if (utils.imageExtensions.includes(ext) || utils.videoExtensions.includes(ext)) {
|
|
|
|
file.thumb = `${config.domain}/thumbs/${file.name.slice(0, -ext.length)}.png`;
|
2017-02-07 08:52:53 +01:00
|
|
|
}
|
2017-10-04 02:13:38 +02:00
|
|
|
}
|
2017-03-17 05:14:24 +01:00
|
|
|
|
2017-10-04 02:13:38 +02:00
|
|
|
return res.json({
|
|
|
|
success: true,
|
|
|
|
title: title,
|
|
|
|
count: files.length,
|
|
|
|
files
|
|
|
|
});
|
|
|
|
};
|
2017-01-30 02:17:49 +01:00
|
|
|
|
2017-10-04 02:13:38 +02:00
|
|
|
module.exports = albumsController;
|