APTrust/dart

View on GitHub
core/config.js

Summary

Maintainability
A
0 mins
Test Coverage
const envPaths = require('env-paths');
const os = require('os');
const path = require('path');

const dartPaths = envPaths('DART', { suffix: ''});
const homedir = os.homedir();

/**
 * defaultConfig contains config settings for running the electron app
 * and command-line apps as a user. These are the settings you'll want
 * to use in all cases except unit tests.
 *
 * @property {string} homedir - Path to the current user's home directory.
 * @property {string} datadir - Path to directory where the current application stores its data.
 * @property {string} logdir  - Path to directory where the current application stores its logs.
 * @property {string} tempdir - Path to directory where the current application stores temp files.
 *
 * @memberof Config
 * @static
 */
const userConfig = {
    homeDir: homedir,
    dataDir: dartPaths.data,
    logDir: dartPaths.log,
    tempDir: dartPaths.temp
};

/**
 * testConfig contains config settings for running automated tests.
 *
 * @property {string} homedir - Path to the current user's home directory.
 * @property {string} datadir - Path to directory where the current application stores its data.
 * @property {string} logdir  - Path to directory where the current application stores its logs.
 * @property {string} tempdir - Path to directory where the current application stores temp files.
 *
 * @memberof Config
 * @static
 */
const testConfig = {
    homeDir: homedir,
    dataDir: path.join(homedir, '.dart-test', 'data'),
    logDir: path.join(homedir, '.dart-test', 'log'),
    tempDir: path.join(homedir, '.dart-test', 'tmp')
};

/**
 * Config contains config settings for user and test environments.
 * The GlobalContext object determines which configuration to use at
 * runtime. It will always select the 'user' config, except when
 * process.env.NODE_ENV=test.
 *
 */
const Config = {
    'user': userConfig,
    'test': testConfig
};

module.exports.Config = Config;