2018-11-20 02:42:21 +02:00
|
|
|
const { filename, fileExtension } = require('lib/path-utils');
|
2019-05-12 02:15:52 +02:00
|
|
|
const { time } = require('lib/time-utils.js');
|
2020-03-10 01:24:57 +02:00
|
|
|
const Setting = require('lib/models/Setting');
|
|
|
|
const md5 = require('md5');
|
2018-11-20 02:42:21 +02:00
|
|
|
|
2018-02-25 23:08:32 +02:00
|
|
|
class FsDriverBase {
|
|
|
|
async isDirectory(path) {
|
|
|
|
const stat = await this.stat(path);
|
|
|
|
return !stat ? false : stat.isDirectory();
|
|
|
|
}
|
|
|
|
|
|
|
|
async readDirStatsHandleRecursion_(basePath, stat, output, options) {
|
|
|
|
if (options.recursive && stat.isDirectory()) {
|
2019-09-19 23:51:18 +02:00
|
|
|
const subPath = `${basePath}/${stat.path}`;
|
2018-02-25 23:08:32 +02:00
|
|
|
const subStats = await this.readDirStats(subPath, options);
|
|
|
|
for (let j = 0; j < subStats.length; j++) {
|
|
|
|
const subStat = subStats[j];
|
2019-09-19 23:51:18 +02:00
|
|
|
subStat.path = `${stat.path}/${subStat.path}`;
|
2018-02-25 23:08:32 +02:00
|
|
|
output.push(subStat);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return output;
|
|
|
|
}
|
|
|
|
|
2020-01-18 15:16:14 +02:00
|
|
|
async findUniqueFilename(name, reservedNames = null) {
|
|
|
|
if (reservedNames === null) {
|
|
|
|
reservedNames = [];
|
|
|
|
}
|
2018-11-20 02:42:21 +02:00
|
|
|
let counter = 1;
|
|
|
|
|
|
|
|
let nameNoExt = filename(name, true);
|
|
|
|
let extension = fileExtension(name);
|
2019-09-19 23:51:18 +02:00
|
|
|
if (extension) extension = `.${extension}`;
|
2018-11-20 02:42:21 +02:00
|
|
|
let nameToTry = nameNoExt + extension;
|
|
|
|
while (true) {
|
2020-01-18 15:16:14 +02:00
|
|
|
// Check if the filename does not exist in the filesystem and is not reserved
|
|
|
|
const exists = await this.exists(nameToTry) || reservedNames.includes(nameToTry);
|
2018-11-20 02:42:21 +02:00
|
|
|
if (!exists) return nameToTry;
|
2019-09-19 23:51:18 +02:00
|
|
|
nameToTry = `${nameNoExt} (${counter})${extension}`;
|
2018-11-20 02:42:21 +02:00
|
|
|
counter++;
|
2020-02-11 16:14:04 +02:00
|
|
|
if (counter >= 1000) {
|
|
|
|
nameToTry = `${nameNoExt} (${new Date().getTime()})${extension}`;
|
|
|
|
await time.msleep(10);
|
|
|
|
}
|
|
|
|
if (counter >= 1100) throw new Error('Cannot find unique filename');
|
2018-11-20 02:42:21 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-11 12:46:13 +02:00
|
|
|
async removeAllThatStartWith(dirPath, filenameStart) {
|
|
|
|
if (!filenameStart || !dirPath) throw new Error('dirPath and filenameStart cannot be empty');
|
|
|
|
|
|
|
|
const stats = await this.readDirStats(dirPath);
|
|
|
|
|
|
|
|
for (const stat of stats) {
|
|
|
|
if (stat.path.indexOf(filenameStart) === 0) {
|
2019-09-19 23:51:18 +02:00
|
|
|
await this.remove(`${dirPath}/${stat.path}`);
|
2019-05-11 12:46:13 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-12 02:15:52 +02:00
|
|
|
async waitTillExists(path, timeout = 10000) {
|
|
|
|
const startTime = Date.now();
|
|
|
|
|
|
|
|
while (true) {
|
|
|
|
const e = await this.exists(path);
|
|
|
|
if (e) return true;
|
|
|
|
if (Date.now() - startTime > timeout) return false;
|
|
|
|
await time.msleep(100);
|
|
|
|
}
|
|
|
|
}
|
2020-03-10 01:24:57 +02:00
|
|
|
|
|
|
|
// TODO: move out of here and make it part of joplin-renderer
|
|
|
|
// or assign to option using .bind(fsDriver())
|
|
|
|
async cacheCssToFile(cssStrings) {
|
|
|
|
const cssString = cssStrings.join('\n');
|
|
|
|
const cssFilePath = `${Setting.value('tempDir')}/${md5(escape(cssString))}.css`;
|
|
|
|
if (!(await this.exists(cssFilePath))) {
|
|
|
|
await this.writeFile(cssFilePath, cssString, 'utf8');
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
|
|
|
path: cssFilePath,
|
|
|
|
mime: 'text/css',
|
|
|
|
};
|
|
|
|
}
|
2018-02-25 23:08:32 +02:00
|
|
|
}
|
|
|
|
|
2019-07-29 15:43:53 +02:00
|
|
|
module.exports = FsDriverBase;
|