1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2024-11-03 21:04:03 +08:00
pigallery2/src/backend/middlewares/GalleryMWs.ts

224 lines
7.3 KiB
TypeScript
Raw Normal View History

2018-03-31 03:30:30 +08:00
import * as path from 'path';
2020-01-03 05:11:59 +08:00
import {promises as fsp} from 'fs';
2018-03-31 03:30:30 +08:00
import {NextFunction, Request, Response} from 'express';
import {ErrorCodes, ErrorDTO} from '../../common/entities/Error';
import {DirectoryDTO} from '../../common/entities/DirectoryDTO';
import {ObjectManagers} from '../model/ObjectManagers';
2018-03-31 03:30:30 +08:00
import {ContentWrapper} from '../../common/entities/ConentWrapper';
import {PhotoDTO} from '../../common/entities/PhotoDTO';
import {ProjectPath} from '../ProjectPath';
import {Config} from '../../common/config/private/Config';
import {UserDTO} from '../../common/entities/UserDTO';
2018-11-18 03:15:48 +08:00
import {MediaDTO} from '../../common/entities/MediaDTO';
import {VideoDTO} from '../../common/entities/VideoDTO';
import {Utils} from '../../common/Utils';
2018-12-09 19:02:02 +08:00
import {QueryParams} from '../../common/QueryParams';
import {VideoProcessing} from '../model/fileprocessing/VideoProcessing';
2021-01-17 22:56:15 +08:00
import {SearchQueryDTO, SearchQueryTypes} from '../../common/entities/SearchQueryDTO';
2021-04-06 17:32:31 +08:00
import {LocationLookupException} from '../exceptions/LocationLookupException';
2018-03-31 03:30:30 +08:00
export class GalleryMWs {
2016-03-20 02:59:19 +08:00
2017-07-04 01:17:49 +08:00
public static async listDirectory(req: Request, res: Response, next: NextFunction) {
2018-05-10 01:56:02 +08:00
const directoryName = req.params.directory || '/';
const absoluteDirectoryName = path.join(ProjectPath.ImageFolder, directoryName);
2020-01-03 05:11:59 +08:00
try {
if ((await fsp.stat(absoluteDirectoryName)).isDirectory() === false) {
return next();
}
} catch (e) {
return next();
2016-03-20 02:59:19 +08:00
}
2017-07-04 01:17:49 +08:00
try {
const directory = await ObjectManagers.getInstance()
2018-12-09 19:02:02 +08:00
.GalleryManager.listDirectory(directoryName,
2021-01-04 18:11:55 +08:00
parseInt(<string>req.query[QueryParams.gallery.knownLastModified], 10),
parseInt(<string>req.query[QueryParams.gallery.knownLastScanned], 10));
if (directory == null) {
req.resultPipe = new ContentWrapper(null, null, true);
2017-07-20 02:47:09 +08:00
return next();
}
2017-07-04 01:17:49 +08:00
if (req.session.user.permissions &&
req.session.user.permissions.length > 0 &&
2018-05-10 01:56:02 +08:00
req.session.user.permissions[0] !== '/*') {
2017-07-20 02:47:09 +08:00
(<DirectoryDTO>directory).directories = (<DirectoryDTO>directory).directories.filter(d =>
2017-07-09 18:03:17 +08:00
UserDTO.isDirectoryAvailable(d, req.session.user.permissions));
2017-07-04 01:17:49 +08:00
}
req.resultPipe = new ContentWrapper(directory, null);
return next();
2017-07-04 01:17:49 +08:00
} catch (err) {
2018-03-31 03:30:30 +08:00
return next(new ErrorDTO(ErrorCodes.GENERAL_ERROR, 'Error during listing the directory', err));
2017-07-04 01:17:49 +08:00
}
}
2016-12-28 03:55:51 +08:00
2018-11-19 03:26:29 +08:00
public static cleanUpGalleryResults(req: Request, res: Response, next: NextFunction) {
2018-05-10 01:56:02 +08:00
if (!req.resultPipe) {
return next();
2018-05-10 01:56:02 +08:00
}
2017-03-18 07:11:53 +08:00
2018-05-10 01:56:02 +08:00
const cw: ContentWrapper = req.resultPipe;
if (cw.notModified === true) {
2017-07-20 02:47:09 +08:00
return next();
}
2017-03-18 07:11:53 +08:00
2018-11-18 03:15:48 +08:00
const cleanUpMedia = (media: MediaDTO[]) => {
media.forEach(m => {
if (MediaDTO.isPhoto(m)) {
delete (<VideoDTO>m).metadata.bitRate;
delete (<VideoDTO>m).metadata.duration;
} else if (MediaDTO.isVideo(m)) {
delete (<PhotoDTO>m).metadata.rating;
delete (<PhotoDTO>m).metadata.caption;
2018-11-18 03:15:48 +08:00
delete (<PhotoDTO>m).metadata.cameraData;
delete (<PhotoDTO>m).metadata.orientation;
delete (<PhotoDTO>m).metadata.orientation;
delete (<PhotoDTO>m).metadata.keywords;
delete (<PhotoDTO>m).metadata.positionData;
}
Utils.removeNullOrEmptyObj(m);
2018-11-18 03:15:48 +08:00
});
};
if (cw.directory) {
2021-04-02 03:48:38 +08:00
DirectoryDTO.packDirectory(cw.directory);
// TODO: remove when typeorm inheritance is fixed (and handles proper inheritance)
2018-11-18 03:15:48 +08:00
cleanUpMedia(cw.directory.media);
}
if (cw.searchResult) {
cleanUpMedia(cw.searchResult.media);
}
2016-05-10 03:43:52 +08:00
if (Config.Client.Media.Video.enabled === false) {
2018-11-19 03:26:29 +08:00
if (cw.directory) {
const removeVideos = (dir: DirectoryDTO) => {
dir.media = dir.media.filter(m => !MediaDTO.isVideo(m));
if (dir.directories) {
dir.directories.forEach(d => removeVideos(d));
}
2018-11-19 03:26:29 +08:00
};
removeVideos(cw.directory);
}
if (cw.searchResult) {
cw.searchResult.media = cw.searchResult.media.filter(m => !MediaDTO.isVideo(m));
}
}
return next();
}
2016-03-20 17:49:49 +08:00
2016-05-09 23:04:56 +08:00
2020-01-03 05:11:59 +08:00
public static async loadFile(req: Request, res: Response, next: NextFunction) {
2018-12-02 06:53:58 +08:00
if (!(req.params.mediaPath)) {
return next();
}
2018-12-02 06:53:58 +08:00
const fullMediaPath = path.join(ProjectPath.ImageFolder, req.params.mediaPath);
2016-03-20 02:59:19 +08:00
// check if file exist
2020-01-03 05:11:59 +08:00
try {
if ((await fsp.stat(fullMediaPath)).isDirectory()) {
return next();
}
} catch (e) {
return next(new ErrorDTO(ErrorCodes.GENERAL_ERROR, 'no such file:' + req.params.mediaPath, 'can\'t find file: ' + fullMediaPath));
}
2017-07-18 05:12:12 +08:00
2018-11-05 02:28:32 +08:00
req.resultPipe = fullMediaPath;
return next();
}
2016-05-10 03:43:52 +08:00
2020-01-03 05:11:59 +08:00
public static async loadBestFitVideo(req: Request, res: Response, next: NextFunction) {
if (!(req.resultPipe)) {
return next();
}
2019-12-15 17:52:56 +08:00
const fullMediaPath: string = req.resultPipe;
2019-12-27 04:03:10 +08:00
const convertedVideo = VideoProcessing.generateConvertedFilePath(fullMediaPath);
// check if transcoded video exist
2020-01-03 05:11:59 +08:00
try {
2020-01-08 05:48:54 +08:00
await fsp.access(convertedVideo);
req.resultPipe = convertedVideo;
2020-01-03 05:11:59 +08:00
} catch (e) {
}
2020-01-03 05:11:59 +08:00
return next();
}
2016-05-16 17:03:11 +08:00
2017-07-08 06:18:24 +08:00
public static async search(req: Request, res: Response, next: NextFunction) {
if (Config.Client.Search.enabled === false || !(req.params.searchQueryDTO)) {
return next();
}
2016-05-16 17:03:11 +08:00
const query: SearchQueryDTO = JSON.parse(<any>req.params.searchQueryDTO);
2021-01-17 22:56:15 +08:00
2017-07-08 06:18:24 +08:00
try {
2021-01-17 22:56:15 +08:00
const result = await ObjectManagers.getInstance().SearchManager.search(query);
2018-11-05 02:28:32 +08:00
result.directories.forEach(dir => dir.media = dir.media || []);
req.resultPipe = new ContentWrapper(null, result);
return next();
2017-07-08 06:18:24 +08:00
} catch (err) {
2021-04-06 17:32:31 +08:00
if (err instanceof LocationLookupException) {
return next(new ErrorDTO(ErrorCodes.LocationLookUp_ERROR, 'Cannot find location: ' + err.location, err));
}
2018-03-31 03:30:30 +08:00
return next(new ErrorDTO(ErrorCodes.GENERAL_ERROR, 'Error during searching', err));
2017-07-08 06:18:24 +08:00
}
}
2016-05-10 03:43:52 +08:00
2021-01-17 22:56:15 +08:00
public static async autocomplete(req: Request, res: Response, next: NextFunction) {
if (Config.Client.Search.AutoComplete.enabled === false) {
return next();
}
if (!(req.params.text)) {
return next();
}
2021-01-17 22:56:15 +08:00
let type: SearchQueryTypes = SearchQueryTypes.any_text;
if (req.query[QueryParams.gallery.search.type]) {
type = parseInt(<string>req.query[QueryParams.gallery.search.type], 10);
}
2017-07-08 06:18:24 +08:00
try {
2021-01-17 22:56:15 +08:00
req.resultPipe = await ObjectManagers.getInstance().SearchManager.autocomplete(req.params.text, type);
return next();
2017-07-08 06:18:24 +08:00
} catch (err) {
2018-03-31 03:30:30 +08:00
return next(new ErrorDTO(ErrorCodes.GENERAL_ERROR, 'Error during searching', err));
2017-07-08 06:18:24 +08:00
}
2021-01-17 22:56:15 +08:00
}
2021-01-17 22:56:15 +08:00
public static async getRandomImage(req: Request, res: Response, next: NextFunction) {
if (Config.Client.RandomPhoto.enabled === false || !(req.params.searchQueryDTO)) {
return next();
2016-03-20 02:59:19 +08:00
}
2017-07-08 06:18:24 +08:00
try {
const query: SearchQueryDTO = JSON.parse(<any>req.params.searchQueryDTO);
2021-01-17 22:56:15 +08:00
const photo = await ObjectManagers.getInstance()
.SearchManager.getRandomPhoto(query);
if (!photo) {
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'No photo found'));
}
req.params.mediaPath = path.join(photo.directory.path, photo.directory.name, photo.name);
return next();
2021-01-17 22:56:15 +08:00
} catch (e) {
return next(new ErrorDTO(ErrorCodes.GENERAL_ERROR, 'Can\'t get random photo: ' + e.toString()));
2017-07-08 06:18:24 +08:00
}
}
2016-03-20 02:59:19 +08:00
}