jsii-release
Version:
Release jsii modules to multiple package managers
170 lines • 17.9 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
exports.UsageDir = exports.DEFAULT_USAGE_DIR = void 0;
const path = __importStar(require("path"));
const fs = __importStar(require("fs-extra"));
const files_1 = require("./files");
exports.DEFAULT_USAGE_DIR = path.join((0, files_1.homeDir)(), '.publib-ca/usage');
/**
* The usage directory is where we write per-session config files to access the CodeArtifact repository.
*
* Some config files may be written in a system-global location, but they will not be active unless the
* contents of this directory have been sourced/copied into the current terminal.
*
* CONTRACT
*
* There are two special entries:
*
* - `env`, a file with `key=value` entries for environment variables to set.
* - `cwd/`, a directory with files that need to be copied into the current directory before each command.
*
* Other than these, code may write tempfiles to this directory if it wants, but there is no meaning
* implied for other files.
*/
class UsageDir {
static default() {
return new UsageDir(exports.DEFAULT_USAGE_DIR);
}
constructor(directory) {
this.directory = directory;
this.envFile = path.join(this.directory, 'env');
this.cwdDir = path.join(this.directory, 'cwd');
}
async delete() {
if (await fs.pathExists(this.directory)) {
await fs.remove(this.directory);
}
}
/**
* Create a fresh empty directory, with helper scripts
*/
async reset() {
await this.delete();
await fs.mkdirp(path.join(this.directory, 'cwd'));
await fs.writeFile(path.join(this.directory, 'env'), '', { encoding: 'utf-8' });
await this.addToEnv({
CWD_FILES_DIR: path.join(this.directory, 'cwd'),
});
// Write a bash helper to load these settings
await fs.writeFile(path.join(this.directory, 'activate.bash'), [
`while read -u10 line; do [[ -z $line ]] || export "$line"; done 10<${this.directory}/env`,
'cp -R $CWD_FILES_DIR/ .', // Copy files from directory even if it is empty
].join('\n'), { encoding: 'utf-8' });
}
/**
* Set the expiration time of the current settings
*/
async setExpirationTimeMs(timestamp) {
await this.addToEnv({
EXPIRATION_TIME_MS: `${timestamp}`,
});
}
/**
* Add settings to the environment variables
*/
async addToEnv(settings) {
const lines = await (0, files_1.loadLines)(this.envFile);
for (const [k, v] of Object.entries(settings)) {
(0, files_1.updateIniKey)(lines, k, v);
}
await (0, files_1.writeLines)(this.envFile, lines);
}
/**
* Return the current environment variables
*/
async currentEnv() {
const lines = await (0, files_1.loadLines)(this.envFile);
const splitter = /^([a-zA-Z0-9_-]+)\s*=\s*(.*)$/;
const ret = {};
for (const line of lines) {
const m = line.match(splitter);
if (m) {
ret[m[1]] = m[2];
}
}
return ret;
}
cwdFile(filename) {
return path.join(this.cwdDir, filename);
}
/**
* Activate in the current process (update process.env), copy the cwd/ directory to the current directory
*/
async activateInCurrentProcess() {
for (const [k, v] of Object.entries(await this.currentEnv())) {
process.env[k] = v;
}
await (0, files_1.copyDirectoryContents)(this.cwdDir, '.');
}
async copySelectCwdFileHere(...filenames) {
for (const file of filenames) {
await fs.copyFile(path.join(this.cwdDir, file), file);
}
}
async putFile(filename, contents) {
const fileName = path.join(this.directory, filename);
await (0, files_1.writeFile)(fileName, contents);
return fileName;
}
async putCwdFile(filename, contents) {
await (0, files_1.writeFile)(path.join(this.cwdDir, filename), contents);
}
async putJson(key, data) {
await (0, files_1.writeFile)(path.join(this.directory, key + '.json'), JSON.stringify(data, undefined, 2));
}
async readJson(key) {
try {
return await fs.readJson(path.join(this.directory, key + '.json'));
}
catch (e) {
if (e.code === 'ENOENT') {
return undefined;
}
throw e;
}
}
/**
* Print to the console on how to activate these settings
*/
advertise() {
// eslint-disable-next-line no-console
console.log('To activate these settings in the current bash shell:');
// eslint-disable-next-line no-console
console.log(` source ${this.directory}/activate.bash`);
}
}
exports.UsageDir = UsageDir;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"usage-dir.js","sourceRoot":"","sources":["../../src/codeartifact/usage-dir.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as fs from 'fs-extra';\nimport { copyDirectoryContents, homeDir, loadLines, updateIniKey, writeFile, writeLines } from './files';\n\nexport const DEFAULT_USAGE_DIR = path.join(homeDir(), '.publib-ca/usage');\n\n/**\n * The usage directory is where we write per-session config files to access the CodeArtifact repository.\n *\n * Some config files may be written in a system-global location, but they will not be active unless the\n * contents of this directory have been sourced/copied into the current terminal.\n *\n * CONTRACT\n *\n * There are two special entries:\n *\n * - `env`, a file with `key=value` entries for environment variables to  set.\n * - `cwd/`, a directory with files that need to be copied into the current directory before each command.\n *\n * Other than these, code may write tempfiles to this directory if it wants, but there is no meaning\n * implied for other files.\n */\nexport class UsageDir {\n  public static default() {\n    return new UsageDir(DEFAULT_USAGE_DIR);\n  }\n\n  public readonly envFile: string;\n  public readonly cwdDir: string;\n\n  private constructor(public readonly directory: string) {\n    this.envFile = path.join(this.directory, 'env');\n    this.cwdDir = path.join(this.directory, 'cwd');\n  }\n\n  public async delete() {\n    if (await fs.pathExists(this.directory)) {\n      await fs.remove(this.directory);\n    }\n  }\n\n  /**\n   * Create a fresh empty directory, with helper scripts\n   */\n  public async reset() {\n    await this.delete();\n    await fs.mkdirp(path.join(this.directory, 'cwd'));\n    await fs.writeFile(path.join(this.directory, 'env'), '', { encoding: 'utf-8' });\n\n    await this.addToEnv({\n      CWD_FILES_DIR: path.join(this.directory, 'cwd'),\n    });\n\n    // Write a bash helper to load these settings\n    await fs.writeFile(path.join(this.directory, 'activate.bash'), [\n      `while read -u10 line; do [[ -z $line ]] || export \"$line\"; done 10<${this.directory}/env`,\n      'cp -R $CWD_FILES_DIR/ .', // Copy files from directory even if it is empty\n    ].join('\\n'), { encoding: 'utf-8' });\n  }\n\n  /**\n   * Set the expiration time of the current settings\n   */\n  public async setExpirationTimeMs(timestamp: number) {\n    await this.addToEnv({\n      EXPIRATION_TIME_MS: `${timestamp}`,\n    });\n  }\n\n  /**\n   * Add settings to the environment variables\n   */\n  public async addToEnv(settings: Record<string, string>) {\n    const lines = await loadLines(this.envFile);\n    for (const [k, v] of Object.entries(settings)) {\n      updateIniKey(lines, k, v);\n    }\n    await writeLines(this.envFile, lines);\n  }\n\n  /**\n   * Return the current environment variables\n   */\n  public async currentEnv(): Promise<Record<string, string>> {\n    const lines = await loadLines(this.envFile);\n\n    const splitter = /^([a-zA-Z0-9_-]+)\\s*=\\s*(.*)$/;\n\n    const ret: Record<string, string> = {};\n    for (const line of lines) {\n      const m = line.match(splitter);\n      if (m) {\n        ret[m[1]] = m[2];\n      }\n    }\n    return ret;\n  }\n\n  public cwdFile(filename: string) {\n    return path.join(this.cwdDir, filename);\n  }\n\n  /**\n   * Activate in the current process (update process.env), copy the cwd/ directory to the current directory\n   */\n  public async activateInCurrentProcess() {\n    for (const [k, v] of Object.entries(await this.currentEnv())) {\n      process.env[k] = v;\n    }\n\n    await copyDirectoryContents(this.cwdDir, '.');\n  }\n\n  public async copySelectCwdFileHere(...filenames: string[]) {\n    for (const file of filenames) {\n      await fs.copyFile(path.join(this.cwdDir, file), file);\n    }\n  }\n\n  public async putFile(filename: string, contents: string) {\n    const fileName = path.join(this.directory, filename);\n    await writeFile(fileName, contents);\n    return fileName;\n  }\n\n  public async putCwdFile(filename: string, contents: string) {\n    await writeFile(path.join(this.cwdDir, filename), contents);\n  }\n\n  public async putJson(key: string, data: any) {\n    await writeFile(path.join(this.directory, key + '.json'), JSON.stringify(data, undefined, 2));\n  }\n\n  public async readJson<A>(key: string): Promise<A | undefined> {\n    try {\n      return await fs.readJson(path.join(this.directory, key + '.json'));\n    } catch (e: any) {\n      if (e.code === 'ENOENT') {\n        return undefined;\n      }\n\n      throw e;\n    }\n  }\n\n  /**\n   * Print to the console on how to activate these settings\n   */\n  public advertise() {\n    // eslint-disable-next-line no-console\n    console.log('To activate these settings in the current bash shell:');\n    // eslint-disable-next-line no-console\n    console.log(`    source ${this.directory}/activate.bash`);\n  }\n}"]}