2018-07-22 22:34:35 +00:00
|
|
|
/**
|
|
|
|
* Provide utility functions
|
|
|
|
*
|
|
|
|
* @author Mohammad Fares <faressoft.com@gmail.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2018-08-24 23:23:32 +00:00
|
|
|
* Check if a path represents a valid path for a file
|
2018-07-22 22:34:35 +00:00
|
|
|
*
|
2018-08-24 23:23:32 +00:00
|
|
|
* @param {String} filePath an absolute or a relative path
|
|
|
|
* @return {Boolean}
|
|
|
|
*/
|
|
|
|
function isFile(filePath) {
|
|
|
|
|
|
|
|
// Resolve the path into an absolute path
|
|
|
|
filePath = di.path.resolve(filePath);
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
2018-09-01 14:01:04 +00:00
|
|
|
return di.fs.statSync(filePath).isFile();
|
2018-08-24 23:23:32 +00:00
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-10-14 18:35:21 +00:00
|
|
|
/**
|
|
|
|
* Check if a path represents a valid path for a directory
|
|
|
|
*
|
|
|
|
* @param {String} dirPath an absolute or a relative path
|
|
|
|
* @return {Boolean}
|
|
|
|
*/
|
|
|
|
function isDir(dirPath) {
|
|
|
|
|
|
|
|
// Resolve the path into an absolute path
|
|
|
|
dirPath = di.path.resolve(dirPath);
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
return di.fs.statSync(dirPath).isDirectory();
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-08-24 23:23:32 +00:00
|
|
|
/**
|
|
|
|
* Load a file's content
|
|
|
|
*
|
|
|
|
* - Check if the file exists, if not found check
|
|
|
|
* if the file exists with appending the extension
|
|
|
|
*
|
2018-07-22 22:34:35 +00:00
|
|
|
* Throws
|
|
|
|
* - The provided file doesn't exit
|
2018-08-24 23:23:32 +00:00
|
|
|
* - Any reading errors
|
2018-07-22 22:34:35 +00:00
|
|
|
*
|
2018-08-24 23:23:32 +00:00
|
|
|
* @param {String} filePath an absolute or a relative path
|
|
|
|
* @param {String} extension
|
|
|
|
* @return {String}
|
2018-07-22 22:34:35 +00:00
|
|
|
*/
|
2018-08-24 23:23:32 +00:00
|
|
|
function loadFile(filePath, extension) {
|
2018-07-22 22:34:35 +00:00
|
|
|
|
2018-08-24 23:23:32 +00:00
|
|
|
var content = null;
|
2018-07-22 22:34:35 +00:00
|
|
|
|
2018-08-04 23:46:01 +00:00
|
|
|
// Resolve the path into an absolute path
|
2018-10-14 18:38:38 +00:00
|
|
|
filePath = resolveFilePath(filePath, extension);
|
2018-07-22 22:34:35 +00:00
|
|
|
|
|
|
|
// The file doesn't exist
|
2018-08-24 23:23:32 +00:00
|
|
|
if (!isFile(filePath)) {
|
2018-10-14 18:38:38 +00:00
|
|
|
throw new Error('The provided file doesn\'t exit');
|
2018-07-22 22:34:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Read the file
|
|
|
|
try {
|
2018-08-24 23:23:32 +00:00
|
|
|
content = di.fs.readFileSync(filePath);
|
2018-07-22 22:34:35 +00:00
|
|
|
} catch (error) {
|
|
|
|
throw new Error(error);
|
|
|
|
}
|
|
|
|
|
2018-08-24 23:23:32 +00:00
|
|
|
return content;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check, load, and parse YAML files
|
|
|
|
*
|
|
|
|
* - Add .yml extension when needed
|
|
|
|
*
|
|
|
|
* Throws
|
|
|
|
* - The provided file doesn't exit
|
|
|
|
* - The provided file is not a valid YAML file
|
|
|
|
* - Any reading errors
|
|
|
|
*
|
|
|
|
* @param {String} filePath an absolute or a relative path
|
|
|
|
* @return {Object}
|
|
|
|
*/
|
|
|
|
function loadYAML(filePath) {
|
|
|
|
|
|
|
|
var file = loadFile(filePath, 'yml');
|
|
|
|
|
2018-07-22 22:34:35 +00:00
|
|
|
// Parse the file
|
|
|
|
try {
|
|
|
|
|
|
|
|
return {
|
|
|
|
json: di.yaml.load(file),
|
|
|
|
raw: file.toString()
|
|
|
|
};
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
|
|
|
throw new Error('The provided file is not a valid YAML file');
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check, load, and parse JSON files
|
|
|
|
*
|
|
|
|
* - Add .json extension when needed
|
|
|
|
*
|
|
|
|
* Throws
|
|
|
|
* - The provided file doesn't exit
|
|
|
|
* - The provided file is not a valid JSON file
|
2018-08-24 23:23:32 +00:00
|
|
|
* - Any reading errors
|
2018-07-22 22:34:35 +00:00
|
|
|
*
|
|
|
|
* @param {String} filePath an absolute or a relative path
|
|
|
|
* @return {Object}
|
|
|
|
*/
|
|
|
|
function loadJSON(filePath) {
|
|
|
|
|
2018-08-24 23:23:32 +00:00
|
|
|
var file = loadFile(filePath, 'json');
|
2018-07-22 22:34:35 +00:00
|
|
|
|
|
|
|
// Read the file
|
|
|
|
try {
|
|
|
|
file = di.fs.readFileSync(filePath);
|
|
|
|
} catch (error) {
|
|
|
|
throw new Error(error);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Parse the file
|
|
|
|
try {
|
|
|
|
return JSON.parse(file);
|
|
|
|
} catch (error) {
|
|
|
|
throw new Error('The provided file is not a valid JSON file');
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2018-10-14 18:39:11 +00:00
|
|
|
* Resolve to an absolute path
|
|
|
|
*
|
|
|
|
* Accepts
|
|
|
|
* - FileName
|
|
|
|
* - FileName.ext
|
|
|
|
* - /path/to/FileName
|
|
|
|
* - /path/to/FileName.ext
|
2018-07-22 22:34:35 +00:00
|
|
|
*
|
|
|
|
* - Add the extension if not already added
|
2018-10-14 18:39:11 +00:00
|
|
|
* - Resolve to `/path/to/FileName.ext`
|
2018-07-22 22:34:35 +00:00
|
|
|
*
|
|
|
|
* @param {String} filePath an absolute or a relative path
|
|
|
|
* @param {String} extension
|
|
|
|
* @return {String}
|
|
|
|
*/
|
|
|
|
function resolveFilePath(filePath, extension) {
|
|
|
|
|
|
|
|
var resolvedPath = di.path.resolve(filePath);
|
|
|
|
|
|
|
|
// The extension is not added
|
|
|
|
if (di.path.extname(resolvedPath) != '.' + extension) {
|
|
|
|
resolvedPath += '.' + extension;
|
|
|
|
}
|
|
|
|
|
|
|
|
return resolvedPath;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the default configurations
|
2018-10-01 09:29:09 +00:00
|
|
|
*
|
|
|
|
* - Check if there is a global config file
|
|
|
|
* - Found: Get the global config file
|
|
|
|
* - Not Found: Get the default config file
|
2018-07-22 22:34:35 +00:00
|
|
|
*
|
|
|
|
* @return {Object} {json, raw}
|
|
|
|
*/
|
|
|
|
function getDefaultConfig() {
|
|
|
|
|
2018-10-01 09:29:09 +00:00
|
|
|
var defaultConfigPath = di.path.join(ROOT_PATH, 'config.yml');
|
|
|
|
var globalConfigPath = di.path.join(getGlobalDirectory(), 'config.yml');
|
|
|
|
|
|
|
|
// The global config file exists
|
|
|
|
if (isFile(globalConfigPath)) {
|
|
|
|
return loadYAML(globalConfigPath);
|
|
|
|
}
|
|
|
|
|
|
|
|
console.log('defaultConfigPath');
|
2018-07-22 22:34:35 +00:00
|
|
|
|
2018-10-01 09:29:09 +00:00
|
|
|
// Load global config file
|
|
|
|
return loadYAML(defaultConfigPath);
|
2018-07-22 22:34:35 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Change a value for a specific key in YAML
|
|
|
|
*
|
|
|
|
* - Works only with the first level keys
|
2018-08-04 23:46:01 +00:00
|
|
|
* - Works only with keys with a single value
|
2018-07-22 22:34:35 +00:00
|
|
|
* - Apply the changes on the json and raw
|
|
|
|
*
|
|
|
|
* @param {Object} data {json, raw}
|
|
|
|
* @param {String} key
|
|
|
|
* @param {*} value
|
|
|
|
*/
|
|
|
|
function changeYAMLValue(data, key, value) {
|
|
|
|
|
|
|
|
data.json[key] = value;
|
|
|
|
data.raw = data.raw.replace(new RegExp('^' + key + ':.+$', 'm'), key + ': ' + value);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-10-01 09:28:39 +00:00
|
|
|
/**
|
2018-10-14 18:40:00 +00:00
|
|
|
* Get the path of the global config directory
|
2018-10-01 09:28:39 +00:00
|
|
|
*
|
|
|
|
* - For Windows, get the path of APPDATA
|
|
|
|
* - For Linux and MacOS, get the path of the home directory
|
|
|
|
*
|
|
|
|
* @return {String}
|
|
|
|
*/
|
|
|
|
function getGlobalDirectory() {
|
|
|
|
|
2018-10-14 18:41:58 +00:00
|
|
|
// Windows
|
|
|
|
if (typeof process.env.APPDATA != 'undefined') {
|
|
|
|
return di.path.join(process.env.APPDATA, 'terminalizer');
|
|
|
|
}
|
|
|
|
|
|
|
|
return di.path.join(process.env.HOME, '.terminalizer');
|
|
|
|
|
2018-10-14 18:51:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if the global config directory is created
|
|
|
|
*
|
|
|
|
* @return {Boolean}
|
|
|
|
*/
|
|
|
|
function isGlobalDirectoryCreated() {
|
|
|
|
|
|
|
|
var globalDirPath = getGlobalDirectory();
|
|
|
|
|
|
|
|
return isDir(globalDirPath);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Generate and save a token to be used for uploading recordings
|
|
|
|
*
|
|
|
|
* @param {String} token
|
|
|
|
* @return {String}
|
|
|
|
*/
|
|
|
|
function generateToken(token) {
|
|
|
|
|
|
|
|
var token = di.uuid.v4();
|
|
|
|
var globalDirPath = getGlobalDirectory();
|
|
|
|
var tokenPath = di.path.join(globalDirPath, 'token.txt');
|
|
|
|
|
|
|
|
di.fs.writeFileSync(tokenPath, token, 'utf8');
|
|
|
|
|
|
|
|
return token;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get registered token for uploading recordings
|
|
|
|
*
|
|
|
|
* @return {String|Null}
|
|
|
|
*/
|
|
|
|
function getToken() {
|
|
|
|
|
|
|
|
var globalDirPath = getGlobalDirectory();
|
|
|
|
var tokenPath = di.path.join(globalDirPath, 'token.txt');
|
|
|
|
|
|
|
|
// The file doesn't exist
|
|
|
|
if (!isFile(tokenPath)) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return di.fs.readFileSync(tokenPath, 'utf8');
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove a registered token
|
|
|
|
*/
|
|
|
|
function removeToken() {
|
|
|
|
|
|
|
|
var globalDirPath = getGlobalDirectory();
|
|
|
|
var tokenPath = di.path.join(globalDirPath, 'token.txt');
|
|
|
|
|
|
|
|
// The file doesn't exist
|
|
|
|
if (!isFile(tokenPath)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
di.fs.unlinkSync(tokenPath);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the name of the current OS
|
|
|
|
*
|
|
|
|
* @return {String} mac, windows, linux
|
|
|
|
*/
|
|
|
|
function getOS() {
|
|
|
|
|
|
|
|
// MacOS
|
|
|
|
if (di.os.platform() == 'darwin') {
|
|
|
|
|
|
|
|
return 'mac';
|
|
|
|
|
|
|
|
// Windows
|
|
|
|
} else if (di.os.platform() == 'win32') {
|
|
|
|
|
|
|
|
return 'windows';
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return 'linux';
|
2018-10-01 09:28:39 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-07-22 22:34:35 +00:00
|
|
|
////////////////////////////////////////////////////
|
|
|
|
// Module //////////////////////////////////////////
|
|
|
|
////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
loadYAML: loadYAML,
|
|
|
|
loadJSON: loadJSON,
|
|
|
|
resolveFilePath: resolveFilePath,
|
|
|
|
getDefaultConfig: getDefaultConfig,
|
2018-10-01 09:28:39 +00:00
|
|
|
changeYAMLValue: changeYAMLValue,
|
2018-10-14 18:51:24 +00:00
|
|
|
getGlobalDirectory: getGlobalDirectory,
|
|
|
|
isGlobalDirectoryCreated: isGlobalDirectoryCreated,
|
|
|
|
generateToken: generateToken,
|
|
|
|
getToken: getToken,
|
|
|
|
removeToken: removeToken,
|
|
|
|
getOS: getOS
|
2018-07-22 22:34:35 +00:00
|
|
|
};
|