2018-03-30 15:30:30 -04:00
|
|
|
import {DirectoryDTO} from '../../common/entities/DirectoryDTO';
|
|
|
|
import {Logger} from '../Logger';
|
|
|
|
import {Config} from '../../common/config/private/Config';
|
|
|
|
import {DiskManagerTH} from './threading/ThreadPool';
|
|
|
|
import {DiskMangerWorker} from './threading/DiskMangerWorker';
|
2016-03-19 19:59:19 +01:00
|
|
|
|
2017-06-03 22:35:47 +02:00
|
|
|
|
2018-03-30 15:30:30 -04:00
|
|
|
const LOG_TAG = '[DiskManager]';
|
|
|
|
|
2017-01-22 20:30:23 +01:00
|
|
|
export class DiskManager {
|
2017-07-04 10:24:20 +02:00
|
|
|
static threadPool: DiskManagerTH = null;
|
2017-06-10 22:32:56 +02:00
|
|
|
|
2017-07-04 10:24:20 +02:00
|
|
|
public static init() {
|
2018-11-02 16:24:37 +01:00
|
|
|
if (Config.Server.threading.enable === true) {
|
2017-07-04 10:24:20 +02:00
|
|
|
DiskManager.threadPool = new DiskManagerTH(1);
|
|
|
|
}
|
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
|
2017-07-04 10:24:20 +02:00
|
|
|
public static async scanDirectory(relativeDirectoryName: string): Promise<DirectoryDTO> {
|
2018-03-30 15:30:30 -04:00
|
|
|
Logger.silly(LOG_TAG, 'scanning directory:', relativeDirectoryName);
|
2017-07-04 10:24:20 +02:00
|
|
|
|
|
|
|
|
|
|
|
let directory: DirectoryDTO = null;
|
|
|
|
|
2018-11-02 16:24:37 +01:00
|
|
|
if (Config.Server.threading.enable === true) {
|
2017-07-04 10:24:20 +02:00
|
|
|
directory = await DiskManager.threadPool.execute(relativeDirectoryName);
|
|
|
|
} else {
|
|
|
|
directory = await DiskMangerWorker.scanDirectory(relativeDirectoryName);
|
|
|
|
}
|
2018-05-12 12:19:51 -04:00
|
|
|
const addDirs = (dir: DirectoryDTO) => {
|
2018-11-04 19:28:32 +01:00
|
|
|
dir.media.forEach((ph) => {
|
2017-07-04 10:24:20 +02:00
|
|
|
ph.directory = dir;
|
|
|
|
});
|
|
|
|
dir.directories.forEach((d) => {
|
|
|
|
addDirs(d);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
addDirs(directory);
|
|
|
|
return directory;
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
2017-01-22 20:30:23 +01:00
|
|
|
|
2017-06-04 18:45:29 +02:00
|
|
|
}
|