setup-node/lib/authutil.js

45 lines
1.6 KiB
JavaScript
Raw Normal View History

2019-08-05 16:35:39 +01:00
"use strict";
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
result["default"] = mod;
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
2019-08-05 16:51:04 +01:00
const fs = __importStar(require("fs"));
const os = __importStar(require("os"));
2019-08-05 16:35:39 +01:00
const path = __importStar(require("path"));
2019-08-05 16:51:04 +01:00
const core = __importStar(require("@actions/core"));
2019-08-05 16:35:39 +01:00
function configAuth(registryUrl) {
2019-08-05 16:51:04 +01:00
let npmrc = path.resolve(process.cwd(), '.npmrc');
let yarnrc = path.resolve(process.cwd(), '.yarnrc');
writeRegistryToFile(registryUrl, npmrc, 'NPM_TOKEN');
writeRegistryToFile(registryUrl, yarnrc, 'YARN_TOKEN');
2019-08-05 16:35:39 +01:00
}
exports.configAuth = configAuth;
2019-08-05 16:51:04 +01:00
function writeRegistryToFile(registryUrl, fileLocation, authTokenName) {
core.debug(`Setting auth in ${fileLocation}`);
let newContents = '';
if (fs.existsSync(fileLocation)) {
const curContents = fs.readFileSync(fileLocation, 'utf8');
curContents.split(os.EOL).forEach((line) => {
// Add current contents unless they are setting the registry
if (!line.startsWith('registry')) {
newContents += line + os.EOL;
}
});
}
newContents +=
'registry=' +
registryUrl +
os.EOL +
'always-auth=true' +
os.EOL +
2019-08-05 16:44:04 +01:00
registryUrl.replace(/(^\w+:|^)/, '') +
2019-08-05 16:51:04 +01:00
':_authToken=${' +
2019-08-05 16:44:04 +01:00
authTokenName +
2019-08-05 16:51:04 +01:00
'}';
fs.writeFileSync(fileLocation, newContents);
2019-08-05 16:35:39 +01:00
}