pegjs/tools/publish-dev/publish.js
2019-09-29 06:53:31 +01:00

77 lines
1.8 KiB
JavaScript

"use strict";
const cp = require( "child_process" );
const fs = require( "fs" );
const path = require( "path" );
function publish( id ) {
// paths
const packagejson = require.resolve( id + "/package.json" );
const directory = path.dirname( packagejson );
const npmignore = path.join( directory, ".npmignore" );
const npmrc = path.join( directory, ".npmrc" );
// variabes
const APP = require( "./package.json" ).name;
const VERSION = require( packagejson ).version;
const {
GITHUB_REF,
GITHUB_SHA,
NPM_TOKEN,
} = process.env;
// local helpers
function die( err ) {
console.error( err );
process.exit( 1 );
}
function exec( command, print = true ) {
const result = cp.execSync( command, {
cwd: directory,
stdio: print ? "inherit" : void 0,
} );
return print ? void 0 : result.toString( "utf8" );
}
// assertions
if ( ! GITHUB_REF ) die( "`process.env.GITHUB_REF` is required by " + APP );
if ( ! GITHUB_SHA ) die( "`process.env.GITHUB_SHA` is required by " + APP );
if ( ! NPM_TOKEN ) die( "`process.env.NPM_TOKEN` is required by " + APP );
// update version field in `<package>/package.json`
const GIT_COMMIT_SHORT_SHA = exec( "git rev-parse --short " + GITHUB_SHA, false );
const dev = `${ VERSION }-${ GITHUB_REF.replace( "refs/heads/", "" ) }.${ GIT_COMMIT_SHORT_SHA }`;
exec( `npm --no-git-tag-version -f version ${ dev }` );
// add npm token and remove ignore file (this is a DEV release after all)
fs.writeFileSync( npmrc, `//registry.npmjs.org/:_authToken=${ NPM_TOKEN }` );
if ( fs.existsSync( npmignore ) ) fs.unlinkSync( npmignore );
// publish <package>@dev
exec( "npm publish --tag=dev" );
fs.unlinkSync( npmrc );
}
module.exports = publish;