1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- const config = require('../config.js');
- const routes = require('express').Router();
- const db = require('knex')(config.database);
- const path = require('path');
- const utils = require('../controllers/utilsController.js');
- routes.get('/a/:identifier', async (req, res, next) => {
- let 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, enabled: 1 }).first();
- if (!album) return res.status(404).sendFile('404.html', { root: './pages/error/' });
- const files = await db.table('files').select('name').where('albumid', album.id).orderBy('id', 'DESC');
- let thumb = '';
- const basedomain = config.domain;
- for (let file of files) {
- file.file = `${basedomain}/${file.name}`;
- let ext = path.extname(file.name).toLowerCase();
- if (utils.imageExtensions.includes(ext) || utils.videoExtensions.includes(ext)) {
- file.thumb = `${basedomain}/thumbs/${file.name.slice(0, -ext.length)}.png`;
- /*
- If thumbnail for album is still not set, do it.
- A potential improvement would be to let the user upload a specific image as an album cover
- since embedding the first image could potentially result in nsfw content when pasting links.
- */
- if (thumb === '') {
- thumb = file.thumb;
- }
- file.thumb = `<img src="${file.thumb}"/>`;
- } else {
- file.thumb = `<h1 class="title">.${ext}</h1>`;
- }
- }
- let enableDownload = false;
- if (config.uploads.generateZips) enableDownload = true;
- return res.render('album_public', {
- layout: false,
- title: album.name,
- count: files.length,
- thumb,
- files,
- identifier,
- enableDownload
- });
- });
- module.exports = routes;
|