2020-03-21 15:46:10 +05:45
|
|
|
const fs = require('fs');
|
|
|
|
const os = require('os');
|
|
|
|
const path = require('path');
|
|
|
|
const { promisify } = require('util');
|
|
|
|
const mkdirp = require('mkdirp');
|
|
|
|
|
2020-03-24 20:35:47 +05:45
|
|
|
// Promisify common fs functions.
|
2020-03-21 15:46:10 +05:45
|
|
|
const stat = promisify(fs.stat);
|
2020-03-24 20:35:47 +05:45
|
|
|
const readFile = promisify(fs.readFile);
|
|
|
|
const writeFile = promisify(fs.writeFile);
|
|
|
|
const readdir = promisify(fs.readdir);
|
2020-03-21 15:46:10 +05:45
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a temporary directory and returns it path.
|
|
|
|
*
|
|
|
|
* @returns {Promise<string>}
|
|
|
|
*/
|
|
|
|
function createTemp() {
|
|
|
|
return promisify(fs.mkdtemp)(`${os.tmpdir()}${path.sep}`);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Ensures the given path exists.
|
|
|
|
* - If the path already exist, it's fine - it does nothing.
|
|
|
|
* - If the path doesn't exist, it will create it.
|
|
|
|
*
|
|
|
|
* @param {string} path
|
|
|
|
* @returns {Promise}
|
|
|
|
*/
|
|
|
|
function ensureDirectoryExists(dir) {
|
|
|
|
return stat(dir).catch(() => mkdirp(dir));
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
stat,
|
2020-03-24 20:35:47 +05:45
|
|
|
readdir,
|
|
|
|
readFile,
|
|
|
|
writeFile,
|
2020-03-21 15:46:10 +05:45
|
|
|
createTemp,
|
|
|
|
ensureDirectoryExists,
|
|
|
|
};
|