mirror of
https://github.com/bpatrik/pigallery2.git
synced 2025-01-22 05:10:01 +02:00
2ea0ea42e3
upgrading packages
227 lines
8.4 KiB
TypeScript
227 lines
8.4 KiB
TypeScript
import {Config} from '../../common/config/private/Config';
|
|
import {
|
|
DataBaseConfig,
|
|
DatabaseType,
|
|
IPrivateConfig,
|
|
ThumbnailConfig,
|
|
ThumbnailProcessingLib
|
|
} from '../../common/config/private/IPrivateConfig';
|
|
import {Logger} from '../Logger';
|
|
import {NotificationManager} from './NotifocationManager';
|
|
import {ProjectPath} from '../ProjectPath';
|
|
import {SQLConnection} from './sql/SQLConnection';
|
|
import * as fs from 'fs';
|
|
import {ClientConfig} from '../../common/config/public/ConfigClass';
|
|
|
|
const LOG_TAG = '[ConfigDiagnostics]';
|
|
|
|
export class ConfigDiagnostics {
|
|
|
|
static async testDatabase(databaseConfig: DataBaseConfig) {
|
|
if (databaseConfig.type !== DatabaseType.memory) {
|
|
await SQLConnection.tryConnection(databaseConfig);
|
|
}
|
|
}
|
|
|
|
|
|
static async testThumbnailLib(processingLibrary: ThumbnailProcessingLib) {
|
|
switch (processingLibrary) {
|
|
case ThumbnailProcessingLib.sharp:
|
|
const sharp = require('sharp');
|
|
sharp();
|
|
break;
|
|
case ThumbnailProcessingLib.gm:
|
|
const gm = require('gm');
|
|
await new Promise((resolve, reject) => {
|
|
gm(ProjectPath.FrontendFolder + '/assets/icon.png').size((err, value) => {
|
|
if (err) {
|
|
return reject(err.toString());
|
|
}
|
|
return resolve();
|
|
});
|
|
});
|
|
break;
|
|
}
|
|
}
|
|
|
|
static async testThumbnailFolder(folder: string) {
|
|
await new Promise((resolve, reject) => {
|
|
fs.access(folder, fs.constants.W_OK, (err) => {
|
|
if (err) {
|
|
reject({message: 'Error during getting write access to temp folder', error: err.toString()});
|
|
}
|
|
});
|
|
resolve();
|
|
});
|
|
}
|
|
|
|
static async testImageFolder(folder: string) {
|
|
await new Promise((resolve, reject) => {
|
|
if (!fs.existsSync(folder)) {
|
|
reject('Images folder not exists: \'' + folder + '\'');
|
|
}
|
|
fs.access(folder, fs.constants.R_OK, (err) => {
|
|
if (err) {
|
|
reject({message: 'Error during getting read access to images folder', error: err.toString()});
|
|
}
|
|
});
|
|
resolve();
|
|
});
|
|
}
|
|
|
|
|
|
static async testServerThumbnailConfig(thumbnailConfig: ThumbnailConfig) {
|
|
await ConfigDiagnostics.testThumbnailLib(thumbnailConfig.processingLibrary);
|
|
await ConfigDiagnostics.testThumbnailFolder(thumbnailConfig.folder);
|
|
}
|
|
|
|
static async testClientThumbnailConfig(thumbnailConfig: ClientConfig.ThumbnailConfig) {
|
|
if (isNaN(thumbnailConfig.iconSize) || thumbnailConfig.iconSize <= 0) {
|
|
throw new Error('IconSize has to be >= 0 integer, got: ' + thumbnailConfig.iconSize);
|
|
}
|
|
|
|
if (!thumbnailConfig.thumbnailSizes.length) {
|
|
throw new Error('At least one thumbnail size is needed');
|
|
}
|
|
for (let i = 0; i < thumbnailConfig.thumbnailSizes.length; i++) {
|
|
if (isNaN(thumbnailConfig.thumbnailSizes[i]) || thumbnailConfig.thumbnailSizes[i] <= 0) {
|
|
throw new Error('Thumbnail size has to be >= 0 integer, got: ' + thumbnailConfig.thumbnailSizes[i]);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
static async testSearchConfig(search: ClientConfig.SearchConfig, config: IPrivateConfig) {
|
|
if (search.enabled === true &&
|
|
config.Server.database.type === DatabaseType.memory) {
|
|
throw new Error('Memory Database do not support searching');
|
|
}
|
|
}
|
|
|
|
|
|
static async testSharingConfig(sharing: ClientConfig.SharingConfig, config: IPrivateConfig) {
|
|
if (sharing.enabled === true &&
|
|
config.Server.database.type === DatabaseType.memory) {
|
|
throw new Error('Memory Database do not support sharing');
|
|
}
|
|
if (sharing.enabled === true &&
|
|
config.Client.authenticationRequired === false) {
|
|
throw new Error('In case of no authentication, sharing is not supported');
|
|
}
|
|
}
|
|
|
|
static async testRandomPhotoConfig(sharing: ClientConfig.RandomPhotoConfig, config: IPrivateConfig) {
|
|
if (sharing.enabled === true &&
|
|
config.Server.database.type === DatabaseType.memory) {
|
|
throw new Error('Memory Database do not support sharing');
|
|
}
|
|
}
|
|
|
|
|
|
static async testMapConfig(map: ClientConfig.MapConfig) {
|
|
if (map.enabled === true && (!map.googleApiKey || map.googleApiKey.length === 0)) {
|
|
throw new Error('Maps need a valid google api key');
|
|
}
|
|
}
|
|
|
|
|
|
static async runDiagnostics() {
|
|
|
|
if (Config.Server.database.type !== DatabaseType.memory) {
|
|
try {
|
|
await ConfigDiagnostics.testDatabase(Config.Server.database);
|
|
} catch (ex) {
|
|
const err: Error = ex;
|
|
Logger.warn(LOG_TAG, '[SQL error]', err.toString());
|
|
Logger.warn(LOG_TAG, 'Error during initializing SQL falling back temporally to memory DB');
|
|
NotificationManager.warning('Error during initializing SQL falling back temporally to memory DB', err.toString());
|
|
Config.setDatabaseType(DatabaseType.memory);
|
|
}
|
|
}
|
|
|
|
if (Config.Server.thumbnail.processingLibrary !== ThumbnailProcessingLib.Jimp) {
|
|
try {
|
|
await ConfigDiagnostics.testThumbnailLib(Config.Server.thumbnail.processingLibrary);
|
|
} catch (ex) {
|
|
const err: Error = ex;
|
|
NotificationManager.warning('Thumbnail hardware acceleration is not possible.' +
|
|
' \'' + ThumbnailProcessingLib[Config.Server.thumbnail.processingLibrary] + '\' node module is not found.' +
|
|
' Falling back temporally to JS based thumbnail generation', err.toString());
|
|
Logger.warn(LOG_TAG, '[Thumbnail hardware acceleration] module error: ', err.toString());
|
|
Logger.warn(LOG_TAG, 'Thumbnail hardware acceleration is not possible.' +
|
|
' \'' + ThumbnailProcessingLib[Config.Server.thumbnail.processingLibrary] + '\' node module is not found.' +
|
|
' Falling back temporally to JS based thumbnail generation');
|
|
Config.Server.thumbnail.processingLibrary = ThumbnailProcessingLib.Jimp;
|
|
}
|
|
}
|
|
|
|
try {
|
|
await ConfigDiagnostics.testThumbnailFolder(Config.Server.thumbnail.folder);
|
|
} catch (ex) {
|
|
const err: Error = ex;
|
|
NotificationManager.error('Thumbnail folder error', err.toString());
|
|
Logger.error(LOG_TAG, 'Thumbnail folder error', err.toString());
|
|
}
|
|
|
|
|
|
try {
|
|
await ConfigDiagnostics.testImageFolder(Config.Server.imagesFolder);
|
|
} catch (ex) {
|
|
const err: Error = ex;
|
|
NotificationManager.error('Images folder error', err.toString());
|
|
Logger.error(LOG_TAG, 'Images folder error', err.toString());
|
|
}
|
|
try {
|
|
await ConfigDiagnostics.testClientThumbnailConfig(Config.Client.Thumbnail);
|
|
} catch (ex) {
|
|
const err: Error = ex;
|
|
NotificationManager.error('Thumbnail settings error', err.toString());
|
|
Logger.error(LOG_TAG, 'Thumbnail settings error', err.toString());
|
|
}
|
|
|
|
|
|
try {
|
|
await ConfigDiagnostics.testSearchConfig(Config.Client.Search, Config);
|
|
} catch (ex) {
|
|
const err: Error = ex;
|
|
NotificationManager.warning('Search is not supported with these settings. Disabling temporally. ' +
|
|
'Please adjust the config properly.', err.toString());
|
|
Logger.warn(LOG_TAG, 'Search is not supported with these settings, switching off..', err.toString());
|
|
Config.Client.Search.enabled = false;
|
|
}
|
|
|
|
try {
|
|
await ConfigDiagnostics.testSharingConfig(Config.Client.Sharing, Config);
|
|
} catch (ex) {
|
|
const err: Error = ex;
|
|
NotificationManager.warning('Sharing is not supported with these settings. Disabling temporally. ' +
|
|
'Please adjust the config properly.', err.toString());
|
|
Logger.warn(LOG_TAG, 'Sharing is not supported with these settings, switching off..', err.toString());
|
|
Config.Client.Sharing.enabled = false;
|
|
}
|
|
|
|
try {
|
|
await ConfigDiagnostics.testRandomPhotoConfig(Config.Client.Sharing, Config);
|
|
} catch (ex) {
|
|
const err: Error = ex;
|
|
NotificationManager.warning('Random Photo is not supported with these settings. Disabling temporally. ' +
|
|
'Please adjust the config properly.', err.toString());
|
|
Logger.warn(LOG_TAG, 'Random Photo is not supported with these settings, switching off..', err.toString());
|
|
Config.Client.Sharing.enabled = false;
|
|
}
|
|
|
|
|
|
try {
|
|
await ConfigDiagnostics.testMapConfig(Config.Client.Map);
|
|
} catch (ex) {
|
|
const err: Error = ex;
|
|
NotificationManager.warning('Maps is not supported with these settings. Disabling temporally. ' +
|
|
'Please adjust the config properly.', err.toString());
|
|
Logger.warn(LOG_TAG, 'Maps is not supported with these settings. Disabling temporally. ' +
|
|
'Please adjust the config properly.', err.toString());
|
|
Config.Client.Map.enabled = false;
|
|
}
|
|
|
|
}
|
|
}
|