mirror of
https://github.com/xuthus83/pigallery2.git
synced 2024-11-03 21:04:03 +08:00
452 lines
20 KiB
TypeScript
452 lines
20 KiB
TypeScript
import {NextFunction, Request, Response} from 'express';
|
|
import {ErrorCodes, ErrorDTO} from '../../common/entities/Error';
|
|
import {ObjectManagerRepository} from '../model/ObjectManagerRepository';
|
|
import {Logger} from '../Logger';
|
|
import {SQLConnection} from '../model/sql/SQLConnection';
|
|
import {DataBaseConfig, DatabaseType, IndexingConfig, ThumbnailConfig} from '../../common/config/private/IPrivateConfig';
|
|
import {Config} from '../../common/config/private/Config';
|
|
import {ConfigDiagnostics} from '../model/diagnostics/ConfigDiagnostics';
|
|
import {ClientConfig} from '../../common/config/public/ConfigClass';
|
|
import {BasicConfigDTO} from '../../common/entities/settings/BasicConfigDTO';
|
|
import {OtherConfigDTO} from '../../common/entities/settings/OtherConfigDTO';
|
|
import {ProjectPath} from '../ProjectPath';
|
|
import {PrivateConfigClass} from '../../common/config/private/PrivateConfigClass';
|
|
import {IndexingDTO} from '../../common/entities/settings/IndexingDTO';
|
|
import {ISQLGalleryManager} from '../model/sql/IGalleryManager';
|
|
|
|
const LOG_TAG = '[AdminMWs]';
|
|
|
|
export class AdminMWs {
|
|
|
|
|
|
public static async loadStatistic(req: Request, res: Response, next: NextFunction) {
|
|
if (Config.Server.database.type === DatabaseType.memory) {
|
|
return next(new ErrorDTO(ErrorCodes.GENERAL_ERROR, 'Statistic is only available for indexed content'));
|
|
}
|
|
|
|
|
|
const galleryManager = <ISQLGalleryManager>ObjectManagerRepository.getInstance().GalleryManager;
|
|
try {
|
|
req.resultPipe = {
|
|
directories: await galleryManager.countDirectories(),
|
|
photos: await galleryManager.countPhotos(),
|
|
videos: await galleryManager.countVideos(),
|
|
diskUsage: await galleryManager.countMediaSize(),
|
|
};
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.GENERAL_ERROR, 'Error while getting statistic: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.GENERAL_ERROR, 'Error while getting statistic', err));
|
|
}
|
|
}
|
|
|
|
public static async updateDatabaseSettings(req: Request, res: Response, next: NextFunction) {
|
|
|
|
if ((typeof req.body === 'undefined') || (typeof req.body.settings === 'undefined')) {
|
|
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'settings is needed'));
|
|
}
|
|
|
|
const databaseSettings = <DataBaseConfig>req.body.settings;
|
|
|
|
try {
|
|
if (databaseSettings.type !== DatabaseType.memory) {
|
|
await SQLConnection.tryConnection(databaseSettings);
|
|
}
|
|
Config.Server.database = databaseSettings;
|
|
// only updating explicitly set config (not saving config set by the diagnostics)
|
|
const original = Config.original();
|
|
original.Server.database = databaseSettings;
|
|
if (databaseSettings.type === DatabaseType.memory) {
|
|
original.Client.Sharing.enabled = false;
|
|
original.Client.Search.enabled = false;
|
|
}
|
|
original.save();
|
|
await ConfigDiagnostics.runDiagnostics();
|
|
Logger.info(LOG_TAG, 'new config:');
|
|
Logger.info(LOG_TAG, JSON.stringify(Config, null, '\t'));
|
|
|
|
await ObjectManagerRepository.reset();
|
|
if (Config.Server.database.type !== DatabaseType.memory) {
|
|
await ObjectManagerRepository.InitSQLManagers();
|
|
} else {
|
|
await ObjectManagerRepository.InitMemoryManagers();
|
|
}
|
|
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Error while saving database settings: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Error while saving database settings', err));
|
|
}
|
|
}
|
|
|
|
public static async updateMapSettings(req: Request, res: Response, next: NextFunction) {
|
|
if ((typeof req.body === 'undefined') || (typeof req.body.settings === 'undefined')) {
|
|
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'settings is needed'));
|
|
}
|
|
|
|
try {
|
|
await ConfigDiagnostics.testMapConfig(<ClientConfig.MapConfig>req.body.settings);
|
|
|
|
Config.Client.Map = <ClientConfig.MapConfig>req.body.settings;
|
|
// only updating explicitly set config (not saving config set by the diagnostics)
|
|
const original = Config.original();
|
|
original.Client.Map = <ClientConfig.MapConfig>req.body.settings;
|
|
original.save();
|
|
await ConfigDiagnostics.runDiagnostics();
|
|
Logger.info(LOG_TAG, 'new config:');
|
|
Logger.info(LOG_TAG, JSON.stringify(Config, null, '\t'));
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
public static async updateVideoSettings(req: Request, res: Response, next: NextFunction) {
|
|
if ((typeof req.body === 'undefined') || (typeof req.body.settings === 'undefined')) {
|
|
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'settings is needed'));
|
|
}
|
|
|
|
try {
|
|
await ConfigDiagnostics.testVideoConfig(<ClientConfig.VideoConfig>req.body.settings);
|
|
|
|
Config.Client.Video = <ClientConfig.VideoConfig>req.body.settings;
|
|
// only updating explicitly set config (not saving config set by the diagnostics)
|
|
const original = Config.original();
|
|
original.Client.Video = <ClientConfig.VideoConfig>req.body.settings;
|
|
original.save();
|
|
await ConfigDiagnostics.runDiagnostics();
|
|
Logger.info(LOG_TAG, 'new config:');
|
|
Logger.info(LOG_TAG, JSON.stringify(Config, null, '\t'));
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
public static async updateMetaFileSettings(req: Request, res: Response, next: NextFunction) {
|
|
if ((typeof req.body === 'undefined') || (typeof req.body.settings === 'undefined')) {
|
|
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'settings is needed'));
|
|
}
|
|
|
|
try {
|
|
const original = Config.original();
|
|
await ConfigDiagnostics.testMetaFileConfig(<ClientConfig.MetaFileConfig>req.body.settings, original);
|
|
|
|
Config.Client.MetaFile = <ClientConfig.MetaFileConfig>req.body.settings;
|
|
// only updating explicitly set config (not saving config set by the diagnostics)
|
|
|
|
original.Client.MetaFile = <ClientConfig.MetaFileConfig>req.body.settings;
|
|
original.save();
|
|
await ConfigDiagnostics.runDiagnostics();
|
|
Logger.info(LOG_TAG, 'new config:');
|
|
Logger.info(LOG_TAG, JSON.stringify(Config, null, '\t'));
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
public static async updateShareSettings(req: Request, res: Response, next: NextFunction) {
|
|
if ((typeof req.body === 'undefined') || (typeof req.body.settings === 'undefined')) {
|
|
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'settings is needed'));
|
|
}
|
|
|
|
try {
|
|
// only updating explicitly set config (not saving config set by the diagnostics)
|
|
const original = Config.original();
|
|
await ConfigDiagnostics.testSharingConfig(<ClientConfig.SharingConfig>req.body.settings, original);
|
|
|
|
Config.Client.Sharing = <ClientConfig.SharingConfig>req.body.settings;
|
|
original.Client.Sharing = <ClientConfig.SharingConfig>req.body.settings;
|
|
original.save();
|
|
await ConfigDiagnostics.runDiagnostics();
|
|
Logger.info(LOG_TAG, 'new config:');
|
|
Logger.info(LOG_TAG, JSON.stringify(Config, null, '\t'));
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
|
|
public static async updateRandomPhotoSettings(req: Request, res: Response, next: NextFunction) {
|
|
if ((typeof req.body === 'undefined') || (typeof req.body.settings === 'undefined')) {
|
|
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'settings is needed'));
|
|
}
|
|
|
|
try {
|
|
// only updating explicitly set config (not saving config set by the diagnostics)
|
|
const original = Config.original();
|
|
await ConfigDiagnostics.testRandomPhotoConfig(<ClientConfig.RandomPhotoConfig>req.body.settings, original);
|
|
|
|
Config.Client.RandomPhoto = <ClientConfig.RandomPhotoConfig>req.body.settings;
|
|
original.Client.RandomPhoto = <ClientConfig.RandomPhotoConfig>req.body.settings;
|
|
original.save();
|
|
await ConfigDiagnostics.runDiagnostics();
|
|
Logger.info(LOG_TAG, 'new config:');
|
|
Logger.info(LOG_TAG, JSON.stringify(Config, null, '\t'));
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
public static async updateSearchSettings(req: Request, res: Response, next: NextFunction) {
|
|
if ((typeof req.body === 'undefined') || (typeof req.body.settings === 'undefined')) {
|
|
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'settings is needed'));
|
|
}
|
|
|
|
try {
|
|
// only updating explicitly set config (not saving config set by the diagnostics)
|
|
const original = Config.original();
|
|
await ConfigDiagnostics.testSearchConfig(<ClientConfig.SearchConfig>req.body.settings, original);
|
|
|
|
Config.Client.Search = <ClientConfig.SearchConfig>req.body.settings;
|
|
original.Client.Search = <ClientConfig.SearchConfig>req.body.settings;
|
|
original.save();
|
|
await ConfigDiagnostics.runDiagnostics();
|
|
Logger.info(LOG_TAG, 'new config:');
|
|
Logger.info(LOG_TAG, JSON.stringify(Config, null, '\t'));
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
|
|
public static async updateAuthenticationSettings(req: Request, res: Response, next: NextFunction) {
|
|
if ((typeof req.body === 'undefined') || (typeof req.body.settings === 'undefined')) {
|
|
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'settings is needed'));
|
|
}
|
|
|
|
try {
|
|
Config.Client.authenticationRequired = <boolean>req.body.settings;
|
|
// only updating explicitly set config (not saving config set by the diagnostics)
|
|
const original = Config.original();
|
|
original.Client.authenticationRequired = <boolean>req.body.settings;
|
|
if (original.Client.authenticationRequired === false) {
|
|
original.Client.Sharing.enabled = false;
|
|
}
|
|
original.save();
|
|
await ConfigDiagnostics.runDiagnostics();
|
|
Logger.info(LOG_TAG, 'new config:');
|
|
Logger.info(LOG_TAG, JSON.stringify(Config, null, '\t'));
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
public static async updateThumbnailSettings(req: Request, res: Response, next: NextFunction) {
|
|
if ((typeof req.body === 'undefined') || (typeof req.body.settings === 'undefined')) {
|
|
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'settings is needed'));
|
|
}
|
|
|
|
try {
|
|
const settings: {
|
|
server: ThumbnailConfig,
|
|
client: ClientConfig.ThumbnailConfig
|
|
} = req.body.settings;
|
|
|
|
await ConfigDiagnostics.testServerThumbnailConfig(settings.server);
|
|
await ConfigDiagnostics.testClientThumbnailConfig(settings.client);
|
|
Config.Server.thumbnail = settings.server;
|
|
Config.Client.Thumbnail = settings.client;
|
|
// only updating explicitly set config (not saving config set by the diagnostics)
|
|
const original = Config.original();
|
|
original.Server.thumbnail = settings.server;
|
|
original.Client.Thumbnail = settings.client;
|
|
original.save();
|
|
ProjectPath.reset();
|
|
await ConfigDiagnostics.runDiagnostics();
|
|
Logger.info(LOG_TAG, 'new config:');
|
|
Logger.info(LOG_TAG, JSON.stringify(Config, null, '\t'));
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
|
|
public static async updateBasicSettings(req: Request, res: Response, next: NextFunction) {
|
|
if ((typeof req.body === 'undefined') || (typeof req.body.settings === 'undefined')) {
|
|
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'settings is needed'));
|
|
}
|
|
|
|
try {
|
|
const settings: BasicConfigDTO = req.body.settings;
|
|
await ConfigDiagnostics.testImageFolder(settings.imagesFolder);
|
|
Config.Server.port = settings.port;
|
|
Config.Server.host = settings.host;
|
|
Config.Server.imagesFolder = settings.imagesFolder;
|
|
Config.Client.publicUrl = settings.publicUrl;
|
|
Config.Client.urlBase = settings.urlBase;
|
|
Config.Client.applicationTitle = settings.applicationTitle;
|
|
// only updating explicitly set config (not saving config set by the diagnostics)
|
|
const original = Config.original();
|
|
original.Server.port = settings.port;
|
|
original.Server.host = settings.host;
|
|
original.Server.imagesFolder = settings.imagesFolder;
|
|
original.Client.publicUrl = settings.publicUrl;
|
|
original.Client.urlBase = settings.urlBase;
|
|
original.Client.applicationTitle = settings.applicationTitle;
|
|
original.save();
|
|
ProjectPath.reset();
|
|
await ConfigDiagnostics.runDiagnostics();
|
|
Logger.info(LOG_TAG, 'new config:');
|
|
Logger.info(LOG_TAG, JSON.stringify(Config, null, '\t'));
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
|
|
public static async updateOtherSettings(req: Request, res: Response, next: NextFunction) {
|
|
if ((typeof req.body === 'undefined') || (typeof req.body.settings === 'undefined')) {
|
|
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'settings is needed'));
|
|
}
|
|
|
|
try {
|
|
const settings: OtherConfigDTO = req.body.settings;
|
|
Config.Client.Other.enableCache = settings.Client.enableCache;
|
|
Config.Client.Other.captionFirstNaming = settings.Client.captionFirstNaming;
|
|
Config.Client.Other.enableOnScrollRendering = settings.Client.enableOnScrollRendering;
|
|
Config.Client.Other.enableOnScrollThumbnailPrioritising = settings.Client.enableOnScrollThumbnailPrioritising;
|
|
Config.Client.Other.defaultPhotoSortingMethod = settings.Client.defaultPhotoSortingMethod;
|
|
Config.Client.Other.NavBar.showItemCount = settings.Client.NavBar.showItemCount;
|
|
|
|
// only updating explicitly set config (not saving config set by the diagnostics)
|
|
const original: PrivateConfigClass = Config.original();
|
|
original.Client.Other.enableCache = settings.Client.enableCache;
|
|
original.Client.Other.captionFirstNaming = settings.Client.captionFirstNaming;
|
|
original.Client.Other.enableOnScrollRendering = settings.Client.enableOnScrollRendering;
|
|
original.Client.Other.enableOnScrollThumbnailPrioritising = settings.Client.enableOnScrollThumbnailPrioritising;
|
|
original.Client.Other.defaultPhotoSortingMethod = settings.Client.defaultPhotoSortingMethod;
|
|
original.Client.Other.NavBar.showItemCount = settings.Client.NavBar.showItemCount;
|
|
original.Server.threading.enable = settings.Server.enable;
|
|
original.Server.threading.thumbnailThreads = settings.Server.thumbnailThreads;
|
|
original.save();
|
|
await ConfigDiagnostics.runDiagnostics();
|
|
Logger.info(LOG_TAG, 'new config:');
|
|
Logger.info(LOG_TAG, JSON.stringify(Config, null, '\t'));
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
public static async updateIndexingSettings(req: Request, res: Response, next: NextFunction) {
|
|
if ((typeof req.body === 'undefined') || (typeof req.body.settings === 'undefined')) {
|
|
return next(new ErrorDTO(ErrorCodes.INPUT_ERROR, 'settings is needed'));
|
|
}
|
|
|
|
try {
|
|
const settings: IndexingConfig = req.body.settings;
|
|
Config.Server.indexing = settings;
|
|
|
|
// only updating explicitly set config (not saving config set by the diagnostics)
|
|
const original = Config.original();
|
|
original.Server.indexing = settings;
|
|
original.save();
|
|
await ConfigDiagnostics.runDiagnostics();
|
|
Logger.info(LOG_TAG, 'new config:');
|
|
Logger.info(LOG_TAG, JSON.stringify(Config, null, '\t'));
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
|
|
public static startIndexing(req: Request, res: Response, next: NextFunction) {
|
|
try {
|
|
const createThumbnails: boolean = (<IndexingDTO>req.body).createThumbnails || false;
|
|
ObjectManagerRepository.getInstance().IndexingTaskManager.startIndexing(createThumbnails);
|
|
req.resultPipe = 'ok';
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
|
|
public static getIndexingProgress(req: Request, res: Response, next: NextFunction) {
|
|
try {
|
|
req.resultPipe = ObjectManagerRepository.getInstance().IndexingTaskManager.getProgress();
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
public static cancelIndexing(req: Request, res: Response, next: NextFunction) {
|
|
try {
|
|
ObjectManagerRepository.getInstance().IndexingTaskManager.cancelIndexing();
|
|
req.resultPipe = 'ok';
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
|
|
public static async resetIndexes(req: Express.Request, res: Response, next: NextFunction) {
|
|
try {
|
|
await ObjectManagerRepository.getInstance().IndexingTaskManager.reset();
|
|
req.resultPipe = 'ok';
|
|
return next();
|
|
} catch (err) {
|
|
if (err instanceof Error) {
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + err.toString(), err));
|
|
}
|
|
return next(new ErrorDTO(ErrorCodes.SETTINGS_ERROR, 'Settings error: ' + JSON.stringify(err, null, ' '), err));
|
|
}
|
|
}
|
|
}
|