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