2016-05-25 21:58:56 +02:00
|
|
|
///<reference path="exif.d.ts"/>
|
2016-05-09 17:04:56 +02:00
|
|
|
import * as path from "path";
|
2016-12-27 20:55:51 +01:00
|
|
|
import {DirectoryDTO} from "../../common/entities/DirectoryDTO";
|
2016-06-25 14:13:06 +02:00
|
|
|
import {ProjectPath} from "../ProjectPath";
|
2017-06-03 22:35:47 +02:00
|
|
|
import {Logger} from "../Logger";
|
2017-06-10 22:32:56 +02:00
|
|
|
import {diskManagerTask, DiskManagerTask} from "./DiskMangerTask";
|
|
|
|
import {Config} from "../../common/config/private/Config";
|
2016-03-19 19:59:19 +01:00
|
|
|
|
2017-01-22 20:30:23 +01:00
|
|
|
const Pool = require('threads').Pool;
|
2017-06-21 11:33:46 +02:00
|
|
|
const pool = new Pool(1);
|
2017-06-03 22:35:47 +02:00
|
|
|
|
|
|
|
const LOG_TAG = "[DiskManager]";
|
|
|
|
|
2017-01-22 20:30:23 +01:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
pool.run(diskManagerTask);
|
2016-05-12 18:24:26 +02:00
|
|
|
|
2017-01-22 20:30:23 +01:00
|
|
|
export class DiskManager {
|
2017-07-03 19:17:49 +02:00
|
|
|
public static scanDirectory(relativeDirectoryName: string): Promise<DirectoryDTO> {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
Logger.silly(LOG_TAG, "scanning directory:", relativeDirectoryName);
|
|
|
|
let directoryName = path.basename(relativeDirectoryName);
|
|
|
|
let directoryParent = path.join(path.dirname(relativeDirectoryName), path.sep);
|
|
|
|
let absoluteDirectoryName = path.join(ProjectPath.ImageFolder, relativeDirectoryName);
|
2017-06-10 22:32:56 +02:00
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
let input = <DiskManagerTask.PoolInput>{
|
|
|
|
relativeDirectoryName,
|
|
|
|
directoryName,
|
|
|
|
directoryParent,
|
|
|
|
absoluteDirectoryName
|
|
|
|
};
|
2017-06-10 22:32:56 +02:00
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
let done = (error: any, result: DirectoryDTO) => {
|
|
|
|
if (error || !result) {
|
|
|
|
return reject(error);
|
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
let addDirs = (dir: DirectoryDTO) => {
|
|
|
|
dir.photos.forEach((ph) => {
|
|
|
|
ph.directory = dir;
|
|
|
|
});
|
|
|
|
dir.directories.forEach((d) => {
|
|
|
|
addDirs(d);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
addDirs(result);
|
|
|
|
return resolve(result);
|
2017-06-10 22:32:56 +02:00
|
|
|
};
|
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
let error = (error) => {
|
|
|
|
return reject(error);
|
|
|
|
};
|
2017-06-10 22:32:56 +02:00
|
|
|
|
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
if (Config.Server.enableThreading == true) {
|
|
|
|
pool.send(input).on('done', done).on('error', error);
|
|
|
|
} else {
|
|
|
|
try {
|
|
|
|
diskManagerTask(input, done);
|
|
|
|
} catch (err) {
|
|
|
|
error(err);
|
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
2017-07-03 19:17:49 +02:00
|
|
|
});
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
2017-01-22 20:30:23 +01:00
|
|
|
|
2017-06-04 18:45:29 +02:00
|
|
|
}
|