UNPKG

jsii-release

Version:

Release jsii modules to multiple package managers

160 lines 17.5 kB
"use strict"; 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 (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __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}"]}