mirror of
				https://github.com/actions/setup-java.git
				synced 2025-10-26 07:16:46 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			4150 lines
		
	
	
		
			144 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			4150 lines
		
	
	
		
			144 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| module.exports =
 | |
| /******/ (function(modules, runtime) { // webpackBootstrap
 | |
| /******/ 	"use strict";
 | |
| /******/ 	// The module cache
 | |
| /******/ 	var installedModules = {};
 | |
| /******/
 | |
| /******/ 	// The require function
 | |
| /******/ 	function __webpack_require__(moduleId) {
 | |
| /******/
 | |
| /******/ 		// Check if module is in cache
 | |
| /******/ 		if(installedModules[moduleId]) {
 | |
| /******/ 			return installedModules[moduleId].exports;
 | |
| /******/ 		}
 | |
| /******/ 		// Create a new module (and put it into the cache)
 | |
| /******/ 		var module = installedModules[moduleId] = {
 | |
| /******/ 			i: moduleId,
 | |
| /******/ 			l: false,
 | |
| /******/ 			exports: {}
 | |
| /******/ 		};
 | |
| /******/
 | |
| /******/ 		// Execute the module function
 | |
| /******/ 		modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
 | |
| /******/
 | |
| /******/ 		// Flag the module as loaded
 | |
| /******/ 		module.l = true;
 | |
| /******/
 | |
| /******/ 		// Return the exports of the module
 | |
| /******/ 		return module.exports;
 | |
| /******/ 	}
 | |
| /******/
 | |
| /******/
 | |
| /******/ 	__webpack_require__.ab = __dirname + "/";
 | |
| /******/
 | |
| /******/ 	// the startup function
 | |
| /******/ 	function startup() {
 | |
| /******/ 		// Load entry module and return exports
 | |
| /******/ 		return __webpack_require__(219);
 | |
| /******/ 	};
 | |
| /******/
 | |
| /******/ 	// run startup
 | |
| /******/ 	return startup();
 | |
| /******/ })
 | |
| /************************************************************************/
 | |
| /******/ ({
 | |
| 
 | |
| /***/ 1:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
 | |
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
 | |
|     return new (P || (P = Promise))(function (resolve, reject) {
 | |
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
 | |
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
 | |
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
 | |
|         step((generator = generator.apply(thisArg, _arguments || [])).next());
 | |
|     });
 | |
| };
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| const childProcess = __webpack_require__(129);
 | |
| const path = __webpack_require__(622);
 | |
| const util_1 = __webpack_require__(669);
 | |
| const ioUtil = __webpack_require__(672);
 | |
| const exec = util_1.promisify(childProcess.exec);
 | |
| /**
 | |
|  * Copies a file or folder.
 | |
|  * Based off of shelljs - https://github.com/shelljs/shelljs/blob/9237f66c52e5daa40458f94f9565e18e8132f5a6/src/cp.js
 | |
|  *
 | |
|  * @param     source    source path
 | |
|  * @param     dest      destination path
 | |
|  * @param     options   optional. See CopyOptions.
 | |
|  */
 | |
| function cp(source, dest, options = {}) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         const { force, recursive } = readCopyOptions(options);
 | |
|         const destStat = (yield ioUtil.exists(dest)) ? yield ioUtil.stat(dest) : null;
 | |
|         // Dest is an existing file, but not forcing
 | |
|         if (destStat && destStat.isFile() && !force) {
 | |
|             return;
 | |
|         }
 | |
|         // If dest is an existing directory, should copy inside.
 | |
|         const newDest = destStat && destStat.isDirectory()
 | |
|             ? path.join(dest, path.basename(source))
 | |
|             : dest;
 | |
|         if (!(yield ioUtil.exists(source))) {
 | |
|             throw new Error(`no such file or directory: ${source}`);
 | |
|         }
 | |
|         const sourceStat = yield ioUtil.stat(source);
 | |
|         if (sourceStat.isDirectory()) {
 | |
|             if (!recursive) {
 | |
|                 throw new Error(`Failed to copy. ${source} is a directory, but tried to copy without recursive flag.`);
 | |
|             }
 | |
|             else {
 | |
|                 yield cpDirRecursive(source, newDest, 0, force);
 | |
|             }
 | |
|         }
 | |
|         else {
 | |
|             if (path.relative(source, newDest) === '') {
 | |
|                 // a file cannot be copied to itself
 | |
|                 throw new Error(`'${newDest}' and '${source}' are the same file`);
 | |
|             }
 | |
|             yield copyFile(source, newDest, force);
 | |
|         }
 | |
|     });
 | |
| }
 | |
| exports.cp = cp;
 | |
| /**
 | |
|  * Moves a path.
 | |
|  *
 | |
|  * @param     source    source path
 | |
|  * @param     dest      destination path
 | |
|  * @param     options   optional. See MoveOptions.
 | |
|  */
 | |
| function mv(source, dest, options = {}) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         if (yield ioUtil.exists(dest)) {
 | |
|             let destExists = true;
 | |
|             if (yield ioUtil.isDirectory(dest)) {
 | |
|                 // If dest is directory copy src into dest
 | |
|                 dest = path.join(dest, path.basename(source));
 | |
|                 destExists = yield ioUtil.exists(dest);
 | |
|             }
 | |
|             if (destExists) {
 | |
|                 if (options.force == null || options.force) {
 | |
|                     yield rmRF(dest);
 | |
|                 }
 | |
|                 else {
 | |
|                     throw new Error('Destination already exists');
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|         yield mkdirP(path.dirname(dest));
 | |
|         yield ioUtil.rename(source, dest);
 | |
|     });
 | |
| }
 | |
| exports.mv = mv;
 | |
| /**
 | |
|  * Remove a path recursively with force
 | |
|  *
 | |
|  * @param inputPath path to remove
 | |
|  */
 | |
| function rmRF(inputPath) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         if (ioUtil.IS_WINDOWS) {
 | |
|             // Node doesn't provide a delete operation, only an unlink function. This means that if the file is being used by another
 | |
|             // program (e.g. antivirus), it won't be deleted. To address this, we shell out the work to rd/del.
 | |
|             try {
 | |
|                 if (yield ioUtil.isDirectory(inputPath, true)) {
 | |
|                     yield exec(`rd /s /q "${inputPath}"`);
 | |
|                 }
 | |
|                 else {
 | |
|                     yield exec(`del /f /a "${inputPath}"`);
 | |
|                 }
 | |
|             }
 | |
|             catch (err) {
 | |
|                 // if you try to delete a file that doesn't exist, desired result is achieved
 | |
|                 // other errors are valid
 | |
|                 if (err.code !== 'ENOENT')
 | |
|                     throw err;
 | |
|             }
 | |
|             // Shelling out fails to remove a symlink folder with missing source, this unlink catches that
 | |
|             try {
 | |
|                 yield ioUtil.unlink(inputPath);
 | |
|             }
 | |
|             catch (err) {
 | |
|                 // if you try to delete a file that doesn't exist, desired result is achieved
 | |
|                 // other errors are valid
 | |
|                 if (err.code !== 'ENOENT')
 | |
|                     throw err;
 | |
|             }
 | |
|         }
 | |
|         else {
 | |
|             let isDir = false;
 | |
|             try {
 | |
|                 isDir = yield ioUtil.isDirectory(inputPath);
 | |
|             }
 | |
|             catch (err) {
 | |
|                 // if you try to delete a file that doesn't exist, desired result is achieved
 | |
|                 // other errors are valid
 | |
|                 if (err.code !== 'ENOENT')
 | |
|                     throw err;
 | |
|                 return;
 | |
|             }
 | |
|             if (isDir) {
 | |
|                 yield exec(`rm -rf "${inputPath}"`);
 | |
|             }
 | |
|             else {
 | |
|                 yield ioUtil.unlink(inputPath);
 | |
|             }
 | |
|         }
 | |
|     });
 | |
| }
 | |
| exports.rmRF = rmRF;
 | |
| /**
 | |
|  * Make a directory.  Creates the full path with folders in between
 | |
|  * Will throw if it fails
 | |
|  *
 | |
|  * @param   fsPath        path to create
 | |
|  * @returns Promise<void>
 | |
|  */
 | |
| function mkdirP(fsPath) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         yield ioUtil.mkdirP(fsPath);
 | |
|     });
 | |
| }
 | |
| exports.mkdirP = mkdirP;
 | |
| /**
 | |
|  * Returns path of a tool had the tool actually been invoked.  Resolves via paths.
 | |
|  * If you check and the tool does not exist, it will throw.
 | |
|  *
 | |
|  * @param     tool              name of the tool
 | |
|  * @param     check             whether to check if tool exists
 | |
|  * @returns   Promise<string>   path to tool
 | |
|  */
 | |
| function which(tool, check) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         if (!tool) {
 | |
|             throw new Error("parameter 'tool' is required");
 | |
|         }
 | |
|         // recursive when check=true
 | |
|         if (check) {
 | |
|             const result = yield which(tool, false);
 | |
|             if (!result) {
 | |
|                 if (ioUtil.IS_WINDOWS) {
 | |
|                     throw new Error(`Unable to locate executable file: ${tool}. Please verify either the file path exists or the file can be found within a directory specified by the PATH environment variable. Also verify the file has a valid extension for an executable file.`);
 | |
|                 }
 | |
|                 else {
 | |
|                     throw new Error(`Unable to locate executable file: ${tool}. Please verify either the file path exists or the file can be found within a directory specified by the PATH environment variable. Also check the file mode to verify the file is executable.`);
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|         try {
 | |
|             // build the list of extensions to try
 | |
|             const extensions = [];
 | |
|             if (ioUtil.IS_WINDOWS && process.env.PATHEXT) {
 | |
|                 for (const extension of process.env.PATHEXT.split(path.delimiter)) {
 | |
|                     if (extension) {
 | |
|                         extensions.push(extension);
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|             // if it's rooted, return it if exists. otherwise return empty.
 | |
|             if (ioUtil.isRooted(tool)) {
 | |
|                 const filePath = yield ioUtil.tryGetExecutablePath(tool, extensions);
 | |
|                 if (filePath) {
 | |
|                     return filePath;
 | |
|                 }
 | |
|                 return '';
 | |
|             }
 | |
|             // if any path separators, return empty
 | |
|             if (tool.includes('/') || (ioUtil.IS_WINDOWS && tool.includes('\\'))) {
 | |
|                 return '';
 | |
|             }
 | |
|             // build the list of directories
 | |
|             //
 | |
|             // Note, technically "where" checks the current directory on Windows. From a toolkit perspective,
 | |
|             // it feels like we should not do this. Checking the current directory seems like more of a use
 | |
|             // case of a shell, and the which() function exposed by the toolkit should strive for consistency
 | |
|             // across platforms.
 | |
|             const directories = [];
 | |
|             if (process.env.PATH) {
 | |
|                 for (const p of process.env.PATH.split(path.delimiter)) {
 | |
|                     if (p) {
 | |
|                         directories.push(p);
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|             // return the first match
 | |
|             for (const directory of directories) {
 | |
|                 const filePath = yield ioUtil.tryGetExecutablePath(directory + path.sep + tool, extensions);
 | |
|                 if (filePath) {
 | |
|                     return filePath;
 | |
|                 }
 | |
|             }
 | |
|             return '';
 | |
|         }
 | |
|         catch (err) {
 | |
|             throw new Error(`which failed with message ${err.message}`);
 | |
|         }
 | |
|     });
 | |
| }
 | |
| exports.which = which;
 | |
| function readCopyOptions(options) {
 | |
|     const force = options.force == null ? true : options.force;
 | |
|     const recursive = Boolean(options.recursive);
 | |
|     return { force, recursive };
 | |
| }
 | |
| function cpDirRecursive(sourceDir, destDir, currentDepth, force) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         // Ensure there is not a run away recursive copy
 | |
|         if (currentDepth >= 255)
 | |
|             return;
 | |
|         currentDepth++;
 | |
|         yield mkdirP(destDir);
 | |
|         const files = yield ioUtil.readdir(sourceDir);
 | |
|         for (const fileName of files) {
 | |
|             const srcFile = `${sourceDir}/${fileName}`;
 | |
|             const destFile = `${destDir}/${fileName}`;
 | |
|             const srcFileStat = yield ioUtil.lstat(srcFile);
 | |
|             if (srcFileStat.isDirectory()) {
 | |
|                 // Recurse
 | |
|                 yield cpDirRecursive(srcFile, destFile, currentDepth, force);
 | |
|             }
 | |
|             else {
 | |
|                 yield copyFile(srcFile, destFile, force);
 | |
|             }
 | |
|         }
 | |
|         // Change the mode for the newly created directory
 | |
|         yield ioUtil.chmod(destDir, (yield ioUtil.stat(sourceDir)).mode);
 | |
|     });
 | |
| }
 | |
| // Buffered file copy
 | |
| function copyFile(srcFile, destFile, force) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         if ((yield ioUtil.lstat(srcFile)).isSymbolicLink()) {
 | |
|             // unlink/re-link it
 | |
|             try {
 | |
|                 yield ioUtil.lstat(destFile);
 | |
|                 yield ioUtil.unlink(destFile);
 | |
|             }
 | |
|             catch (e) {
 | |
|                 // Try to override file permission
 | |
|                 if (e.code === 'EPERM') {
 | |
|                     yield ioUtil.chmod(destFile, '0666');
 | |
|                     yield ioUtil.unlink(destFile);
 | |
|                 }
 | |
|                 // other errors = it doesn't exist, no work to do
 | |
|             }
 | |
|             // Copy over symlink
 | |
|             const symlinkFull = yield ioUtil.readlink(srcFile);
 | |
|             yield ioUtil.symlink(symlinkFull, destFile, ioUtil.IS_WINDOWS ? 'junction' : null);
 | |
|         }
 | |
|         else if (!(yield ioUtil.exists(destFile)) || force) {
 | |
|             yield ioUtil.copyFile(srcFile, destFile);
 | |
|         }
 | |
|     });
 | |
| }
 | |
| //# sourceMappingURL=io.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 4:
 | |
| /***/ (function(__unusedmodule, exports) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| var _default = '00000000-0000-0000-0000-000000000000';
 | |
| exports.default = _default;
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 9:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
 | |
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
 | |
|     return new (P || (P = Promise))(function (resolve, reject) {
 | |
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
 | |
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
 | |
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
 | |
|         step((generator = generator.apply(thisArg, _arguments || [])).next());
 | |
|     });
 | |
| };
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| const os = __webpack_require__(87);
 | |
| const events = __webpack_require__(614);
 | |
| const child = __webpack_require__(129);
 | |
| const path = __webpack_require__(622);
 | |
| const io = __webpack_require__(1);
 | |
| const ioUtil = __webpack_require__(672);
 | |
| /* eslint-disable @typescript-eslint/unbound-method */
 | |
| const IS_WINDOWS = process.platform === 'win32';
 | |
| /*
 | |
|  * Class for running command line tools. Handles quoting and arg parsing in a platform agnostic way.
 | |
|  */
 | |
| class ToolRunner extends events.EventEmitter {
 | |
|     constructor(toolPath, args, options) {
 | |
|         super();
 | |
|         if (!toolPath) {
 | |
|             throw new Error("Parameter 'toolPath' cannot be null or empty.");
 | |
|         }
 | |
|         this.toolPath = toolPath;
 | |
|         this.args = args || [];
 | |
|         this.options = options || {};
 | |
|     }
 | |
|     _debug(message) {
 | |
|         if (this.options.listeners && this.options.listeners.debug) {
 | |
|             this.options.listeners.debug(message);
 | |
|         }
 | |
|     }
 | |
|     _getCommandString(options, noPrefix) {
 | |
|         const toolPath = this._getSpawnFileName();
 | |
|         const args = this._getSpawnArgs(options);
 | |
|         let cmd = noPrefix ? '' : '[command]'; // omit prefix when piped to a second tool
 | |
|         if (IS_WINDOWS) {
 | |
|             // Windows + cmd file
 | |
|             if (this._isCmdFile()) {
 | |
|                 cmd += toolPath;
 | |
|                 for (const a of args) {
 | |
|                     cmd += ` ${a}`;
 | |
|                 }
 | |
|             }
 | |
|             // Windows + verbatim
 | |
|             else if (options.windowsVerbatimArguments) {
 | |
|                 cmd += `"${toolPath}"`;
 | |
|                 for (const a of args) {
 | |
|                     cmd += ` ${a}`;
 | |
|                 }
 | |
|             }
 | |
|             // Windows (regular)
 | |
|             else {
 | |
|                 cmd += this._windowsQuoteCmdArg(toolPath);
 | |
|                 for (const a of args) {
 | |
|                     cmd += ` ${this._windowsQuoteCmdArg(a)}`;
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|         else {
 | |
|             // OSX/Linux - this can likely be improved with some form of quoting.
 | |
|             // creating processes on Unix is fundamentally different than Windows.
 | |
|             // on Unix, execvp() takes an arg array.
 | |
|             cmd += toolPath;
 | |
|             for (const a of args) {
 | |
|                 cmd += ` ${a}`;
 | |
|             }
 | |
|         }
 | |
|         return cmd;
 | |
|     }
 | |
|     _processLineBuffer(data, strBuffer, onLine) {
 | |
|         try {
 | |
|             let s = strBuffer + data.toString();
 | |
|             let n = s.indexOf(os.EOL);
 | |
|             while (n > -1) {
 | |
|                 const line = s.substring(0, n);
 | |
|                 onLine(line);
 | |
|                 // the rest of the string ...
 | |
|                 s = s.substring(n + os.EOL.length);
 | |
|                 n = s.indexOf(os.EOL);
 | |
|             }
 | |
|             strBuffer = s;
 | |
|         }
 | |
|         catch (err) {
 | |
|             // streaming lines to console is best effort.  Don't fail a build.
 | |
|             this._debug(`error processing line. Failed with error ${err}`);
 | |
|         }
 | |
|     }
 | |
|     _getSpawnFileName() {
 | |
|         if (IS_WINDOWS) {
 | |
|             if (this._isCmdFile()) {
 | |
|                 return process.env['COMSPEC'] || 'cmd.exe';
 | |
|             }
 | |
|         }
 | |
|         return this.toolPath;
 | |
|     }
 | |
|     _getSpawnArgs(options) {
 | |
|         if (IS_WINDOWS) {
 | |
|             if (this._isCmdFile()) {
 | |
|                 let argline = `/D /S /C "${this._windowsQuoteCmdArg(this.toolPath)}`;
 | |
|                 for (const a of this.args) {
 | |
|                     argline += ' ';
 | |
|                     argline += options.windowsVerbatimArguments
 | |
|                         ? a
 | |
|                         : this._windowsQuoteCmdArg(a);
 | |
|                 }
 | |
|                 argline += '"';
 | |
|                 return [argline];
 | |
|             }
 | |
|         }
 | |
|         return this.args;
 | |
|     }
 | |
|     _endsWith(str, end) {
 | |
|         return str.endsWith(end);
 | |
|     }
 | |
|     _isCmdFile() {
 | |
|         const upperToolPath = this.toolPath.toUpperCase();
 | |
|         return (this._endsWith(upperToolPath, '.CMD') ||
 | |
|             this._endsWith(upperToolPath, '.BAT'));
 | |
|     }
 | |
|     _windowsQuoteCmdArg(arg) {
 | |
|         // for .exe, apply the normal quoting rules that libuv applies
 | |
|         if (!this._isCmdFile()) {
 | |
|             return this._uvQuoteCmdArg(arg);
 | |
|         }
 | |
|         // otherwise apply quoting rules specific to the cmd.exe command line parser.
 | |
|         // the libuv rules are generic and are not designed specifically for cmd.exe
 | |
|         // command line parser.
 | |
|         //
 | |
|         // for a detailed description of the cmd.exe command line parser, refer to
 | |
|         // http://stackoverflow.com/questions/4094699/how-does-the-windows-command-interpreter-cmd-exe-parse-scripts/7970912#7970912
 | |
|         // need quotes for empty arg
 | |
|         if (!arg) {
 | |
|             return '""';
 | |
|         }
 | |
|         // determine whether the arg needs to be quoted
 | |
|         const cmdSpecialChars = [
 | |
|             ' ',
 | |
|             '\t',
 | |
|             '&',
 | |
|             '(',
 | |
|             ')',
 | |
|             '[',
 | |
|             ']',
 | |
|             '{',
 | |
|             '}',
 | |
|             '^',
 | |
|             '=',
 | |
|             ';',
 | |
|             '!',
 | |
|             "'",
 | |
|             '+',
 | |
|             ',',
 | |
|             '`',
 | |
|             '~',
 | |
|             '|',
 | |
|             '<',
 | |
|             '>',
 | |
|             '"'
 | |
|         ];
 | |
|         let needsQuotes = false;
 | |
|         for (const char of arg) {
 | |
|             if (cmdSpecialChars.some(x => x === char)) {
 | |
|                 needsQuotes = true;
 | |
|                 break;
 | |
|             }
 | |
|         }
 | |
|         // short-circuit if quotes not needed
 | |
|         if (!needsQuotes) {
 | |
|             return arg;
 | |
|         }
 | |
|         // the following quoting rules are very similar to the rules that by libuv applies.
 | |
|         //
 | |
|         // 1) wrap the string in quotes
 | |
|         //
 | |
|         // 2) double-up quotes - i.e. " => ""
 | |
|         //
 | |
|         //    this is different from the libuv quoting rules. libuv replaces " with \", which unfortunately
 | |
|         //    doesn't work well with a cmd.exe command line.
 | |
|         //
 | |
|         //    note, replacing " with "" also works well if the arg is passed to a downstream .NET console app.
 | |
|         //    for example, the command line:
 | |
|         //          foo.exe "myarg:""my val"""
 | |
|         //    is parsed by a .NET console app into an arg array:
 | |
|         //          [ "myarg:\"my val\"" ]
 | |
|         //    which is the same end result when applying libuv quoting rules. although the actual
 | |
|         //    command line from libuv quoting rules would look like:
 | |
|         //          foo.exe "myarg:\"my val\""
 | |
|         //
 | |
|         // 3) double-up slashes that precede a quote,
 | |
|         //    e.g.  hello \world    => "hello \world"
 | |
|         //          hello\"world    => "hello\\""world"
 | |
|         //          hello\\"world   => "hello\\\\""world"
 | |
|         //          hello world\    => "hello world\\"
 | |
|         //
 | |
|         //    technically this is not required for a cmd.exe command line, or the batch argument parser.
 | |
|         //    the reasons for including this as a .cmd quoting rule are:
 | |
|         //
 | |
|         //    a) this is optimized for the scenario where the argument is passed from the .cmd file to an
 | |
|         //       external program. many programs (e.g. .NET console apps) rely on the slash-doubling rule.
 | |
|         //
 | |
|         //    b) it's what we've been doing previously (by deferring to node default behavior) and we
 | |
|         //       haven't heard any complaints about that aspect.
 | |
|         //
 | |
|         // note, a weakness of the quoting rules chosen here, is that % is not escaped. in fact, % cannot be
 | |
|         // escaped when used on the command line directly - even though within a .cmd file % can be escaped
 | |
|         // by using %%.
 | |
|         //
 | |
|         // the saving grace is, on the command line, %var% is left as-is if var is not defined. this contrasts
 | |
|         // the line parsing rules within a .cmd file, where if var is not defined it is replaced with nothing.
 | |
|         //
 | |
|         // one option that was explored was replacing % with ^% - i.e. %var% => ^%var^%. this hack would
 | |
|         // often work, since it is unlikely that var^ would exist, and the ^ character is removed when the
 | |
|         // variable is used. the problem, however, is that ^ is not removed when %* is used to pass the args
 | |
|         // to an external program.
 | |
|         //
 | |
|         // an unexplored potential solution for the % escaping problem, is to create a wrapper .cmd file.
 | |
|         // % can be escaped within a .cmd file.
 | |
|         let reverse = '"';
 | |
|         let quoteHit = true;
 | |
|         for (let i = arg.length; i > 0; i--) {
 | |
|             // walk the string in reverse
 | |
|             reverse += arg[i - 1];
 | |
|             if (quoteHit && arg[i - 1] === '\\') {
 | |
|                 reverse += '\\'; // double the slash
 | |
|             }
 | |
|             else if (arg[i - 1] === '"') {
 | |
|                 quoteHit = true;
 | |
|                 reverse += '"'; // double the quote
 | |
|             }
 | |
|             else {
 | |
|                 quoteHit = false;
 | |
|             }
 | |
|         }
 | |
|         reverse += '"';
 | |
|         return reverse
 | |
|             .split('')
 | |
|             .reverse()
 | |
|             .join('');
 | |
|     }
 | |
|     _uvQuoteCmdArg(arg) {
 | |
|         // Tool runner wraps child_process.spawn() and needs to apply the same quoting as
 | |
|         // Node in certain cases where the undocumented spawn option windowsVerbatimArguments
 | |
|         // is used.
 | |
|         //
 | |
|         // Since this function is a port of quote_cmd_arg from Node 4.x (technically, lib UV,
 | |
|         // see https://github.com/nodejs/node/blob/v4.x/deps/uv/src/win/process.c for details),
 | |
|         // pasting copyright notice from Node within this function:
 | |
|         //
 | |
|         //      Copyright Joyent, Inc. and other Node contributors. All rights reserved.
 | |
|         //
 | |
|         //      Permission is hereby granted, free of charge, to any person obtaining a copy
 | |
|         //      of this software and associated documentation files (the "Software"), to
 | |
|         //      deal in the Software without restriction, including without limitation the
 | |
|         //      rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
 | |
|         //      sell copies of the Software, and to permit persons to whom the Software is
 | |
|         //      furnished to do so, subject to the following conditions:
 | |
|         //
 | |
|         //      The above copyright notice and this permission notice shall be included in
 | |
|         //      all copies or substantial portions of the Software.
 | |
|         //
 | |
|         //      THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | |
|         //      IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | |
|         //      FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | |
|         //      AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | |
|         //      LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 | |
|         //      FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
 | |
|         //      IN THE SOFTWARE.
 | |
|         if (!arg) {
 | |
|             // Need double quotation for empty argument
 | |
|             return '""';
 | |
|         }
 | |
|         if (!arg.includes(' ') && !arg.includes('\t') && !arg.includes('"')) {
 | |
|             // No quotation needed
 | |
|             return arg;
 | |
|         }
 | |
|         if (!arg.includes('"') && !arg.includes('\\')) {
 | |
|             // No embedded double quotes or backslashes, so I can just wrap
 | |
|             // quote marks around the whole thing.
 | |
|             return `"${arg}"`;
 | |
|         }
 | |
|         // Expected input/output:
 | |
|         //   input : hello"world
 | |
|         //   output: "hello\"world"
 | |
|         //   input : hello""world
 | |
|         //   output: "hello\"\"world"
 | |
|         //   input : hello\world
 | |
|         //   output: hello\world
 | |
|         //   input : hello\\world
 | |
|         //   output: hello\\world
 | |
|         //   input : hello\"world
 | |
|         //   output: "hello\\\"world"
 | |
|         //   input : hello\\"world
 | |
|         //   output: "hello\\\\\"world"
 | |
|         //   input : hello world\
 | |
|         //   output: "hello world\\" - note the comment in libuv actually reads "hello world\"
 | |
|         //                             but it appears the comment is wrong, it should be "hello world\\"
 | |
|         let reverse = '"';
 | |
|         let quoteHit = true;
 | |
|         for (let i = arg.length; i > 0; i--) {
 | |
|             // walk the string in reverse
 | |
|             reverse += arg[i - 1];
 | |
|             if (quoteHit && arg[i - 1] === '\\') {
 | |
|                 reverse += '\\';
 | |
|             }
 | |
|             else if (arg[i - 1] === '"') {
 | |
|                 quoteHit = true;
 | |
|                 reverse += '\\';
 | |
|             }
 | |
|             else {
 | |
|                 quoteHit = false;
 | |
|             }
 | |
|         }
 | |
|         reverse += '"';
 | |
|         return reverse
 | |
|             .split('')
 | |
|             .reverse()
 | |
|             .join('');
 | |
|     }
 | |
|     _cloneExecOptions(options) {
 | |
|         options = options || {};
 | |
|         const result = {
 | |
|             cwd: options.cwd || process.cwd(),
 | |
|             env: options.env || process.env,
 | |
|             silent: options.silent || false,
 | |
|             windowsVerbatimArguments: options.windowsVerbatimArguments || false,
 | |
|             failOnStdErr: options.failOnStdErr || false,
 | |
|             ignoreReturnCode: options.ignoreReturnCode || false,
 | |
|             delay: options.delay || 10000
 | |
|         };
 | |
|         result.outStream = options.outStream || process.stdout;
 | |
|         result.errStream = options.errStream || process.stderr;
 | |
|         return result;
 | |
|     }
 | |
|     _getSpawnOptions(options, toolPath) {
 | |
|         options = options || {};
 | |
|         const result = {};
 | |
|         result.cwd = options.cwd;
 | |
|         result.env = options.env;
 | |
|         result['windowsVerbatimArguments'] =
 | |
|             options.windowsVerbatimArguments || this._isCmdFile();
 | |
|         if (options.windowsVerbatimArguments) {
 | |
|             result.argv0 = `"${toolPath}"`;
 | |
|         }
 | |
|         return result;
 | |
|     }
 | |
|     /**
 | |
|      * Exec a tool.
 | |
|      * Output will be streamed to the live console.
 | |
|      * Returns promise with return code
 | |
|      *
 | |
|      * @param     tool     path to tool to exec
 | |
|      * @param     options  optional exec options.  See ExecOptions
 | |
|      * @returns   number
 | |
|      */
 | |
|     exec() {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             // root the tool path if it is unrooted and contains relative pathing
 | |
|             if (!ioUtil.isRooted(this.toolPath) &&
 | |
|                 (this.toolPath.includes('/') ||
 | |
|                     (IS_WINDOWS && this.toolPath.includes('\\')))) {
 | |
|                 // prefer options.cwd if it is specified, however options.cwd may also need to be rooted
 | |
|                 this.toolPath = path.resolve(process.cwd(), this.options.cwd || process.cwd(), this.toolPath);
 | |
|             }
 | |
|             // if the tool is only a file name, then resolve it from the PATH
 | |
|             // otherwise verify it exists (add extension on Windows if necessary)
 | |
|             this.toolPath = yield io.which(this.toolPath, true);
 | |
|             return new Promise((resolve, reject) => {
 | |
|                 this._debug(`exec tool: ${this.toolPath}`);
 | |
|                 this._debug('arguments:');
 | |
|                 for (const arg of this.args) {
 | |
|                     this._debug(`   ${arg}`);
 | |
|                 }
 | |
|                 const optionsNonNull = this._cloneExecOptions(this.options);
 | |
|                 if (!optionsNonNull.silent && optionsNonNull.outStream) {
 | |
|                     optionsNonNull.outStream.write(this._getCommandString(optionsNonNull) + os.EOL);
 | |
|                 }
 | |
|                 const state = new ExecState(optionsNonNull, this.toolPath);
 | |
|                 state.on('debug', (message) => {
 | |
|                     this._debug(message);
 | |
|                 });
 | |
|                 const fileName = this._getSpawnFileName();
 | |
|                 const cp = child.spawn(fileName, this._getSpawnArgs(optionsNonNull), this._getSpawnOptions(this.options, fileName));
 | |
|                 const stdbuffer = '';
 | |
|                 if (cp.stdout) {
 | |
|                     cp.stdout.on('data', (data) => {
 | |
|                         if (this.options.listeners && this.options.listeners.stdout) {
 | |
|                             this.options.listeners.stdout(data);
 | |
|                         }
 | |
|                         if (!optionsNonNull.silent && optionsNonNull.outStream) {
 | |
|                             optionsNonNull.outStream.write(data);
 | |
|                         }
 | |
|                         this._processLineBuffer(data, stdbuffer, (line) => {
 | |
|                             if (this.options.listeners && this.options.listeners.stdline) {
 | |
|                                 this.options.listeners.stdline(line);
 | |
|                             }
 | |
|                         });
 | |
|                     });
 | |
|                 }
 | |
|                 const errbuffer = '';
 | |
|                 if (cp.stderr) {
 | |
|                     cp.stderr.on('data', (data) => {
 | |
|                         state.processStderr = true;
 | |
|                         if (this.options.listeners && this.options.listeners.stderr) {
 | |
|                             this.options.listeners.stderr(data);
 | |
|                         }
 | |
|                         if (!optionsNonNull.silent &&
 | |
|                             optionsNonNull.errStream &&
 | |
|                             optionsNonNull.outStream) {
 | |
|                             const s = optionsNonNull.failOnStdErr
 | |
|                                 ? optionsNonNull.errStream
 | |
|                                 : optionsNonNull.outStream;
 | |
|                             s.write(data);
 | |
|                         }
 | |
|                         this._processLineBuffer(data, errbuffer, (line) => {
 | |
|                             if (this.options.listeners && this.options.listeners.errline) {
 | |
|                                 this.options.listeners.errline(line);
 | |
|                             }
 | |
|                         });
 | |
|                     });
 | |
|                 }
 | |
|                 cp.on('error', (err) => {
 | |
|                     state.processError = err.message;
 | |
|                     state.processExited = true;
 | |
|                     state.processClosed = true;
 | |
|                     state.CheckComplete();
 | |
|                 });
 | |
|                 cp.on('exit', (code) => {
 | |
|                     state.processExitCode = code;
 | |
|                     state.processExited = true;
 | |
|                     this._debug(`Exit code ${code} received from tool '${this.toolPath}'`);
 | |
|                     state.CheckComplete();
 | |
|                 });
 | |
|                 cp.on('close', (code) => {
 | |
|                     state.processExitCode = code;
 | |
|                     state.processExited = true;
 | |
|                     state.processClosed = true;
 | |
|                     this._debug(`STDIO streams have closed for tool '${this.toolPath}'`);
 | |
|                     state.CheckComplete();
 | |
|                 });
 | |
|                 state.on('done', (error, exitCode) => {
 | |
|                     if (stdbuffer.length > 0) {
 | |
|                         this.emit('stdline', stdbuffer);
 | |
|                     }
 | |
|                     if (errbuffer.length > 0) {
 | |
|                         this.emit('errline', errbuffer);
 | |
|                     }
 | |
|                     cp.removeAllListeners();
 | |
|                     if (error) {
 | |
|                         reject(error);
 | |
|                     }
 | |
|                     else {
 | |
|                         resolve(exitCode);
 | |
|                     }
 | |
|                 });
 | |
|             });
 | |
|         });
 | |
|     }
 | |
| }
 | |
| exports.ToolRunner = ToolRunner;
 | |
| /**
 | |
|  * Convert an arg string to an array of args. Handles escaping
 | |
|  *
 | |
|  * @param    argString   string of arguments
 | |
|  * @returns  string[]    array of arguments
 | |
|  */
 | |
| function argStringToArray(argString) {
 | |
|     const args = [];
 | |
|     let inQuotes = false;
 | |
|     let escaped = false;
 | |
|     let arg = '';
 | |
|     function append(c) {
 | |
|         // we only escape double quotes.
 | |
|         if (escaped && c !== '"') {
 | |
|             arg += '\\';
 | |
|         }
 | |
|         arg += c;
 | |
|         escaped = false;
 | |
|     }
 | |
|     for (let i = 0; i < argString.length; i++) {
 | |
|         const c = argString.charAt(i);
 | |
|         if (c === '"') {
 | |
|             if (!escaped) {
 | |
|                 inQuotes = !inQuotes;
 | |
|             }
 | |
|             else {
 | |
|                 append(c);
 | |
|             }
 | |
|             continue;
 | |
|         }
 | |
|         if (c === '\\' && escaped) {
 | |
|             append(c);
 | |
|             continue;
 | |
|         }
 | |
|         if (c === '\\' && inQuotes) {
 | |
|             escaped = true;
 | |
|             continue;
 | |
|         }
 | |
|         if (c === ' ' && !inQuotes) {
 | |
|             if (arg.length > 0) {
 | |
|                 args.push(arg);
 | |
|                 arg = '';
 | |
|             }
 | |
|             continue;
 | |
|         }
 | |
|         append(c);
 | |
|     }
 | |
|     if (arg.length > 0) {
 | |
|         args.push(arg.trim());
 | |
|     }
 | |
|     return args;
 | |
| }
 | |
| exports.argStringToArray = argStringToArray;
 | |
| class ExecState extends events.EventEmitter {
 | |
|     constructor(options, toolPath) {
 | |
|         super();
 | |
|         this.processClosed = false; // tracks whether the process has exited and stdio is closed
 | |
|         this.processError = '';
 | |
|         this.processExitCode = 0;
 | |
|         this.processExited = false; // tracks whether the process has exited
 | |
|         this.processStderr = false; // tracks whether stderr was written to
 | |
|         this.delay = 10000; // 10 seconds
 | |
|         this.done = false;
 | |
|         this.timeout = null;
 | |
|         if (!toolPath) {
 | |
|             throw new Error('toolPath must not be empty');
 | |
|         }
 | |
|         this.options = options;
 | |
|         this.toolPath = toolPath;
 | |
|         if (options.delay) {
 | |
|             this.delay = options.delay;
 | |
|         }
 | |
|     }
 | |
|     CheckComplete() {
 | |
|         if (this.done) {
 | |
|             return;
 | |
|         }
 | |
|         if (this.processClosed) {
 | |
|             this._setResult();
 | |
|         }
 | |
|         else if (this.processExited) {
 | |
|             this.timeout = setTimeout(ExecState.HandleTimeout, this.delay, this);
 | |
|         }
 | |
|     }
 | |
|     _debug(message) {
 | |
|         this.emit('debug', message);
 | |
|     }
 | |
|     _setResult() {
 | |
|         // determine whether there is an error
 | |
|         let error;
 | |
|         if (this.processExited) {
 | |
|             if (this.processError) {
 | |
|                 error = new Error(`There was an error when attempting to execute the process '${this.toolPath}'. This may indicate the process failed to start. Error: ${this.processError}`);
 | |
|             }
 | |
|             else if (this.processExitCode !== 0 && !this.options.ignoreReturnCode) {
 | |
|                 error = new Error(`The process '${this.toolPath}' failed with exit code ${this.processExitCode}`);
 | |
|             }
 | |
|             else if (this.processStderr && this.options.failOnStdErr) {
 | |
|                 error = new Error(`The process '${this.toolPath}' failed because one or more lines were written to the STDERR stream`);
 | |
|             }
 | |
|         }
 | |
|         // clear the timeout
 | |
|         if (this.timeout) {
 | |
|             clearTimeout(this.timeout);
 | |
|             this.timeout = null;
 | |
|         }
 | |
|         this.done = true;
 | |
|         this.emit('done', error, this.processExitCode);
 | |
|     }
 | |
|     static HandleTimeout(state) {
 | |
|         if (state.done) {
 | |
|             return;
 | |
|         }
 | |
|         if (!state.processClosed && state.processExited) {
 | |
|             const message = `The STDIO streams did not close within ${state.delay /
 | |
|                 1000} seconds of the exit event from process '${state.toolPath}'. This may indicate a child process inherited the STDIO streams and has not yet exited.`;
 | |
|             state._debug(message);
 | |
|         }
 | |
|         state._setResult();
 | |
|     }
 | |
| }
 | |
| //# sourceMappingURL=toolrunner.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 16:
 | |
| /***/ (function(module) {
 | |
| 
 | |
| module.exports = require("tls");
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 25:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| Object.defineProperty(exports, "v1", {
 | |
|   enumerable: true,
 | |
|   get: function () {
 | |
|     return _v.default;
 | |
|   }
 | |
| });
 | |
| Object.defineProperty(exports, "v3", {
 | |
|   enumerable: true,
 | |
|   get: function () {
 | |
|     return _v2.default;
 | |
|   }
 | |
| });
 | |
| Object.defineProperty(exports, "v4", {
 | |
|   enumerable: true,
 | |
|   get: function () {
 | |
|     return _v3.default;
 | |
|   }
 | |
| });
 | |
| Object.defineProperty(exports, "v5", {
 | |
|   enumerable: true,
 | |
|   get: function () {
 | |
|     return _v4.default;
 | |
|   }
 | |
| });
 | |
| Object.defineProperty(exports, "NIL", {
 | |
|   enumerable: true,
 | |
|   get: function () {
 | |
|     return _nil.default;
 | |
|   }
 | |
| });
 | |
| Object.defineProperty(exports, "version", {
 | |
|   enumerable: true,
 | |
|   get: function () {
 | |
|     return _version.default;
 | |
|   }
 | |
| });
 | |
| Object.defineProperty(exports, "validate", {
 | |
|   enumerable: true,
 | |
|   get: function () {
 | |
|     return _validate.default;
 | |
|   }
 | |
| });
 | |
| Object.defineProperty(exports, "stringify", {
 | |
|   enumerable: true,
 | |
|   get: function () {
 | |
|     return _stringify.default;
 | |
|   }
 | |
| });
 | |
| Object.defineProperty(exports, "parse", {
 | |
|   enumerable: true,
 | |
|   get: function () {
 | |
|     return _parse.default;
 | |
|   }
 | |
| });
 | |
| 
 | |
| var _v = _interopRequireDefault(__webpack_require__(810));
 | |
| 
 | |
| var _v2 = _interopRequireDefault(__webpack_require__(572));
 | |
| 
 | |
| var _v3 = _interopRequireDefault(__webpack_require__(293));
 | |
| 
 | |
| var _v4 = _interopRequireDefault(__webpack_require__(638));
 | |
| 
 | |
| var _nil = _interopRequireDefault(__webpack_require__(4));
 | |
| 
 | |
| var _version = _interopRequireDefault(__webpack_require__(135));
 | |
| 
 | |
| var _validate = _interopRequireDefault(__webpack_require__(634));
 | |
| 
 | |
| var _stringify = _interopRequireDefault(__webpack_require__(960));
 | |
| 
 | |
| var _parse = _interopRequireDefault(__webpack_require__(204));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 82:
 | |
| /***/ (function(__unusedmodule, exports) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| // We use any as a valid input type
 | |
| /* eslint-disable @typescript-eslint/no-explicit-any */
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.toCommandProperties = exports.toCommandValue = void 0;
 | |
| /**
 | |
|  * Sanitizes an input into a string so it can be passed into issueCommand safely
 | |
|  * @param input input to sanitize into a string
 | |
|  */
 | |
| function toCommandValue(input) {
 | |
|     if (input === null || input === undefined) {
 | |
|         return '';
 | |
|     }
 | |
|     else if (typeof input === 'string' || input instanceof String) {
 | |
|         return input;
 | |
|     }
 | |
|     return JSON.stringify(input);
 | |
| }
 | |
| exports.toCommandValue = toCommandValue;
 | |
| /**
 | |
|  *
 | |
|  * @param annotationProperties
 | |
|  * @returns The command properties to send with the actual annotation command
 | |
|  * See IssueCommandProperties: https://github.com/actions/runner/blob/main/src/Runner.Worker/ActionCommandManager.cs#L646
 | |
|  */
 | |
| function toCommandProperties(annotationProperties) {
 | |
|     if (!Object.keys(annotationProperties).length) {
 | |
|         return {};
 | |
|     }
 | |
|     return {
 | |
|         title: annotationProperties.title,
 | |
|         file: annotationProperties.file,
 | |
|         line: annotationProperties.startLine,
 | |
|         endLine: annotationProperties.endLine,
 | |
|         col: annotationProperties.startColumn,
 | |
|         endColumn: annotationProperties.endColumn
 | |
|     };
 | |
| }
 | |
| exports.toCommandProperties = toCommandProperties;
 | |
| //# sourceMappingURL=utils.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 87:
 | |
| /***/ (function(module) {
 | |
| 
 | |
| module.exports = require("os");
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 95:
 | |
| /***/ (function(__unusedmodule, exports) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.checkBypass = exports.getProxyUrl = void 0;
 | |
| function getProxyUrl(reqUrl) {
 | |
|     const usingSsl = reqUrl.protocol === 'https:';
 | |
|     if (checkBypass(reqUrl)) {
 | |
|         return undefined;
 | |
|     }
 | |
|     const proxyVar = (() => {
 | |
|         if (usingSsl) {
 | |
|             return process.env['https_proxy'] || process.env['HTTPS_PROXY'];
 | |
|         }
 | |
|         else {
 | |
|             return process.env['http_proxy'] || process.env['HTTP_PROXY'];
 | |
|         }
 | |
|     })();
 | |
|     if (proxyVar) {
 | |
|         return new URL(proxyVar);
 | |
|     }
 | |
|     else {
 | |
|         return undefined;
 | |
|     }
 | |
| }
 | |
| exports.getProxyUrl = getProxyUrl;
 | |
| function checkBypass(reqUrl) {
 | |
|     if (!reqUrl.hostname) {
 | |
|         return false;
 | |
|     }
 | |
|     const reqHost = reqUrl.hostname;
 | |
|     if (isLoopbackAddress(reqHost)) {
 | |
|         return true;
 | |
|     }
 | |
|     const noProxy = process.env['no_proxy'] || process.env['NO_PROXY'] || '';
 | |
|     if (!noProxy) {
 | |
|         return false;
 | |
|     }
 | |
|     // Determine the request port
 | |
|     let reqPort;
 | |
|     if (reqUrl.port) {
 | |
|         reqPort = Number(reqUrl.port);
 | |
|     }
 | |
|     else if (reqUrl.protocol === 'http:') {
 | |
|         reqPort = 80;
 | |
|     }
 | |
|     else if (reqUrl.protocol === 'https:') {
 | |
|         reqPort = 443;
 | |
|     }
 | |
|     // Format the request hostname and hostname with port
 | |
|     const upperReqHosts = [reqUrl.hostname.toUpperCase()];
 | |
|     if (typeof reqPort === 'number') {
 | |
|         upperReqHosts.push(`${upperReqHosts[0]}:${reqPort}`);
 | |
|     }
 | |
|     // Compare request host against noproxy
 | |
|     for (const upperNoProxyItem of noProxy
 | |
|         .split(',')
 | |
|         .map(x => x.trim().toUpperCase())
 | |
|         .filter(x => x)) {
 | |
|         if (upperNoProxyItem === '*' ||
 | |
|             upperReqHosts.some(x => x === upperNoProxyItem ||
 | |
|                 x.endsWith(`.${upperNoProxyItem}`) ||
 | |
|                 (upperNoProxyItem.startsWith('.') &&
 | |
|                     x.endsWith(`${upperNoProxyItem}`)))) {
 | |
|             return true;
 | |
|         }
 | |
|     }
 | |
|     return false;
 | |
| }
 | |
| exports.checkBypass = checkBypass;
 | |
| function isLoopbackAddress(host) {
 | |
|     const hostLower = host.toLowerCase();
 | |
|     return (hostLower === 'localhost' ||
 | |
|         hostLower.startsWith('127.') ||
 | |
|         hostLower.startsWith('[::1]') ||
 | |
|         hostLower.startsWith('[0:0:0:0:0:0:0:1]'));
 | |
| }
 | |
| //# sourceMappingURL=proxy.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 102:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| // For internal use, subject to change.
 | |
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
 | |
|     if (k2 === undefined) k2 = k;
 | |
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
 | |
| }) : (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.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
 | |
|     __setModuleDefault(result, mod);
 | |
|     return result;
 | |
| };
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.prepareKeyValueMessage = exports.issueFileCommand = void 0;
 | |
| // We use any as a valid input type
 | |
| /* eslint-disable @typescript-eslint/no-explicit-any */
 | |
| const fs = __importStar(__webpack_require__(747));
 | |
| const os = __importStar(__webpack_require__(87));
 | |
| const uuid_1 = __webpack_require__(25);
 | |
| const utils_1 = __webpack_require__(82);
 | |
| function issueFileCommand(command, message) {
 | |
|     const filePath = process.env[`GITHUB_${command}`];
 | |
|     if (!filePath) {
 | |
|         throw new Error(`Unable to find environment variable for file command ${command}`);
 | |
|     }
 | |
|     if (!fs.existsSync(filePath)) {
 | |
|         throw new Error(`Missing file at path: ${filePath}`);
 | |
|     }
 | |
|     fs.appendFileSync(filePath, `${utils_1.toCommandValue(message)}${os.EOL}`, {
 | |
|         encoding: 'utf8'
 | |
|     });
 | |
| }
 | |
| exports.issueFileCommand = issueFileCommand;
 | |
| function prepareKeyValueMessage(key, value) {
 | |
|     const delimiter = `ghadelimiter_${uuid_1.v4()}`;
 | |
|     const convertedValue = utils_1.toCommandValue(value);
 | |
|     // These should realistically never happen, but just in case someone finds a
 | |
|     // way to exploit uuid generation let's not allow keys or values that contain
 | |
|     // the delimiter.
 | |
|     if (key.includes(delimiter)) {
 | |
|         throw new Error(`Unexpected input: name should not contain the delimiter "${delimiter}"`);
 | |
|     }
 | |
|     if (convertedValue.includes(delimiter)) {
 | |
|         throw new Error(`Unexpected input: value should not contain the delimiter "${delimiter}"`);
 | |
|     }
 | |
|     return `${key}<<${delimiter}${os.EOL}${convertedValue}${os.EOL}${delimiter}`;
 | |
| }
 | |
| exports.prepareKeyValueMessage = prepareKeyValueMessage;
 | |
| //# sourceMappingURL=file-command.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 129:
 | |
| /***/ (function(module) {
 | |
| 
 | |
| module.exports = require("child_process");
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 135:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| 
 | |
| var _validate = _interopRequireDefault(__webpack_require__(634));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| function version(uuid) {
 | |
|   if (!(0, _validate.default)(uuid)) {
 | |
|     throw TypeError('Invalid UUID');
 | |
|   }
 | |
| 
 | |
|   return parseInt(uuid.substr(14, 1), 16);
 | |
| }
 | |
| 
 | |
| var _default = version;
 | |
| exports.default = _default;
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 136:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = _default;
 | |
| exports.URL = exports.DNS = void 0;
 | |
| 
 | |
| var _stringify = _interopRequireDefault(__webpack_require__(960));
 | |
| 
 | |
| var _parse = _interopRequireDefault(__webpack_require__(204));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| function stringToBytes(str) {
 | |
|   str = unescape(encodeURIComponent(str)); // UTF8 escape
 | |
| 
 | |
|   const bytes = [];
 | |
| 
 | |
|   for (let i = 0; i < str.length; ++i) {
 | |
|     bytes.push(str.charCodeAt(i));
 | |
|   }
 | |
| 
 | |
|   return bytes;
 | |
| }
 | |
| 
 | |
| const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';
 | |
| exports.DNS = DNS;
 | |
| const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';
 | |
| exports.URL = URL;
 | |
| 
 | |
| function _default(name, version, hashfunc) {
 | |
|   function generateUUID(value, namespace, buf, offset) {
 | |
|     if (typeof value === 'string') {
 | |
|       value = stringToBytes(value);
 | |
|     }
 | |
| 
 | |
|     if (typeof namespace === 'string') {
 | |
|       namespace = (0, _parse.default)(namespace);
 | |
|     }
 | |
| 
 | |
|     if (namespace.length !== 16) {
 | |
|       throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');
 | |
|     } // Compute hash of namespace and value, Per 4.3
 | |
|     // Future: Use spread syntax when supported on all platforms, e.g. `bytes =
 | |
|     // hashfunc([...namespace, ... value])`
 | |
| 
 | |
| 
 | |
|     let bytes = new Uint8Array(16 + value.length);
 | |
|     bytes.set(namespace);
 | |
|     bytes.set(value, namespace.length);
 | |
|     bytes = hashfunc(bytes);
 | |
|     bytes[6] = bytes[6] & 0x0f | version;
 | |
|     bytes[8] = bytes[8] & 0x3f | 0x80;
 | |
| 
 | |
|     if (buf) {
 | |
|       offset = offset || 0;
 | |
| 
 | |
|       for (let i = 0; i < 16; ++i) {
 | |
|         buf[offset + i] = bytes[i];
 | |
|       }
 | |
| 
 | |
|       return buf;
 | |
|     }
 | |
| 
 | |
|     return (0, _stringify.default)(bytes);
 | |
|   } // Function#name is not settable on some platforms (#270)
 | |
| 
 | |
| 
 | |
|   try {
 | |
|     generateUUID.name = name; // eslint-disable-next-line no-empty
 | |
|   } catch (err) {} // For CommonJS default export support
 | |
| 
 | |
| 
 | |
|   generateUUID.DNS = DNS;
 | |
|   generateUUID.URL = URL;
 | |
|   return generateUUID;
 | |
| }
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 141:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| var net = __webpack_require__(631);
 | |
| var tls = __webpack_require__(16);
 | |
| var http = __webpack_require__(605);
 | |
| var https = __webpack_require__(211);
 | |
| var events = __webpack_require__(614);
 | |
| var assert = __webpack_require__(357);
 | |
| var util = __webpack_require__(669);
 | |
| 
 | |
| 
 | |
| exports.httpOverHttp = httpOverHttp;
 | |
| exports.httpsOverHttp = httpsOverHttp;
 | |
| exports.httpOverHttps = httpOverHttps;
 | |
| exports.httpsOverHttps = httpsOverHttps;
 | |
| 
 | |
| 
 | |
| function httpOverHttp(options) {
 | |
|   var agent = new TunnelingAgent(options);
 | |
|   agent.request = http.request;
 | |
|   return agent;
 | |
| }
 | |
| 
 | |
| function httpsOverHttp(options) {
 | |
|   var agent = new TunnelingAgent(options);
 | |
|   agent.request = http.request;
 | |
|   agent.createSocket = createSecureSocket;
 | |
|   agent.defaultPort = 443;
 | |
|   return agent;
 | |
| }
 | |
| 
 | |
| function httpOverHttps(options) {
 | |
|   var agent = new TunnelingAgent(options);
 | |
|   agent.request = https.request;
 | |
|   return agent;
 | |
| }
 | |
| 
 | |
| function httpsOverHttps(options) {
 | |
|   var agent = new TunnelingAgent(options);
 | |
|   agent.request = https.request;
 | |
|   agent.createSocket = createSecureSocket;
 | |
|   agent.defaultPort = 443;
 | |
|   return agent;
 | |
| }
 | |
| 
 | |
| 
 | |
| function TunnelingAgent(options) {
 | |
|   var self = this;
 | |
|   self.options = options || {};
 | |
|   self.proxyOptions = self.options.proxy || {};
 | |
|   self.maxSockets = self.options.maxSockets || http.Agent.defaultMaxSockets;
 | |
|   self.requests = [];
 | |
|   self.sockets = [];
 | |
| 
 | |
|   self.on('free', function onFree(socket, host, port, localAddress) {
 | |
|     var options = toOptions(host, port, localAddress);
 | |
|     for (var i = 0, len = self.requests.length; i < len; ++i) {
 | |
|       var pending = self.requests[i];
 | |
|       if (pending.host === options.host && pending.port === options.port) {
 | |
|         // Detect the request to connect same origin server,
 | |
|         // reuse the connection.
 | |
|         self.requests.splice(i, 1);
 | |
|         pending.request.onSocket(socket);
 | |
|         return;
 | |
|       }
 | |
|     }
 | |
|     socket.destroy();
 | |
|     self.removeSocket(socket);
 | |
|   });
 | |
| }
 | |
| util.inherits(TunnelingAgent, events.EventEmitter);
 | |
| 
 | |
| TunnelingAgent.prototype.addRequest = function addRequest(req, host, port, localAddress) {
 | |
|   var self = this;
 | |
|   var options = mergeOptions({request: req}, self.options, toOptions(host, port, localAddress));
 | |
| 
 | |
|   if (self.sockets.length >= this.maxSockets) {
 | |
|     // We are over limit so we'll add it to the queue.
 | |
|     self.requests.push(options);
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   // If we are under maxSockets create a new one.
 | |
|   self.createSocket(options, function(socket) {
 | |
|     socket.on('free', onFree);
 | |
|     socket.on('close', onCloseOrRemove);
 | |
|     socket.on('agentRemove', onCloseOrRemove);
 | |
|     req.onSocket(socket);
 | |
| 
 | |
|     function onFree() {
 | |
|       self.emit('free', socket, options);
 | |
|     }
 | |
| 
 | |
|     function onCloseOrRemove(err) {
 | |
|       self.removeSocket(socket);
 | |
|       socket.removeListener('free', onFree);
 | |
|       socket.removeListener('close', onCloseOrRemove);
 | |
|       socket.removeListener('agentRemove', onCloseOrRemove);
 | |
|     }
 | |
|   });
 | |
| };
 | |
| 
 | |
| TunnelingAgent.prototype.createSocket = function createSocket(options, cb) {
 | |
|   var self = this;
 | |
|   var placeholder = {};
 | |
|   self.sockets.push(placeholder);
 | |
| 
 | |
|   var connectOptions = mergeOptions({}, self.proxyOptions, {
 | |
|     method: 'CONNECT',
 | |
|     path: options.host + ':' + options.port,
 | |
|     agent: false,
 | |
|     headers: {
 | |
|       host: options.host + ':' + options.port
 | |
|     }
 | |
|   });
 | |
|   if (options.localAddress) {
 | |
|     connectOptions.localAddress = options.localAddress;
 | |
|   }
 | |
|   if (connectOptions.proxyAuth) {
 | |
|     connectOptions.headers = connectOptions.headers || {};
 | |
|     connectOptions.headers['Proxy-Authorization'] = 'Basic ' +
 | |
|         new Buffer(connectOptions.proxyAuth).toString('base64');
 | |
|   }
 | |
| 
 | |
|   debug('making CONNECT request');
 | |
|   var connectReq = self.request(connectOptions);
 | |
|   connectReq.useChunkedEncodingByDefault = false; // for v0.6
 | |
|   connectReq.once('response', onResponse); // for v0.6
 | |
|   connectReq.once('upgrade', onUpgrade);   // for v0.6
 | |
|   connectReq.once('connect', onConnect);   // for v0.7 or later
 | |
|   connectReq.once('error', onError);
 | |
|   connectReq.end();
 | |
| 
 | |
|   function onResponse(res) {
 | |
|     // Very hacky. This is necessary to avoid http-parser leaks.
 | |
|     res.upgrade = true;
 | |
|   }
 | |
| 
 | |
|   function onUpgrade(res, socket, head) {
 | |
|     // Hacky.
 | |
|     process.nextTick(function() {
 | |
|       onConnect(res, socket, head);
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   function onConnect(res, socket, head) {
 | |
|     connectReq.removeAllListeners();
 | |
|     socket.removeAllListeners();
 | |
| 
 | |
|     if (res.statusCode !== 200) {
 | |
|       debug('tunneling socket could not be established, statusCode=%d',
 | |
|         res.statusCode);
 | |
|       socket.destroy();
 | |
|       var error = new Error('tunneling socket could not be established, ' +
 | |
|         'statusCode=' + res.statusCode);
 | |
|       error.code = 'ECONNRESET';
 | |
|       options.request.emit('error', error);
 | |
|       self.removeSocket(placeholder);
 | |
|       return;
 | |
|     }
 | |
|     if (head.length > 0) {
 | |
|       debug('got illegal response body from proxy');
 | |
|       socket.destroy();
 | |
|       var error = new Error('got illegal response body from proxy');
 | |
|       error.code = 'ECONNRESET';
 | |
|       options.request.emit('error', error);
 | |
|       self.removeSocket(placeholder);
 | |
|       return;
 | |
|     }
 | |
|     debug('tunneling connection has established');
 | |
|     self.sockets[self.sockets.indexOf(placeholder)] = socket;
 | |
|     return cb(socket);
 | |
|   }
 | |
| 
 | |
|   function onError(cause) {
 | |
|     connectReq.removeAllListeners();
 | |
| 
 | |
|     debug('tunneling socket could not be established, cause=%s\n',
 | |
|           cause.message, cause.stack);
 | |
|     var error = new Error('tunneling socket could not be established, ' +
 | |
|                           'cause=' + cause.message);
 | |
|     error.code = 'ECONNRESET';
 | |
|     options.request.emit('error', error);
 | |
|     self.removeSocket(placeholder);
 | |
|   }
 | |
| };
 | |
| 
 | |
| TunnelingAgent.prototype.removeSocket = function removeSocket(socket) {
 | |
|   var pos = this.sockets.indexOf(socket)
 | |
|   if (pos === -1) {
 | |
|     return;
 | |
|   }
 | |
|   this.sockets.splice(pos, 1);
 | |
| 
 | |
|   var pending = this.requests.shift();
 | |
|   if (pending) {
 | |
|     // If we have pending requests and a socket gets closed a new one
 | |
|     // needs to be created to take over in the pool for the one that closed.
 | |
|     this.createSocket(pending, function(socket) {
 | |
|       pending.request.onSocket(socket);
 | |
|     });
 | |
|   }
 | |
| };
 | |
| 
 | |
| function createSecureSocket(options, cb) {
 | |
|   var self = this;
 | |
|   TunnelingAgent.prototype.createSocket.call(self, options, function(socket) {
 | |
|     var hostHeader = options.request.getHeader('host');
 | |
|     var tlsOptions = mergeOptions({}, self.options, {
 | |
|       socket: socket,
 | |
|       servername: hostHeader ? hostHeader.replace(/:.*$/, '') : options.host
 | |
|     });
 | |
| 
 | |
|     // 0 is dummy port for v0.6
 | |
|     var secureSocket = tls.connect(0, tlsOptions);
 | |
|     self.sockets[self.sockets.indexOf(socket)] = secureSocket;
 | |
|     cb(secureSocket);
 | |
|   });
 | |
| }
 | |
| 
 | |
| 
 | |
| function toOptions(host, port, localAddress) {
 | |
|   if (typeof host === 'string') { // since v0.10
 | |
|     return {
 | |
|       host: host,
 | |
|       port: port,
 | |
|       localAddress: localAddress
 | |
|     };
 | |
|   }
 | |
|   return host; // for v0.11 or later
 | |
| }
 | |
| 
 | |
| function mergeOptions(target) {
 | |
|   for (var i = 1, len = arguments.length; i < len; ++i) {
 | |
|     var overrides = arguments[i];
 | |
|     if (typeof overrides === 'object') {
 | |
|       var keys = Object.keys(overrides);
 | |
|       for (var j = 0, keyLen = keys.length; j < keyLen; ++j) {
 | |
|         var k = keys[j];
 | |
|         if (overrides[k] !== undefined) {
 | |
|           target[k] = overrides[k];
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
|   return target;
 | |
| }
 | |
| 
 | |
| 
 | |
| var debug;
 | |
| if (process.env.NODE_DEBUG && /\btunnel\b/.test(process.env.NODE_DEBUG)) {
 | |
|   debug = function() {
 | |
|     var args = Array.prototype.slice.call(arguments);
 | |
|     if (typeof args[0] === 'string') {
 | |
|       args[0] = 'TUNNEL: ' + args[0];
 | |
|     } else {
 | |
|       args.unshift('TUNNEL:');
 | |
|     }
 | |
|     console.error.apply(console, args);
 | |
|   }
 | |
| } else {
 | |
|   debug = function() {};
 | |
| }
 | |
| exports.debug = debug; // for test
 | |
| 
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 204:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| 
 | |
| var _validate = _interopRequireDefault(__webpack_require__(634));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| function parse(uuid) {
 | |
|   if (!(0, _validate.default)(uuid)) {
 | |
|     throw TypeError('Invalid UUID');
 | |
|   }
 | |
| 
 | |
|   let v;
 | |
|   const arr = new Uint8Array(16); // Parse ########-....-....-....-............
 | |
| 
 | |
|   arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;
 | |
|   arr[1] = v >>> 16 & 0xff;
 | |
|   arr[2] = v >>> 8 & 0xff;
 | |
|   arr[3] = v & 0xff; // Parse ........-####-....-....-............
 | |
| 
 | |
|   arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;
 | |
|   arr[5] = v & 0xff; // Parse ........-....-####-....-............
 | |
| 
 | |
|   arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;
 | |
|   arr[7] = v & 0xff; // Parse ........-....-....-####-............
 | |
| 
 | |
|   arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;
 | |
|   arr[9] = v & 0xff; // Parse ........-....-....-....-############
 | |
|   // (Use "/" to avoid 32-bit truncation when bit-shifting high-order bytes)
 | |
| 
 | |
|   arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;
 | |
|   arr[11] = v / 0x100000000 & 0xff;
 | |
|   arr[12] = v >>> 24 & 0xff;
 | |
|   arr[13] = v >>> 16 & 0xff;
 | |
|   arr[14] = v >>> 8 & 0xff;
 | |
|   arr[15] = v & 0xff;
 | |
|   return arr;
 | |
| }
 | |
| 
 | |
| var _default = parse;
 | |
| exports.default = _default;
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 211:
 | |
| /***/ (function(module) {
 | |
| 
 | |
| module.exports = require("https");
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 219:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
 | |
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
 | |
|     return new (P || (P = Promise))(function (resolve, reject) {
 | |
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
 | |
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
 | |
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
 | |
|         step((generator = generator.apply(thisArg, _arguments || [])).next());
 | |
|     });
 | |
| };
 | |
| 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 });
 | |
| const core = __importStar(__webpack_require__(470));
 | |
| const gpg = __importStar(__webpack_require__(884));
 | |
| const constants = __importStar(__webpack_require__(694));
 | |
| function run() {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         if (core.getInput(constants.INPUT_GPG_PRIVATE_KEY, { required: false })) {
 | |
|             core.info('removing private key from keychain');
 | |
|             try {
 | |
|                 const keyFingerprint = core.getState(constants.STATE_GPG_PRIVATE_KEY_FINGERPRINT);
 | |
|                 yield gpg.deleteKey(keyFingerprint);
 | |
|             }
 | |
|             catch (error) {
 | |
|                 core.setFailed('failed to remove private key');
 | |
|             }
 | |
|         }
 | |
|     });
 | |
| }
 | |
| run();
 | |
| 
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 293:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| 
 | |
| var _rng = _interopRequireDefault(__webpack_require__(506));
 | |
| 
 | |
| var _stringify = _interopRequireDefault(__webpack_require__(960));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| function v4(options, buf, offset) {
 | |
|   options = options || {};
 | |
| 
 | |
|   const rnds = options.random || (options.rng || _rng.default)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`
 | |
| 
 | |
| 
 | |
|   rnds[6] = rnds[6] & 0x0f | 0x40;
 | |
|   rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided
 | |
| 
 | |
|   if (buf) {
 | |
|     offset = offset || 0;
 | |
| 
 | |
|     for (let i = 0; i < 16; ++i) {
 | |
|       buf[offset + i] = rnds[i];
 | |
|     }
 | |
| 
 | |
|     return buf;
 | |
|   }
 | |
| 
 | |
|   return (0, _stringify.default)(rnds);
 | |
| }
 | |
| 
 | |
| var _default = v4;
 | |
| exports.default = _default;
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 322:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "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 });
 | |
| const path = __importStar(__webpack_require__(622));
 | |
| function getTempDir() {
 | |
|     let tempDirectory = process.env.RUNNER_TEMP;
 | |
|     if (tempDirectory === undefined) {
 | |
|         let baseLocation;
 | |
|         if (isWindows()) {
 | |
|             // On windows use the USERPROFILE env variable
 | |
|             baseLocation = process.env['USERPROFILE']
 | |
|                 ? process.env['USERPROFILE']
 | |
|                 : 'C:\\';
 | |
|         }
 | |
|         else {
 | |
|             if (process.platform === 'darwin') {
 | |
|                 baseLocation = '/Users';
 | |
|             }
 | |
|             else {
 | |
|                 baseLocation = '/home';
 | |
|             }
 | |
|         }
 | |
|         tempDirectory = path.join(baseLocation, 'actions', 'temp');
 | |
|     }
 | |
|     return tempDirectory;
 | |
| }
 | |
| exports.getTempDir = getTempDir;
 | |
| function isWindows() {
 | |
|     return process.platform === 'win32';
 | |
| }
 | |
| exports.isWindows = isWindows;
 | |
| 
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 329:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| 
 | |
| var _crypto = _interopRequireDefault(__webpack_require__(417));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| function sha1(bytes) {
 | |
|   if (Array.isArray(bytes)) {
 | |
|     bytes = Buffer.from(bytes);
 | |
|   } else if (typeof bytes === 'string') {
 | |
|     bytes = Buffer.from(bytes, 'utf8');
 | |
|   }
 | |
| 
 | |
|   return _crypto.default.createHash('sha1').update(bytes).digest();
 | |
| }
 | |
| 
 | |
| var _default = sha1;
 | |
| exports.default = _default;
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 357:
 | |
| /***/ (function(module) {
 | |
| 
 | |
| module.exports = require("assert");
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 363:
 | |
| /***/ (function(__unusedmodule, exports) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
 | |
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
 | |
|     return new (P || (P = Promise))(function (resolve, reject) {
 | |
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
 | |
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
 | |
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
 | |
|         step((generator = generator.apply(thisArg, _arguments || [])).next());
 | |
|     });
 | |
| };
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.PersonalAccessTokenCredentialHandler = exports.BearerCredentialHandler = exports.BasicCredentialHandler = void 0;
 | |
| class BasicCredentialHandler {
 | |
|     constructor(username, password) {
 | |
|         this.username = username;
 | |
|         this.password = password;
 | |
|     }
 | |
|     prepareRequest(options) {
 | |
|         if (!options.headers) {
 | |
|             throw Error('The request has no headers');
 | |
|         }
 | |
|         options.headers['Authorization'] = `Basic ${Buffer.from(`${this.username}:${this.password}`).toString('base64')}`;
 | |
|     }
 | |
|     // This handler cannot handle 401
 | |
|     canHandleAuthentication() {
 | |
|         return false;
 | |
|     }
 | |
|     handleAuthentication() {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             throw new Error('not implemented');
 | |
|         });
 | |
|     }
 | |
| }
 | |
| exports.BasicCredentialHandler = BasicCredentialHandler;
 | |
| class BearerCredentialHandler {
 | |
|     constructor(token) {
 | |
|         this.token = token;
 | |
|     }
 | |
|     // currently implements pre-authorization
 | |
|     // TODO: support preAuth = false where it hooks on 401
 | |
|     prepareRequest(options) {
 | |
|         if (!options.headers) {
 | |
|             throw Error('The request has no headers');
 | |
|         }
 | |
|         options.headers['Authorization'] = `Bearer ${this.token}`;
 | |
|     }
 | |
|     // This handler cannot handle 401
 | |
|     canHandleAuthentication() {
 | |
|         return false;
 | |
|     }
 | |
|     handleAuthentication() {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             throw new Error('not implemented');
 | |
|         });
 | |
|     }
 | |
| }
 | |
| exports.BearerCredentialHandler = BearerCredentialHandler;
 | |
| class PersonalAccessTokenCredentialHandler {
 | |
|     constructor(token) {
 | |
|         this.token = token;
 | |
|     }
 | |
|     // currently implements pre-authorization
 | |
|     // TODO: support preAuth = false where it hooks on 401
 | |
|     prepareRequest(options) {
 | |
|         if (!options.headers) {
 | |
|             throw Error('The request has no headers');
 | |
|         }
 | |
|         options.headers['Authorization'] = `Basic ${Buffer.from(`PAT:${this.token}`).toString('base64')}`;
 | |
|     }
 | |
|     // This handler cannot handle 401
 | |
|     canHandleAuthentication() {
 | |
|         return false;
 | |
|     }
 | |
|     handleAuthentication() {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             throw new Error('not implemented');
 | |
|         });
 | |
|     }
 | |
| }
 | |
| exports.PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHandler;
 | |
| //# sourceMappingURL=auth.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 413:
 | |
| /***/ (function(module, __unusedexports, __webpack_require__) {
 | |
| 
 | |
| module.exports = __webpack_require__(141);
 | |
| 
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 417:
 | |
| /***/ (function(module) {
 | |
| 
 | |
| module.exports = require("crypto");
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 431:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
 | |
|     if (k2 === undefined) k2 = k;
 | |
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
 | |
| }) : (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.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
 | |
|     __setModuleDefault(result, mod);
 | |
|     return result;
 | |
| };
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.issue = exports.issueCommand = void 0;
 | |
| const os = __importStar(__webpack_require__(87));
 | |
| const utils_1 = __webpack_require__(82);
 | |
| /**
 | |
|  * Commands
 | |
|  *
 | |
|  * Command Format:
 | |
|  *   ::name key=value,key=value::message
 | |
|  *
 | |
|  * Examples:
 | |
|  *   ::warning::This is the message
 | |
|  *   ::set-env name=MY_VAR::some value
 | |
|  */
 | |
| function issueCommand(command, properties, message) {
 | |
|     const cmd = new Command(command, properties, message);
 | |
|     process.stdout.write(cmd.toString() + os.EOL);
 | |
| }
 | |
| exports.issueCommand = issueCommand;
 | |
| function issue(name, message = '') {
 | |
|     issueCommand(name, {}, message);
 | |
| }
 | |
| exports.issue = issue;
 | |
| const CMD_STRING = '::';
 | |
| class Command {
 | |
|     constructor(command, properties, message) {
 | |
|         if (!command) {
 | |
|             command = 'missing.command';
 | |
|         }
 | |
|         this.command = command;
 | |
|         this.properties = properties;
 | |
|         this.message = message;
 | |
|     }
 | |
|     toString() {
 | |
|         let cmdStr = CMD_STRING + this.command;
 | |
|         if (this.properties && Object.keys(this.properties).length > 0) {
 | |
|             cmdStr += ' ';
 | |
|             let first = true;
 | |
|             for (const key in this.properties) {
 | |
|                 if (this.properties.hasOwnProperty(key)) {
 | |
|                     const val = this.properties[key];
 | |
|                     if (val) {
 | |
|                         if (first) {
 | |
|                             first = false;
 | |
|                         }
 | |
|                         else {
 | |
|                             cmdStr += ',';
 | |
|                         }
 | |
|                         cmdStr += `${key}=${escapeProperty(val)}`;
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|         cmdStr += `${CMD_STRING}${escapeData(this.message)}`;
 | |
|         return cmdStr;
 | |
|     }
 | |
| }
 | |
| function escapeData(s) {
 | |
|     return utils_1.toCommandValue(s)
 | |
|         .replace(/%/g, '%25')
 | |
|         .replace(/\r/g, '%0D')
 | |
|         .replace(/\n/g, '%0A');
 | |
| }
 | |
| function escapeProperty(s) {
 | |
|     return utils_1.toCommandValue(s)
 | |
|         .replace(/%/g, '%25')
 | |
|         .replace(/\r/g, '%0D')
 | |
|         .replace(/\n/g, '%0A')
 | |
|         .replace(/:/g, '%3A')
 | |
|         .replace(/,/g, '%2C');
 | |
| }
 | |
| //# sourceMappingURL=command.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 470:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
 | |
|     if (k2 === undefined) k2 = k;
 | |
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
 | |
| }) : (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.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
 | |
|     __setModuleDefault(result, mod);
 | |
|     return result;
 | |
| };
 | |
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
 | |
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
 | |
|     return new (P || (P = Promise))(function (resolve, reject) {
 | |
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
 | |
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
 | |
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
 | |
|         step((generator = generator.apply(thisArg, _arguments || [])).next());
 | |
|     });
 | |
| };
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.getIDToken = exports.getState = exports.saveState = exports.group = exports.endGroup = exports.startGroup = exports.info = exports.notice = exports.warning = exports.error = exports.debug = exports.isDebug = exports.setFailed = exports.setCommandEcho = exports.setOutput = exports.getBooleanInput = exports.getMultilineInput = exports.getInput = exports.addPath = exports.setSecret = exports.exportVariable = exports.ExitCode = void 0;
 | |
| const command_1 = __webpack_require__(431);
 | |
| const file_command_1 = __webpack_require__(102);
 | |
| const utils_1 = __webpack_require__(82);
 | |
| const os = __importStar(__webpack_require__(87));
 | |
| const path = __importStar(__webpack_require__(622));
 | |
| const oidc_utils_1 = __webpack_require__(742);
 | |
| /**
 | |
|  * The code to exit an action
 | |
|  */
 | |
| var ExitCode;
 | |
| (function (ExitCode) {
 | |
|     /**
 | |
|      * A code indicating that the action was successful
 | |
|      */
 | |
|     ExitCode[ExitCode["Success"] = 0] = "Success";
 | |
|     /**
 | |
|      * A code indicating that the action was a failure
 | |
|      */
 | |
|     ExitCode[ExitCode["Failure"] = 1] = "Failure";
 | |
| })(ExitCode = exports.ExitCode || (exports.ExitCode = {}));
 | |
| //-----------------------------------------------------------------------
 | |
| // Variables
 | |
| //-----------------------------------------------------------------------
 | |
| /**
 | |
|  * Sets env variable for this action and future actions in the job
 | |
|  * @param name the name of the variable to set
 | |
|  * @param val the value of the variable. Non-string values will be converted to a string via JSON.stringify
 | |
|  */
 | |
| // eslint-disable-next-line @typescript-eslint/no-explicit-any
 | |
| function exportVariable(name, val) {
 | |
|     const convertedVal = utils_1.toCommandValue(val);
 | |
|     process.env[name] = convertedVal;
 | |
|     const filePath = process.env['GITHUB_ENV'] || '';
 | |
|     if (filePath) {
 | |
|         return file_command_1.issueFileCommand('ENV', file_command_1.prepareKeyValueMessage(name, val));
 | |
|     }
 | |
|     command_1.issueCommand('set-env', { name }, convertedVal);
 | |
| }
 | |
| exports.exportVariable = exportVariable;
 | |
| /**
 | |
|  * Registers a secret which will get masked from logs
 | |
|  * @param secret value of the secret
 | |
|  */
 | |
| function setSecret(secret) {
 | |
|     command_1.issueCommand('add-mask', {}, secret);
 | |
| }
 | |
| exports.setSecret = setSecret;
 | |
| /**
 | |
|  * Prepends inputPath to the PATH (for this action and future actions)
 | |
|  * @param inputPath
 | |
|  */
 | |
| function addPath(inputPath) {
 | |
|     const filePath = process.env['GITHUB_PATH'] || '';
 | |
|     if (filePath) {
 | |
|         file_command_1.issueFileCommand('PATH', inputPath);
 | |
|     }
 | |
|     else {
 | |
|         command_1.issueCommand('add-path', {}, inputPath);
 | |
|     }
 | |
|     process.env['PATH'] = `${inputPath}${path.delimiter}${process.env['PATH']}`;
 | |
| }
 | |
| exports.addPath = addPath;
 | |
| /**
 | |
|  * Gets the value of an input.
 | |
|  * Unless trimWhitespace is set to false in InputOptions, the value is also trimmed.
 | |
|  * Returns an empty string if the value is not defined.
 | |
|  *
 | |
|  * @param     name     name of the input to get
 | |
|  * @param     options  optional. See InputOptions.
 | |
|  * @returns   string
 | |
|  */
 | |
| function getInput(name, options) {
 | |
|     const val = process.env[`INPUT_${name.replace(/ /g, '_').toUpperCase()}`] || '';
 | |
|     if (options && options.required && !val) {
 | |
|         throw new Error(`Input required and not supplied: ${name}`);
 | |
|     }
 | |
|     if (options && options.trimWhitespace === false) {
 | |
|         return val;
 | |
|     }
 | |
|     return val.trim();
 | |
| }
 | |
| exports.getInput = getInput;
 | |
| /**
 | |
|  * Gets the values of an multiline input.  Each value is also trimmed.
 | |
|  *
 | |
|  * @param     name     name of the input to get
 | |
|  * @param     options  optional. See InputOptions.
 | |
|  * @returns   string[]
 | |
|  *
 | |
|  */
 | |
| function getMultilineInput(name, options) {
 | |
|     const inputs = getInput(name, options)
 | |
|         .split('\n')
 | |
|         .filter(x => x !== '');
 | |
|     if (options && options.trimWhitespace === false) {
 | |
|         return inputs;
 | |
|     }
 | |
|     return inputs.map(input => input.trim());
 | |
| }
 | |
| exports.getMultilineInput = getMultilineInput;
 | |
| /**
 | |
|  * Gets the input value of the boolean type in the YAML 1.2 "core schema" specification.
 | |
|  * Support boolean input list: `true | True | TRUE | false | False | FALSE` .
 | |
|  * The return value is also in boolean type.
 | |
|  * ref: https://yaml.org/spec/1.2/spec.html#id2804923
 | |
|  *
 | |
|  * @param     name     name of the input to get
 | |
|  * @param     options  optional. See InputOptions.
 | |
|  * @returns   boolean
 | |
|  */
 | |
| function getBooleanInput(name, options) {
 | |
|     const trueValue = ['true', 'True', 'TRUE'];
 | |
|     const falseValue = ['false', 'False', 'FALSE'];
 | |
|     const val = getInput(name, options);
 | |
|     if (trueValue.includes(val))
 | |
|         return true;
 | |
|     if (falseValue.includes(val))
 | |
|         return false;
 | |
|     throw new TypeError(`Input does not meet YAML 1.2 "Core Schema" specification: ${name}\n` +
 | |
|         `Support boolean input list: \`true | True | TRUE | false | False | FALSE\``);
 | |
| }
 | |
| exports.getBooleanInput = getBooleanInput;
 | |
| /**
 | |
|  * Sets the value of an output.
 | |
|  *
 | |
|  * @param     name     name of the output to set
 | |
|  * @param     value    value to store. Non-string values will be converted to a string via JSON.stringify
 | |
|  */
 | |
| // eslint-disable-next-line @typescript-eslint/no-explicit-any
 | |
| function setOutput(name, value) {
 | |
|     const filePath = process.env['GITHUB_OUTPUT'] || '';
 | |
|     if (filePath) {
 | |
|         return file_command_1.issueFileCommand('OUTPUT', file_command_1.prepareKeyValueMessage(name, value));
 | |
|     }
 | |
|     process.stdout.write(os.EOL);
 | |
|     command_1.issueCommand('set-output', { name }, utils_1.toCommandValue(value));
 | |
| }
 | |
| exports.setOutput = setOutput;
 | |
| /**
 | |
|  * Enables or disables the echoing of commands into stdout for the rest of the step.
 | |
|  * Echoing is disabled by default if ACTIONS_STEP_DEBUG is not set.
 | |
|  *
 | |
|  */
 | |
| function setCommandEcho(enabled) {
 | |
|     command_1.issue('echo', enabled ? 'on' : 'off');
 | |
| }
 | |
| exports.setCommandEcho = setCommandEcho;
 | |
| //-----------------------------------------------------------------------
 | |
| // Results
 | |
| //-----------------------------------------------------------------------
 | |
| /**
 | |
|  * Sets the action status to failed.
 | |
|  * When the action exits it will be with an exit code of 1
 | |
|  * @param message add error issue message
 | |
|  */
 | |
| function setFailed(message) {
 | |
|     process.exitCode = ExitCode.Failure;
 | |
|     error(message);
 | |
| }
 | |
| exports.setFailed = setFailed;
 | |
| //-----------------------------------------------------------------------
 | |
| // Logging Commands
 | |
| //-----------------------------------------------------------------------
 | |
| /**
 | |
|  * Gets whether Actions Step Debug is on or not
 | |
|  */
 | |
| function isDebug() {
 | |
|     return process.env['RUNNER_DEBUG'] === '1';
 | |
| }
 | |
| exports.isDebug = isDebug;
 | |
| /**
 | |
|  * Writes debug message to user log
 | |
|  * @param message debug message
 | |
|  */
 | |
| function debug(message) {
 | |
|     command_1.issueCommand('debug', {}, message);
 | |
| }
 | |
| exports.debug = debug;
 | |
| /**
 | |
|  * Adds an error issue
 | |
|  * @param message error issue message. Errors will be converted to string via toString()
 | |
|  * @param properties optional properties to add to the annotation.
 | |
|  */
 | |
| function error(message, properties = {}) {
 | |
|     command_1.issueCommand('error', utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);
 | |
| }
 | |
| exports.error = error;
 | |
| /**
 | |
|  * Adds a warning issue
 | |
|  * @param message warning issue message. Errors will be converted to string via toString()
 | |
|  * @param properties optional properties to add to the annotation.
 | |
|  */
 | |
| function warning(message, properties = {}) {
 | |
|     command_1.issueCommand('warning', utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);
 | |
| }
 | |
| exports.warning = warning;
 | |
| /**
 | |
|  * Adds a notice issue
 | |
|  * @param message notice issue message. Errors will be converted to string via toString()
 | |
|  * @param properties optional properties to add to the annotation.
 | |
|  */
 | |
| function notice(message, properties = {}) {
 | |
|     command_1.issueCommand('notice', utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);
 | |
| }
 | |
| exports.notice = notice;
 | |
| /**
 | |
|  * Writes info to log with console.log.
 | |
|  * @param message info message
 | |
|  */
 | |
| function info(message) {
 | |
|     process.stdout.write(message + os.EOL);
 | |
| }
 | |
| exports.info = info;
 | |
| /**
 | |
|  * Begin an output group.
 | |
|  *
 | |
|  * Output until the next `groupEnd` will be foldable in this group
 | |
|  *
 | |
|  * @param name The name of the output group
 | |
|  */
 | |
| function startGroup(name) {
 | |
|     command_1.issue('group', name);
 | |
| }
 | |
| exports.startGroup = startGroup;
 | |
| /**
 | |
|  * End an output group.
 | |
|  */
 | |
| function endGroup() {
 | |
|     command_1.issue('endgroup');
 | |
| }
 | |
| exports.endGroup = endGroup;
 | |
| /**
 | |
|  * Wrap an asynchronous function call in a group.
 | |
|  *
 | |
|  * Returns the same type as the function itself.
 | |
|  *
 | |
|  * @param name The name of the group
 | |
|  * @param fn The function to wrap in the group
 | |
|  */
 | |
| function group(name, fn) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         startGroup(name);
 | |
|         let result;
 | |
|         try {
 | |
|             result = yield fn();
 | |
|         }
 | |
|         finally {
 | |
|             endGroup();
 | |
|         }
 | |
|         return result;
 | |
|     });
 | |
| }
 | |
| exports.group = group;
 | |
| //-----------------------------------------------------------------------
 | |
| // Wrapper action state
 | |
| //-----------------------------------------------------------------------
 | |
| /**
 | |
|  * Saves state for current action, the state can only be retrieved by this action's post job execution.
 | |
|  *
 | |
|  * @param     name     name of the state to store
 | |
|  * @param     value    value to store. Non-string values will be converted to a string via JSON.stringify
 | |
|  */
 | |
| // eslint-disable-next-line @typescript-eslint/no-explicit-any
 | |
| function saveState(name, value) {
 | |
|     const filePath = process.env['GITHUB_STATE'] || '';
 | |
|     if (filePath) {
 | |
|         return file_command_1.issueFileCommand('STATE', file_command_1.prepareKeyValueMessage(name, value));
 | |
|     }
 | |
|     command_1.issueCommand('save-state', { name }, utils_1.toCommandValue(value));
 | |
| }
 | |
| exports.saveState = saveState;
 | |
| /**
 | |
|  * Gets the value of an state set by this action's main execution.
 | |
|  *
 | |
|  * @param     name     name of the state to get
 | |
|  * @returns   string
 | |
|  */
 | |
| function getState(name) {
 | |
|     return process.env[`STATE_${name}`] || '';
 | |
| }
 | |
| exports.getState = getState;
 | |
| function getIDToken(aud) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         return yield oidc_utils_1.OidcClient.getIDToken(aud);
 | |
|     });
 | |
| }
 | |
| exports.getIDToken = getIDToken;
 | |
| /**
 | |
|  * Summary exports
 | |
|  */
 | |
| var summary_1 = __webpack_require__(665);
 | |
| Object.defineProperty(exports, "summary", { enumerable: true, get: function () { return summary_1.summary; } });
 | |
| /**
 | |
|  * @deprecated use core.summary
 | |
|  */
 | |
| var summary_2 = __webpack_require__(665);
 | |
| Object.defineProperty(exports, "markdownSummary", { enumerable: true, get: function () { return summary_2.markdownSummary; } });
 | |
| /**
 | |
|  * Path exports
 | |
|  */
 | |
| var path_utils_1 = __webpack_require__(573);
 | |
| Object.defineProperty(exports, "toPosixPath", { enumerable: true, get: function () { return path_utils_1.toPosixPath; } });
 | |
| Object.defineProperty(exports, "toWin32Path", { enumerable: true, get: function () { return path_utils_1.toWin32Path; } });
 | |
| Object.defineProperty(exports, "toPlatformPath", { enumerable: true, get: function () { return path_utils_1.toPlatformPath; } });
 | |
| //# sourceMappingURL=core.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 506:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = rng;
 | |
| 
 | |
| var _crypto = _interopRequireDefault(__webpack_require__(417));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| const rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate
 | |
| 
 | |
| let poolPtr = rnds8Pool.length;
 | |
| 
 | |
| function rng() {
 | |
|   if (poolPtr > rnds8Pool.length - 16) {
 | |
|     _crypto.default.randomFillSync(rnds8Pool);
 | |
| 
 | |
|     poolPtr = 0;
 | |
|   }
 | |
| 
 | |
|   return rnds8Pool.slice(poolPtr, poolPtr += 16);
 | |
| }
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 525:
 | |
| /***/ (function(__unusedmodule, exports) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| var _default = /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;
 | |
| exports.default = _default;
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 572:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| 
 | |
| var _v = _interopRequireDefault(__webpack_require__(136));
 | |
| 
 | |
| var _md = _interopRequireDefault(__webpack_require__(659));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| const v3 = (0, _v.default)('v3', 0x30, _md.default);
 | |
| var _default = v3;
 | |
| exports.default = _default;
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 573:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
 | |
|     if (k2 === undefined) k2 = k;
 | |
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
 | |
| }) : (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.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
 | |
|     __setModuleDefault(result, mod);
 | |
|     return result;
 | |
| };
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.toPlatformPath = exports.toWin32Path = exports.toPosixPath = void 0;
 | |
| const path = __importStar(__webpack_require__(622));
 | |
| /**
 | |
|  * toPosixPath converts the given path to the posix form. On Windows, \\ will be
 | |
|  * replaced with /.
 | |
|  *
 | |
|  * @param pth. Path to transform.
 | |
|  * @return string Posix path.
 | |
|  */
 | |
| function toPosixPath(pth) {
 | |
|     return pth.replace(/[\\]/g, '/');
 | |
| }
 | |
| exports.toPosixPath = toPosixPath;
 | |
| /**
 | |
|  * toWin32Path converts the given path to the win32 form. On Linux, / will be
 | |
|  * replaced with \\.
 | |
|  *
 | |
|  * @param pth. Path to transform.
 | |
|  * @return string Win32 path.
 | |
|  */
 | |
| function toWin32Path(pth) {
 | |
|     return pth.replace(/[/]/g, '\\');
 | |
| }
 | |
| exports.toWin32Path = toWin32Path;
 | |
| /**
 | |
|  * toPlatformPath converts the given path to a platform-specific path. It does
 | |
|  * this by replacing instances of / and \ with the platform-specific path
 | |
|  * separator.
 | |
|  *
 | |
|  * @param pth The path to platformize.
 | |
|  * @return string The platform-specific path.
 | |
|  */
 | |
| function toPlatformPath(pth) {
 | |
|     return pth.replace(/[/\\]/g, path.sep);
 | |
| }
 | |
| exports.toPlatformPath = toPlatformPath;
 | |
| //# sourceMappingURL=path-utils.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 605:
 | |
| /***/ (function(module) {
 | |
| 
 | |
| module.exports = require("http");
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 614:
 | |
| /***/ (function(module) {
 | |
| 
 | |
| module.exports = require("events");
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 622:
 | |
| /***/ (function(module) {
 | |
| 
 | |
| module.exports = require("path");
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 631:
 | |
| /***/ (function(module) {
 | |
| 
 | |
| module.exports = require("net");
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 634:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| 
 | |
| var _regex = _interopRequireDefault(__webpack_require__(525));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| function validate(uuid) {
 | |
|   return typeof uuid === 'string' && _regex.default.test(uuid);
 | |
| }
 | |
| 
 | |
| var _default = validate;
 | |
| exports.default = _default;
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 638:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| 
 | |
| var _v = _interopRequireDefault(__webpack_require__(136));
 | |
| 
 | |
| var _sha = _interopRequireDefault(__webpack_require__(329));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| const v5 = (0, _v.default)('v5', 0x50, _sha.default);
 | |
| var _default = v5;
 | |
| exports.default = _default;
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 659:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| 
 | |
| var _crypto = _interopRequireDefault(__webpack_require__(417));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| function md5(bytes) {
 | |
|   if (Array.isArray(bytes)) {
 | |
|     bytes = Buffer.from(bytes);
 | |
|   } else if (typeof bytes === 'string') {
 | |
|     bytes = Buffer.from(bytes, 'utf8');
 | |
|   }
 | |
| 
 | |
|   return _crypto.default.createHash('md5').update(bytes).digest();
 | |
| }
 | |
| 
 | |
| var _default = md5;
 | |
| exports.default = _default;
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 665:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
 | |
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
 | |
|     return new (P || (P = Promise))(function (resolve, reject) {
 | |
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
 | |
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
 | |
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
 | |
|         step((generator = generator.apply(thisArg, _arguments || [])).next());
 | |
|     });
 | |
| };
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.summary = exports.markdownSummary = exports.SUMMARY_DOCS_URL = exports.SUMMARY_ENV_VAR = void 0;
 | |
| const os_1 = __webpack_require__(87);
 | |
| const fs_1 = __webpack_require__(747);
 | |
| const { access, appendFile, writeFile } = fs_1.promises;
 | |
| exports.SUMMARY_ENV_VAR = 'GITHUB_STEP_SUMMARY';
 | |
| exports.SUMMARY_DOCS_URL = 'https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#adding-a-job-summary';
 | |
| class Summary {
 | |
|     constructor() {
 | |
|         this._buffer = '';
 | |
|     }
 | |
|     /**
 | |
|      * Finds the summary file path from the environment, rejects if env var is not found or file does not exist
 | |
|      * Also checks r/w permissions.
 | |
|      *
 | |
|      * @returns step summary file path
 | |
|      */
 | |
|     filePath() {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             if (this._filePath) {
 | |
|                 return this._filePath;
 | |
|             }
 | |
|             const pathFromEnv = process.env[exports.SUMMARY_ENV_VAR];
 | |
|             if (!pathFromEnv) {
 | |
|                 throw new Error(`Unable to find environment variable for $${exports.SUMMARY_ENV_VAR}. Check if your runtime environment supports job summaries.`);
 | |
|             }
 | |
|             try {
 | |
|                 yield access(pathFromEnv, fs_1.constants.R_OK | fs_1.constants.W_OK);
 | |
|             }
 | |
|             catch (_a) {
 | |
|                 throw new Error(`Unable to access summary file: '${pathFromEnv}'. Check if the file has correct read/write permissions.`);
 | |
|             }
 | |
|             this._filePath = pathFromEnv;
 | |
|             return this._filePath;
 | |
|         });
 | |
|     }
 | |
|     /**
 | |
|      * Wraps content in an HTML tag, adding any HTML attributes
 | |
|      *
 | |
|      * @param {string} tag HTML tag to wrap
 | |
|      * @param {string | null} content content within the tag
 | |
|      * @param {[attribute: string]: string} attrs key-value list of HTML attributes to add
 | |
|      *
 | |
|      * @returns {string} content wrapped in HTML element
 | |
|      */
 | |
|     wrap(tag, content, attrs = {}) {
 | |
|         const htmlAttrs = Object.entries(attrs)
 | |
|             .map(([key, value]) => ` ${key}="${value}"`)
 | |
|             .join('');
 | |
|         if (!content) {
 | |
|             return `<${tag}${htmlAttrs}>`;
 | |
|         }
 | |
|         return `<${tag}${htmlAttrs}>${content}</${tag}>`;
 | |
|     }
 | |
|     /**
 | |
|      * Writes text in the buffer to the summary buffer file and empties buffer. Will append by default.
 | |
|      *
 | |
|      * @param {SummaryWriteOptions} [options] (optional) options for write operation
 | |
|      *
 | |
|      * @returns {Promise<Summary>} summary instance
 | |
|      */
 | |
|     write(options) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             const overwrite = !!(options === null || options === void 0 ? void 0 : options.overwrite);
 | |
|             const filePath = yield this.filePath();
 | |
|             const writeFunc = overwrite ? writeFile : appendFile;
 | |
|             yield writeFunc(filePath, this._buffer, { encoding: 'utf8' });
 | |
|             return this.emptyBuffer();
 | |
|         });
 | |
|     }
 | |
|     /**
 | |
|      * Clears the summary buffer and wipes the summary file
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     clear() {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             return this.emptyBuffer().write({ overwrite: true });
 | |
|         });
 | |
|     }
 | |
|     /**
 | |
|      * Returns the current summary buffer as a string
 | |
|      *
 | |
|      * @returns {string} string of summary buffer
 | |
|      */
 | |
|     stringify() {
 | |
|         return this._buffer;
 | |
|     }
 | |
|     /**
 | |
|      * If the summary buffer is empty
 | |
|      *
 | |
|      * @returns {boolen} true if the buffer is empty
 | |
|      */
 | |
|     isEmptyBuffer() {
 | |
|         return this._buffer.length === 0;
 | |
|     }
 | |
|     /**
 | |
|      * Resets the summary buffer without writing to summary file
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     emptyBuffer() {
 | |
|         this._buffer = '';
 | |
|         return this;
 | |
|     }
 | |
|     /**
 | |
|      * Adds raw text to the summary buffer
 | |
|      *
 | |
|      * @param {string} text content to add
 | |
|      * @param {boolean} [addEOL=false] (optional) append an EOL to the raw text (default: false)
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     addRaw(text, addEOL = false) {
 | |
|         this._buffer += text;
 | |
|         return addEOL ? this.addEOL() : this;
 | |
|     }
 | |
|     /**
 | |
|      * Adds the operating system-specific end-of-line marker to the buffer
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     addEOL() {
 | |
|         return this.addRaw(os_1.EOL);
 | |
|     }
 | |
|     /**
 | |
|      * Adds an HTML codeblock to the summary buffer
 | |
|      *
 | |
|      * @param {string} code content to render within fenced code block
 | |
|      * @param {string} lang (optional) language to syntax highlight code
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     addCodeBlock(code, lang) {
 | |
|         const attrs = Object.assign({}, (lang && { lang }));
 | |
|         const element = this.wrap('pre', this.wrap('code', code), attrs);
 | |
|         return this.addRaw(element).addEOL();
 | |
|     }
 | |
|     /**
 | |
|      * Adds an HTML list to the summary buffer
 | |
|      *
 | |
|      * @param {string[]} items list of items to render
 | |
|      * @param {boolean} [ordered=false] (optional) if the rendered list should be ordered or not (default: false)
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     addList(items, ordered = false) {
 | |
|         const tag = ordered ? 'ol' : 'ul';
 | |
|         const listItems = items.map(item => this.wrap('li', item)).join('');
 | |
|         const element = this.wrap(tag, listItems);
 | |
|         return this.addRaw(element).addEOL();
 | |
|     }
 | |
|     /**
 | |
|      * Adds an HTML table to the summary buffer
 | |
|      *
 | |
|      * @param {SummaryTableCell[]} rows table rows
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     addTable(rows) {
 | |
|         const tableBody = rows
 | |
|             .map(row => {
 | |
|             const cells = row
 | |
|                 .map(cell => {
 | |
|                 if (typeof cell === 'string') {
 | |
|                     return this.wrap('td', cell);
 | |
|                 }
 | |
|                 const { header, data, colspan, rowspan } = cell;
 | |
|                 const tag = header ? 'th' : 'td';
 | |
|                 const attrs = Object.assign(Object.assign({}, (colspan && { colspan })), (rowspan && { rowspan }));
 | |
|                 return this.wrap(tag, data, attrs);
 | |
|             })
 | |
|                 .join('');
 | |
|             return this.wrap('tr', cells);
 | |
|         })
 | |
|             .join('');
 | |
|         const element = this.wrap('table', tableBody);
 | |
|         return this.addRaw(element).addEOL();
 | |
|     }
 | |
|     /**
 | |
|      * Adds a collapsable HTML details element to the summary buffer
 | |
|      *
 | |
|      * @param {string} label text for the closed state
 | |
|      * @param {string} content collapsable content
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     addDetails(label, content) {
 | |
|         const element = this.wrap('details', this.wrap('summary', label) + content);
 | |
|         return this.addRaw(element).addEOL();
 | |
|     }
 | |
|     /**
 | |
|      * Adds an HTML image tag to the summary buffer
 | |
|      *
 | |
|      * @param {string} src path to the image you to embed
 | |
|      * @param {string} alt text description of the image
 | |
|      * @param {SummaryImageOptions} options (optional) addition image attributes
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     addImage(src, alt, options) {
 | |
|         const { width, height } = options || {};
 | |
|         const attrs = Object.assign(Object.assign({}, (width && { width })), (height && { height }));
 | |
|         const element = this.wrap('img', null, Object.assign({ src, alt }, attrs));
 | |
|         return this.addRaw(element).addEOL();
 | |
|     }
 | |
|     /**
 | |
|      * Adds an HTML section heading element
 | |
|      *
 | |
|      * @param {string} text heading text
 | |
|      * @param {number | string} [level=1] (optional) the heading level, default: 1
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     addHeading(text, level) {
 | |
|         const tag = `h${level}`;
 | |
|         const allowedTag = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6'].includes(tag)
 | |
|             ? tag
 | |
|             : 'h1';
 | |
|         const element = this.wrap(allowedTag, text);
 | |
|         return this.addRaw(element).addEOL();
 | |
|     }
 | |
|     /**
 | |
|      * Adds an HTML thematic break (<hr>) to the summary buffer
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     addSeparator() {
 | |
|         const element = this.wrap('hr', null);
 | |
|         return this.addRaw(element).addEOL();
 | |
|     }
 | |
|     /**
 | |
|      * Adds an HTML line break (<br>) to the summary buffer
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     addBreak() {
 | |
|         const element = this.wrap('br', null);
 | |
|         return this.addRaw(element).addEOL();
 | |
|     }
 | |
|     /**
 | |
|      * Adds an HTML blockquote to the summary buffer
 | |
|      *
 | |
|      * @param {string} text quote text
 | |
|      * @param {string} cite (optional) citation url
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     addQuote(text, cite) {
 | |
|         const attrs = Object.assign({}, (cite && { cite }));
 | |
|         const element = this.wrap('blockquote', text, attrs);
 | |
|         return this.addRaw(element).addEOL();
 | |
|     }
 | |
|     /**
 | |
|      * Adds an HTML anchor tag to the summary buffer
 | |
|      *
 | |
|      * @param {string} text link text/content
 | |
|      * @param {string} href hyperlink
 | |
|      *
 | |
|      * @returns {Summary} summary instance
 | |
|      */
 | |
|     addLink(text, href) {
 | |
|         const element = this.wrap('a', text, { href });
 | |
|         return this.addRaw(element).addEOL();
 | |
|     }
 | |
| }
 | |
| const _summary = new Summary();
 | |
| /**
 | |
|  * @deprecated use `core.summary`
 | |
|  */
 | |
| exports.markdownSummary = _summary;
 | |
| exports.summary = _summary;
 | |
| //# sourceMappingURL=summary.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 669:
 | |
| /***/ (function(module) {
 | |
| 
 | |
| module.exports = require("util");
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 672:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
 | |
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
 | |
|     return new (P || (P = Promise))(function (resolve, reject) {
 | |
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
 | |
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
 | |
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
 | |
|         step((generator = generator.apply(thisArg, _arguments || [])).next());
 | |
|     });
 | |
| };
 | |
| var _a;
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| const assert_1 = __webpack_require__(357);
 | |
| const fs = __webpack_require__(747);
 | |
| const path = __webpack_require__(622);
 | |
| _a = fs.promises, exports.chmod = _a.chmod, exports.copyFile = _a.copyFile, exports.lstat = _a.lstat, exports.mkdir = _a.mkdir, exports.readdir = _a.readdir, exports.readlink = _a.readlink, exports.rename = _a.rename, exports.rmdir = _a.rmdir, exports.stat = _a.stat, exports.symlink = _a.symlink, exports.unlink = _a.unlink;
 | |
| exports.IS_WINDOWS = process.platform === 'win32';
 | |
| function exists(fsPath) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         try {
 | |
|             yield exports.stat(fsPath);
 | |
|         }
 | |
|         catch (err) {
 | |
|             if (err.code === 'ENOENT') {
 | |
|                 return false;
 | |
|             }
 | |
|             throw err;
 | |
|         }
 | |
|         return true;
 | |
|     });
 | |
| }
 | |
| exports.exists = exists;
 | |
| function isDirectory(fsPath, useStat = false) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         const stats = useStat ? yield exports.stat(fsPath) : yield exports.lstat(fsPath);
 | |
|         return stats.isDirectory();
 | |
|     });
 | |
| }
 | |
| exports.isDirectory = isDirectory;
 | |
| /**
 | |
|  * On OSX/Linux, true if path starts with '/'. On Windows, true for paths like:
 | |
|  * \, \hello, \\hello\share, C:, and C:\hello (and corresponding alternate separator cases).
 | |
|  */
 | |
| function isRooted(p) {
 | |
|     p = normalizeSeparators(p);
 | |
|     if (!p) {
 | |
|         throw new Error('isRooted() parameter "p" cannot be empty');
 | |
|     }
 | |
|     if (exports.IS_WINDOWS) {
 | |
|         return (p.startsWith('\\') || /^[A-Z]:/i.test(p) // e.g. \ or \hello or \\hello
 | |
|         ); // e.g. C: or C:\hello
 | |
|     }
 | |
|     return p.startsWith('/');
 | |
| }
 | |
| exports.isRooted = isRooted;
 | |
| /**
 | |
|  * Recursively create a directory at `fsPath`.
 | |
|  *
 | |
|  * This implementation is optimistic, meaning it attempts to create the full
 | |
|  * path first, and backs up the path stack from there.
 | |
|  *
 | |
|  * @param fsPath The path to create
 | |
|  * @param maxDepth The maximum recursion depth
 | |
|  * @param depth The current recursion depth
 | |
|  */
 | |
| function mkdirP(fsPath, maxDepth = 1000, depth = 1) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         assert_1.ok(fsPath, 'a path argument must be provided');
 | |
|         fsPath = path.resolve(fsPath);
 | |
|         if (depth >= maxDepth)
 | |
|             return exports.mkdir(fsPath);
 | |
|         try {
 | |
|             yield exports.mkdir(fsPath);
 | |
|             return;
 | |
|         }
 | |
|         catch (err) {
 | |
|             switch (err.code) {
 | |
|                 case 'ENOENT': {
 | |
|                     yield mkdirP(path.dirname(fsPath), maxDepth, depth + 1);
 | |
|                     yield exports.mkdir(fsPath);
 | |
|                     return;
 | |
|                 }
 | |
|                 default: {
 | |
|                     let stats;
 | |
|                     try {
 | |
|                         stats = yield exports.stat(fsPath);
 | |
|                     }
 | |
|                     catch (err2) {
 | |
|                         throw err;
 | |
|                     }
 | |
|                     if (!stats.isDirectory())
 | |
|                         throw err;
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     });
 | |
| }
 | |
| exports.mkdirP = mkdirP;
 | |
| /**
 | |
|  * Best effort attempt to determine whether a file exists and is executable.
 | |
|  * @param filePath    file path to check
 | |
|  * @param extensions  additional file extensions to try
 | |
|  * @return if file exists and is executable, returns the file path. otherwise empty string.
 | |
|  */
 | |
| function tryGetExecutablePath(filePath, extensions) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         let stats = undefined;
 | |
|         try {
 | |
|             // test file exists
 | |
|             stats = yield exports.stat(filePath);
 | |
|         }
 | |
|         catch (err) {
 | |
|             if (err.code !== 'ENOENT') {
 | |
|                 // eslint-disable-next-line no-console
 | |
|                 console.log(`Unexpected error attempting to determine if executable file exists '${filePath}': ${err}`);
 | |
|             }
 | |
|         }
 | |
|         if (stats && stats.isFile()) {
 | |
|             if (exports.IS_WINDOWS) {
 | |
|                 // on Windows, test for valid extension
 | |
|                 const upperExt = path.extname(filePath).toUpperCase();
 | |
|                 if (extensions.some(validExt => validExt.toUpperCase() === upperExt)) {
 | |
|                     return filePath;
 | |
|                 }
 | |
|             }
 | |
|             else {
 | |
|                 if (isUnixExecutable(stats)) {
 | |
|                     return filePath;
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|         // try each extension
 | |
|         const originalFilePath = filePath;
 | |
|         for (const extension of extensions) {
 | |
|             filePath = originalFilePath + extension;
 | |
|             stats = undefined;
 | |
|             try {
 | |
|                 stats = yield exports.stat(filePath);
 | |
|             }
 | |
|             catch (err) {
 | |
|                 if (err.code !== 'ENOENT') {
 | |
|                     // eslint-disable-next-line no-console
 | |
|                     console.log(`Unexpected error attempting to determine if executable file exists '${filePath}': ${err}`);
 | |
|                 }
 | |
|             }
 | |
|             if (stats && stats.isFile()) {
 | |
|                 if (exports.IS_WINDOWS) {
 | |
|                     // preserve the case of the actual file (since an extension was appended)
 | |
|                     try {
 | |
|                         const directory = path.dirname(filePath);
 | |
|                         const upperName = path.basename(filePath).toUpperCase();
 | |
|                         for (const actualName of yield exports.readdir(directory)) {
 | |
|                             if (upperName === actualName.toUpperCase()) {
 | |
|                                 filePath = path.join(directory, actualName);
 | |
|                                 break;
 | |
|                             }
 | |
|                         }
 | |
|                     }
 | |
|                     catch (err) {
 | |
|                         // eslint-disable-next-line no-console
 | |
|                         console.log(`Unexpected error attempting to determine the actual case of the file '${filePath}': ${err}`);
 | |
|                     }
 | |
|                     return filePath;
 | |
|                 }
 | |
|                 else {
 | |
|                     if (isUnixExecutable(stats)) {
 | |
|                         return filePath;
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|         return '';
 | |
|     });
 | |
| }
 | |
| exports.tryGetExecutablePath = tryGetExecutablePath;
 | |
| function normalizeSeparators(p) {
 | |
|     p = p || '';
 | |
|     if (exports.IS_WINDOWS) {
 | |
|         // convert slashes on Windows
 | |
|         p = p.replace(/\//g, '\\');
 | |
|         // remove redundant slashes
 | |
|         return p.replace(/\\\\+/g, '\\');
 | |
|     }
 | |
|     // remove redundant slashes
 | |
|     return p.replace(/\/\/+/g, '/');
 | |
| }
 | |
| // on Mac/Linux, test the execute bit
 | |
| //     R   W  X  R  W X R W X
 | |
| //   256 128 64 32 16 8 4 2 1
 | |
| function isUnixExecutable(stats) {
 | |
|     return ((stats.mode & 1) > 0 ||
 | |
|         ((stats.mode & 8) > 0 && stats.gid === process.getgid()) ||
 | |
|         ((stats.mode & 64) > 0 && stats.uid === process.getuid()));
 | |
| }
 | |
| //# sourceMappingURL=io-util.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 694:
 | |
| /***/ (function(__unusedmodule, exports) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.INPUT_VERSION = 'version';
 | |
| exports.INPUT_JAVA_VERSION = 'java-version';
 | |
| exports.INPUT_ARCHITECTURE = 'architecture';
 | |
| exports.INPUT_JAVA_PACKAGE = 'java-package';
 | |
| exports.INPUT_JDK_FILE = 'jdkFile';
 | |
| exports.INPUT_SERVER_ID = 'server-id';
 | |
| exports.INPUT_SERVER_USERNAME = 'server-username';
 | |
| exports.INPUT_SERVER_PASSWORD = 'server-password';
 | |
| exports.INPUT_SETTINGS_PATH = 'settings-path';
 | |
| exports.INPUT_GPG_PRIVATE_KEY = 'gpg-private-key';
 | |
| exports.INPUT_GPG_PASSPHRASE = 'gpg-passphrase';
 | |
| exports.INPUT_DEFAULT_GPG_PRIVATE_KEY = undefined;
 | |
| exports.INPUT_DEFAULT_GPG_PASSPHRASE = 'GPG_PASSPHRASE';
 | |
| exports.STATE_GPG_PRIVATE_KEY_FINGERPRINT = 'gpg-private-key-fingerprint';
 | |
| 
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 742:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
 | |
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
 | |
|     return new (P || (P = Promise))(function (resolve, reject) {
 | |
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
 | |
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
 | |
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
 | |
|         step((generator = generator.apply(thisArg, _arguments || [])).next());
 | |
|     });
 | |
| };
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.OidcClient = void 0;
 | |
| const http_client_1 = __webpack_require__(993);
 | |
| const auth_1 = __webpack_require__(363);
 | |
| const core_1 = __webpack_require__(470);
 | |
| class OidcClient {
 | |
|     static createHttpClient(allowRetry = true, maxRetry = 10) {
 | |
|         const requestOptions = {
 | |
|             allowRetries: allowRetry,
 | |
|             maxRetries: maxRetry
 | |
|         };
 | |
|         return new http_client_1.HttpClient('actions/oidc-client', [new auth_1.BearerCredentialHandler(OidcClient.getRequestToken())], requestOptions);
 | |
|     }
 | |
|     static getRequestToken() {
 | |
|         const token = process.env['ACTIONS_ID_TOKEN_REQUEST_TOKEN'];
 | |
|         if (!token) {
 | |
|             throw new Error('Unable to get ACTIONS_ID_TOKEN_REQUEST_TOKEN env variable');
 | |
|         }
 | |
|         return token;
 | |
|     }
 | |
|     static getIDTokenUrl() {
 | |
|         const runtimeUrl = process.env['ACTIONS_ID_TOKEN_REQUEST_URL'];
 | |
|         if (!runtimeUrl) {
 | |
|             throw new Error('Unable to get ACTIONS_ID_TOKEN_REQUEST_URL env variable');
 | |
|         }
 | |
|         return runtimeUrl;
 | |
|     }
 | |
|     static getCall(id_token_url) {
 | |
|         var _a;
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             const httpclient = OidcClient.createHttpClient();
 | |
|             const res = yield httpclient
 | |
|                 .getJson(id_token_url)
 | |
|                 .catch(error => {
 | |
|                 throw new Error(`Failed to get ID Token. \n 
 | |
|         Error Code : ${error.statusCode}\n 
 | |
|         Error Message: ${error.result.message}`);
 | |
|             });
 | |
|             const id_token = (_a = res.result) === null || _a === void 0 ? void 0 : _a.value;
 | |
|             if (!id_token) {
 | |
|                 throw new Error('Response json body do not have ID Token field');
 | |
|             }
 | |
|             return id_token;
 | |
|         });
 | |
|     }
 | |
|     static getIDToken(audience) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             try {
 | |
|                 // New ID Token is requested from action service
 | |
|                 let id_token_url = OidcClient.getIDTokenUrl();
 | |
|                 if (audience) {
 | |
|                     const encodedAudience = encodeURIComponent(audience);
 | |
|                     id_token_url = `${id_token_url}&audience=${encodedAudience}`;
 | |
|                 }
 | |
|                 core_1.debug(`ID token url is ${id_token_url}`);
 | |
|                 const id_token = yield OidcClient.getCall(id_token_url);
 | |
|                 core_1.setSecret(id_token);
 | |
|                 return id_token;
 | |
|             }
 | |
|             catch (error) {
 | |
|                 throw new Error(`Error message: ${error.message}`);
 | |
|             }
 | |
|         });
 | |
|     }
 | |
| }
 | |
| exports.OidcClient = OidcClient;
 | |
| //# sourceMappingURL=oidc-utils.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 747:
 | |
| /***/ (function(module) {
 | |
| 
 | |
| module.exports = require("fs");
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 810:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| 
 | |
| var _rng = _interopRequireDefault(__webpack_require__(506));
 | |
| 
 | |
| var _stringify = _interopRequireDefault(__webpack_require__(960));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| // **`v1()` - Generate time-based UUID**
 | |
| //
 | |
| // Inspired by https://github.com/LiosK/UUID.js
 | |
| // and http://docs.python.org/library/uuid.html
 | |
| let _nodeId;
 | |
| 
 | |
| let _clockseq; // Previous uuid creation time
 | |
| 
 | |
| 
 | |
| let _lastMSecs = 0;
 | |
| let _lastNSecs = 0; // See https://github.com/uuidjs/uuid for API details
 | |
| 
 | |
| function v1(options, buf, offset) {
 | |
|   let i = buf && offset || 0;
 | |
|   const b = buf || new Array(16);
 | |
|   options = options || {};
 | |
|   let node = options.node || _nodeId;
 | |
|   let clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq; // node and clockseq need to be initialized to random values if they're not
 | |
|   // specified.  We do this lazily to minimize issues related to insufficient
 | |
|   // system entropy.  See #189
 | |
| 
 | |
|   if (node == null || clockseq == null) {
 | |
|     const seedBytes = options.random || (options.rng || _rng.default)();
 | |
| 
 | |
|     if (node == null) {
 | |
|       // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)
 | |
|       node = _nodeId = [seedBytes[0] | 0x01, seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]];
 | |
|     }
 | |
| 
 | |
|     if (clockseq == null) {
 | |
|       // Per 4.2.2, randomize (14 bit) clockseq
 | |
|       clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;
 | |
|     }
 | |
|   } // UUID timestamps are 100 nano-second units since the Gregorian epoch,
 | |
|   // (1582-10-15 00:00).  JSNumbers aren't precise enough for this, so
 | |
|   // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'
 | |
|   // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.
 | |
| 
 | |
| 
 | |
|   let msecs = options.msecs !== undefined ? options.msecs : Date.now(); // Per 4.2.1.2, use count of uuid's generated during the current clock
 | |
|   // cycle to simulate higher resolution clock
 | |
| 
 | |
|   let nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1; // Time since last uuid creation (in msecs)
 | |
| 
 | |
|   const dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 10000; // Per 4.2.1.2, Bump clockseq on clock regression
 | |
| 
 | |
|   if (dt < 0 && options.clockseq === undefined) {
 | |
|     clockseq = clockseq + 1 & 0x3fff;
 | |
|   } // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new
 | |
|   // time interval
 | |
| 
 | |
| 
 | |
|   if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {
 | |
|     nsecs = 0;
 | |
|   } // Per 4.2.1.2 Throw error if too many uuids are requested
 | |
| 
 | |
| 
 | |
|   if (nsecs >= 10000) {
 | |
|     throw new Error("uuid.v1(): Can't create more than 10M uuids/sec");
 | |
|   }
 | |
| 
 | |
|   _lastMSecs = msecs;
 | |
|   _lastNSecs = nsecs;
 | |
|   _clockseq = clockseq; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch
 | |
| 
 | |
|   msecs += 12219292800000; // `time_low`
 | |
| 
 | |
|   const tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;
 | |
|   b[i++] = tl >>> 24 & 0xff;
 | |
|   b[i++] = tl >>> 16 & 0xff;
 | |
|   b[i++] = tl >>> 8 & 0xff;
 | |
|   b[i++] = tl & 0xff; // `time_mid`
 | |
| 
 | |
|   const tmh = msecs / 0x100000000 * 10000 & 0xfffffff;
 | |
|   b[i++] = tmh >>> 8 & 0xff;
 | |
|   b[i++] = tmh & 0xff; // `time_high_and_version`
 | |
| 
 | |
|   b[i++] = tmh >>> 24 & 0xf | 0x10; // include version
 | |
| 
 | |
|   b[i++] = tmh >>> 16 & 0xff; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)
 | |
| 
 | |
|   b[i++] = clockseq >>> 8 | 0x80; // `clock_seq_low`
 | |
| 
 | |
|   b[i++] = clockseq & 0xff; // `node`
 | |
| 
 | |
|   for (let n = 0; n < 6; ++n) {
 | |
|     b[i + n] = node[n];
 | |
|   }
 | |
| 
 | |
|   return buf || (0, _stringify.default)(b);
 | |
| }
 | |
| 
 | |
| var _default = v1;
 | |
| exports.default = _default;
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 884:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
 | |
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
 | |
|     return new (P || (P = Promise))(function (resolve, reject) {
 | |
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
 | |
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
 | |
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
 | |
|         step((generator = generator.apply(thisArg, _arguments || [])).next());
 | |
|     });
 | |
| };
 | |
| 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 });
 | |
| const fs = __importStar(__webpack_require__(747));
 | |
| const path = __importStar(__webpack_require__(622));
 | |
| const io = __importStar(__webpack_require__(1));
 | |
| const exec = __importStar(__webpack_require__(986));
 | |
| const util = __importStar(__webpack_require__(322));
 | |
| exports.PRIVATE_KEY_FILE = path.join(util.getTempDir(), 'private-key.asc');
 | |
| const PRIVATE_KEY_FINGERPRINT_REGEX = /\w{40}/;
 | |
| function importKey(privateKey) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         fs.writeFileSync(exports.PRIVATE_KEY_FILE, privateKey, {
 | |
|             encoding: 'utf-8',
 | |
|             flag: 'w'
 | |
|         });
 | |
|         let output = '';
 | |
|         const options = {
 | |
|             silent: true,
 | |
|             listeners: {
 | |
|                 stdout: (data) => {
 | |
|                     output += data.toString();
 | |
|                 }
 | |
|             }
 | |
|         };
 | |
|         yield exec.exec('gpg', [
 | |
|             '--batch',
 | |
|             '--import-options',
 | |
|             'import-show',
 | |
|             '--import',
 | |
|             exports.PRIVATE_KEY_FILE
 | |
|         ], options);
 | |
|         yield io.rmRF(exports.PRIVATE_KEY_FILE);
 | |
|         const match = output.match(PRIVATE_KEY_FINGERPRINT_REGEX);
 | |
|         return match && match[0];
 | |
|     });
 | |
| }
 | |
| exports.importKey = importKey;
 | |
| function deleteKey(keyFingerprint) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         yield exec.exec('gpg', ['--batch', '--yes', '--delete-secret-keys', keyFingerprint], { silent: true });
 | |
|         yield exec.exec('gpg', ['--batch', '--yes', '--delete-keys', keyFingerprint], { silent: true });
 | |
|     });
 | |
| }
 | |
| exports.deleteKey = deleteKey;
 | |
| 
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 960:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.default = void 0;
 | |
| 
 | |
| var _validate = _interopRequireDefault(__webpack_require__(634));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
 | |
| 
 | |
| /**
 | |
|  * Convert array of 16 byte values to UUID string format of the form:
 | |
|  * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX
 | |
|  */
 | |
| const byteToHex = [];
 | |
| 
 | |
| for (let i = 0; i < 256; ++i) {
 | |
|   byteToHex.push((i + 0x100).toString(16).substr(1));
 | |
| }
 | |
| 
 | |
| function stringify(arr, offset = 0) {
 | |
|   // Note: Be careful editing this code!  It's been tuned for performance
 | |
|   // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434
 | |
|   const uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID.  If this throws, it's likely due to one
 | |
|   // of the following:
 | |
|   // - One or more input array values don't map to a hex octet (leading to
 | |
|   // "undefined" in the uuid)
 | |
|   // - Invalid input values for the RFC `version` or `variant` fields
 | |
| 
 | |
|   if (!(0, _validate.default)(uuid)) {
 | |
|     throw TypeError('Stringified UUID is invalid');
 | |
|   }
 | |
| 
 | |
|   return uuid;
 | |
| }
 | |
| 
 | |
| var _default = stringify;
 | |
| exports.default = _default;
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 986:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
 | |
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
 | |
|     return new (P || (P = Promise))(function (resolve, reject) {
 | |
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
 | |
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
 | |
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
 | |
|         step((generator = generator.apply(thisArg, _arguments || [])).next());
 | |
|     });
 | |
| };
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| const tr = __webpack_require__(9);
 | |
| /**
 | |
|  * Exec a command.
 | |
|  * Output will be streamed to the live console.
 | |
|  * Returns promise with return code
 | |
|  *
 | |
|  * @param     commandLine        command to execute (can include additional args). Must be correctly escaped.
 | |
|  * @param     args               optional arguments for tool. Escaping is handled by the lib.
 | |
|  * @param     options            optional exec options.  See ExecOptions
 | |
|  * @returns   Promise<number>    exit code
 | |
|  */
 | |
| function exec(commandLine, args, options) {
 | |
|     return __awaiter(this, void 0, void 0, function* () {
 | |
|         const commandArgs = tr.argStringToArray(commandLine);
 | |
|         if (commandArgs.length === 0) {
 | |
|             throw new Error(`Parameter 'commandLine' cannot be null or empty.`);
 | |
|         }
 | |
|         // Path to tool to execute should be first arg
 | |
|         const toolPath = commandArgs[0];
 | |
|         args = commandArgs.slice(1).concat(args || []);
 | |
|         const runner = new tr.ToolRunner(toolPath, args, options);
 | |
|         return runner.exec();
 | |
|     });
 | |
| }
 | |
| exports.exec = exec;
 | |
| //# sourceMappingURL=exec.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 993:
 | |
| /***/ (function(__unusedmodule, exports, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| /* eslint-disable @typescript-eslint/no-explicit-any */
 | |
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
 | |
|     if (k2 === undefined) k2 = k;
 | |
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
 | |
| }) : (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.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
 | |
|     __setModuleDefault(result, mod);
 | |
|     return result;
 | |
| };
 | |
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
 | |
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
 | |
|     return new (P || (P = Promise))(function (resolve, reject) {
 | |
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
 | |
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
 | |
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
 | |
|         step((generator = generator.apply(thisArg, _arguments || [])).next());
 | |
|     });
 | |
| };
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.HttpClient = exports.isHttps = exports.HttpClientResponse = exports.HttpClientError = exports.getProxyUrl = exports.MediaTypes = exports.Headers = exports.HttpCodes = void 0;
 | |
| const http = __importStar(__webpack_require__(605));
 | |
| const https = __importStar(__webpack_require__(211));
 | |
| const pm = __importStar(__webpack_require__(95));
 | |
| const tunnel = __importStar(__webpack_require__(413));
 | |
| var HttpCodes;
 | |
| (function (HttpCodes) {
 | |
|     HttpCodes[HttpCodes["OK"] = 200] = "OK";
 | |
|     HttpCodes[HttpCodes["MultipleChoices"] = 300] = "MultipleChoices";
 | |
|     HttpCodes[HttpCodes["MovedPermanently"] = 301] = "MovedPermanently";
 | |
|     HttpCodes[HttpCodes["ResourceMoved"] = 302] = "ResourceMoved";
 | |
|     HttpCodes[HttpCodes["SeeOther"] = 303] = "SeeOther";
 | |
|     HttpCodes[HttpCodes["NotModified"] = 304] = "NotModified";
 | |
|     HttpCodes[HttpCodes["UseProxy"] = 305] = "UseProxy";
 | |
|     HttpCodes[HttpCodes["SwitchProxy"] = 306] = "SwitchProxy";
 | |
|     HttpCodes[HttpCodes["TemporaryRedirect"] = 307] = "TemporaryRedirect";
 | |
|     HttpCodes[HttpCodes["PermanentRedirect"] = 308] = "PermanentRedirect";
 | |
|     HttpCodes[HttpCodes["BadRequest"] = 400] = "BadRequest";
 | |
|     HttpCodes[HttpCodes["Unauthorized"] = 401] = "Unauthorized";
 | |
|     HttpCodes[HttpCodes["PaymentRequired"] = 402] = "PaymentRequired";
 | |
|     HttpCodes[HttpCodes["Forbidden"] = 403] = "Forbidden";
 | |
|     HttpCodes[HttpCodes["NotFound"] = 404] = "NotFound";
 | |
|     HttpCodes[HttpCodes["MethodNotAllowed"] = 405] = "MethodNotAllowed";
 | |
|     HttpCodes[HttpCodes["NotAcceptable"] = 406] = "NotAcceptable";
 | |
|     HttpCodes[HttpCodes["ProxyAuthenticationRequired"] = 407] = "ProxyAuthenticationRequired";
 | |
|     HttpCodes[HttpCodes["RequestTimeout"] = 408] = "RequestTimeout";
 | |
|     HttpCodes[HttpCodes["Conflict"] = 409] = "Conflict";
 | |
|     HttpCodes[HttpCodes["Gone"] = 410] = "Gone";
 | |
|     HttpCodes[HttpCodes["TooManyRequests"] = 429] = "TooManyRequests";
 | |
|     HttpCodes[HttpCodes["InternalServerError"] = 500] = "InternalServerError";
 | |
|     HttpCodes[HttpCodes["NotImplemented"] = 501] = "NotImplemented";
 | |
|     HttpCodes[HttpCodes["BadGateway"] = 502] = "BadGateway";
 | |
|     HttpCodes[HttpCodes["ServiceUnavailable"] = 503] = "ServiceUnavailable";
 | |
|     HttpCodes[HttpCodes["GatewayTimeout"] = 504] = "GatewayTimeout";
 | |
| })(HttpCodes = exports.HttpCodes || (exports.HttpCodes = {}));
 | |
| var Headers;
 | |
| (function (Headers) {
 | |
|     Headers["Accept"] = "accept";
 | |
|     Headers["ContentType"] = "content-type";
 | |
| })(Headers = exports.Headers || (exports.Headers = {}));
 | |
| var MediaTypes;
 | |
| (function (MediaTypes) {
 | |
|     MediaTypes["ApplicationJson"] = "application/json";
 | |
| })(MediaTypes = exports.MediaTypes || (exports.MediaTypes = {}));
 | |
| /**
 | |
|  * Returns the proxy URL, depending upon the supplied url and proxy environment variables.
 | |
|  * @param serverUrl  The server URL where the request will be sent. For example, https://api.github.com
 | |
|  */
 | |
| function getProxyUrl(serverUrl) {
 | |
|     const proxyUrl = pm.getProxyUrl(new URL(serverUrl));
 | |
|     return proxyUrl ? proxyUrl.href : '';
 | |
| }
 | |
| exports.getProxyUrl = getProxyUrl;
 | |
| const HttpRedirectCodes = [
 | |
|     HttpCodes.MovedPermanently,
 | |
|     HttpCodes.ResourceMoved,
 | |
|     HttpCodes.SeeOther,
 | |
|     HttpCodes.TemporaryRedirect,
 | |
|     HttpCodes.PermanentRedirect
 | |
| ];
 | |
| const HttpResponseRetryCodes = [
 | |
|     HttpCodes.BadGateway,
 | |
|     HttpCodes.ServiceUnavailable,
 | |
|     HttpCodes.GatewayTimeout
 | |
| ];
 | |
| const RetryableHttpVerbs = ['OPTIONS', 'GET', 'DELETE', 'HEAD'];
 | |
| const ExponentialBackoffCeiling = 10;
 | |
| const ExponentialBackoffTimeSlice = 5;
 | |
| class HttpClientError extends Error {
 | |
|     constructor(message, statusCode) {
 | |
|         super(message);
 | |
|         this.name = 'HttpClientError';
 | |
|         this.statusCode = statusCode;
 | |
|         Object.setPrototypeOf(this, HttpClientError.prototype);
 | |
|     }
 | |
| }
 | |
| exports.HttpClientError = HttpClientError;
 | |
| class HttpClientResponse {
 | |
|     constructor(message) {
 | |
|         this.message = message;
 | |
|     }
 | |
|     readBody() {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             return new Promise((resolve) => __awaiter(this, void 0, void 0, function* () {
 | |
|                 let output = Buffer.alloc(0);
 | |
|                 this.message.on('data', (chunk) => {
 | |
|                     output = Buffer.concat([output, chunk]);
 | |
|                 });
 | |
|                 this.message.on('end', () => {
 | |
|                     resolve(output.toString());
 | |
|                 });
 | |
|             }));
 | |
|         });
 | |
|     }
 | |
| }
 | |
| exports.HttpClientResponse = HttpClientResponse;
 | |
| function isHttps(requestUrl) {
 | |
|     const parsedUrl = new URL(requestUrl);
 | |
|     return parsedUrl.protocol === 'https:';
 | |
| }
 | |
| exports.isHttps = isHttps;
 | |
| class HttpClient {
 | |
|     constructor(userAgent, handlers, requestOptions) {
 | |
|         this._ignoreSslError = false;
 | |
|         this._allowRedirects = true;
 | |
|         this._allowRedirectDowngrade = false;
 | |
|         this._maxRedirects = 50;
 | |
|         this._allowRetries = false;
 | |
|         this._maxRetries = 1;
 | |
|         this._keepAlive = false;
 | |
|         this._disposed = false;
 | |
|         this.userAgent = userAgent;
 | |
|         this.handlers = handlers || [];
 | |
|         this.requestOptions = requestOptions;
 | |
|         if (requestOptions) {
 | |
|             if (requestOptions.ignoreSslError != null) {
 | |
|                 this._ignoreSslError = requestOptions.ignoreSslError;
 | |
|             }
 | |
|             this._socketTimeout = requestOptions.socketTimeout;
 | |
|             if (requestOptions.allowRedirects != null) {
 | |
|                 this._allowRedirects = requestOptions.allowRedirects;
 | |
|             }
 | |
|             if (requestOptions.allowRedirectDowngrade != null) {
 | |
|                 this._allowRedirectDowngrade = requestOptions.allowRedirectDowngrade;
 | |
|             }
 | |
|             if (requestOptions.maxRedirects != null) {
 | |
|                 this._maxRedirects = Math.max(requestOptions.maxRedirects, 0);
 | |
|             }
 | |
|             if (requestOptions.keepAlive != null) {
 | |
|                 this._keepAlive = requestOptions.keepAlive;
 | |
|             }
 | |
|             if (requestOptions.allowRetries != null) {
 | |
|                 this._allowRetries = requestOptions.allowRetries;
 | |
|             }
 | |
|             if (requestOptions.maxRetries != null) {
 | |
|                 this._maxRetries = requestOptions.maxRetries;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     options(requestUrl, additionalHeaders) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             return this.request('OPTIONS', requestUrl, null, additionalHeaders || {});
 | |
|         });
 | |
|     }
 | |
|     get(requestUrl, additionalHeaders) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             return this.request('GET', requestUrl, null, additionalHeaders || {});
 | |
|         });
 | |
|     }
 | |
|     del(requestUrl, additionalHeaders) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             return this.request('DELETE', requestUrl, null, additionalHeaders || {});
 | |
|         });
 | |
|     }
 | |
|     post(requestUrl, data, additionalHeaders) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             return this.request('POST', requestUrl, data, additionalHeaders || {});
 | |
|         });
 | |
|     }
 | |
|     patch(requestUrl, data, additionalHeaders) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             return this.request('PATCH', requestUrl, data, additionalHeaders || {});
 | |
|         });
 | |
|     }
 | |
|     put(requestUrl, data, additionalHeaders) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             return this.request('PUT', requestUrl, data, additionalHeaders || {});
 | |
|         });
 | |
|     }
 | |
|     head(requestUrl, additionalHeaders) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             return this.request('HEAD', requestUrl, null, additionalHeaders || {});
 | |
|         });
 | |
|     }
 | |
|     sendStream(verb, requestUrl, stream, additionalHeaders) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             return this.request(verb, requestUrl, stream, additionalHeaders);
 | |
|         });
 | |
|     }
 | |
|     /**
 | |
|      * Gets a typed object from an endpoint
 | |
|      * Be aware that not found returns a null.  Other errors (4xx, 5xx) reject the promise
 | |
|      */
 | |
|     getJson(requestUrl, additionalHeaders = {}) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);
 | |
|             const res = yield this.get(requestUrl, additionalHeaders);
 | |
|             return this._processResponse(res, this.requestOptions);
 | |
|         });
 | |
|     }
 | |
|     postJson(requestUrl, obj, additionalHeaders = {}) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             const data = JSON.stringify(obj, null, 2);
 | |
|             additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);
 | |
|             additionalHeaders[Headers.ContentType] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.ContentType, MediaTypes.ApplicationJson);
 | |
|             const res = yield this.post(requestUrl, data, additionalHeaders);
 | |
|             return this._processResponse(res, this.requestOptions);
 | |
|         });
 | |
|     }
 | |
|     putJson(requestUrl, obj, additionalHeaders = {}) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             const data = JSON.stringify(obj, null, 2);
 | |
|             additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);
 | |
|             additionalHeaders[Headers.ContentType] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.ContentType, MediaTypes.ApplicationJson);
 | |
|             const res = yield this.put(requestUrl, data, additionalHeaders);
 | |
|             return this._processResponse(res, this.requestOptions);
 | |
|         });
 | |
|     }
 | |
|     patchJson(requestUrl, obj, additionalHeaders = {}) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             const data = JSON.stringify(obj, null, 2);
 | |
|             additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);
 | |
|             additionalHeaders[Headers.ContentType] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.ContentType, MediaTypes.ApplicationJson);
 | |
|             const res = yield this.patch(requestUrl, data, additionalHeaders);
 | |
|             return this._processResponse(res, this.requestOptions);
 | |
|         });
 | |
|     }
 | |
|     /**
 | |
|      * Makes a raw http request.
 | |
|      * All other methods such as get, post, patch, and request ultimately call this.
 | |
|      * Prefer get, del, post and patch
 | |
|      */
 | |
|     request(verb, requestUrl, data, headers) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             if (this._disposed) {
 | |
|                 throw new Error('Client has already been disposed.');
 | |
|             }
 | |
|             const parsedUrl = new URL(requestUrl);
 | |
|             let info = this._prepareRequest(verb, parsedUrl, headers);
 | |
|             // Only perform retries on reads since writes may not be idempotent.
 | |
|             const maxTries = this._allowRetries && RetryableHttpVerbs.includes(verb)
 | |
|                 ? this._maxRetries + 1
 | |
|                 : 1;
 | |
|             let numTries = 0;
 | |
|             let response;
 | |
|             do {
 | |
|                 response = yield this.requestRaw(info, data);
 | |
|                 // Check if it's an authentication challenge
 | |
|                 if (response &&
 | |
|                     response.message &&
 | |
|                     response.message.statusCode === HttpCodes.Unauthorized) {
 | |
|                     let authenticationHandler;
 | |
|                     for (const handler of this.handlers) {
 | |
|                         if (handler.canHandleAuthentication(response)) {
 | |
|                             authenticationHandler = handler;
 | |
|                             break;
 | |
|                         }
 | |
|                     }
 | |
|                     if (authenticationHandler) {
 | |
|                         return authenticationHandler.handleAuthentication(this, info, data);
 | |
|                     }
 | |
|                     else {
 | |
|                         // We have received an unauthorized response but have no handlers to handle it.
 | |
|                         // Let the response return to the caller.
 | |
|                         return response;
 | |
|                     }
 | |
|                 }
 | |
|                 let redirectsRemaining = this._maxRedirects;
 | |
|                 while (response.message.statusCode &&
 | |
|                     HttpRedirectCodes.includes(response.message.statusCode) &&
 | |
|                     this._allowRedirects &&
 | |
|                     redirectsRemaining > 0) {
 | |
|                     const redirectUrl = response.message.headers['location'];
 | |
|                     if (!redirectUrl) {
 | |
|                         // if there's no location to redirect to, we won't
 | |
|                         break;
 | |
|                     }
 | |
|                     const parsedRedirectUrl = new URL(redirectUrl);
 | |
|                     if (parsedUrl.protocol === 'https:' &&
 | |
|                         parsedUrl.protocol !== parsedRedirectUrl.protocol &&
 | |
|                         !this._allowRedirectDowngrade) {
 | |
|                         throw new Error('Redirect from HTTPS to HTTP protocol. This downgrade is not allowed for security reasons. If you want to allow this behavior, set the allowRedirectDowngrade option to true.');
 | |
|                     }
 | |
|                     // we need to finish reading the response before reassigning response
 | |
|                     // which will leak the open socket.
 | |
|                     yield response.readBody();
 | |
|                     // strip authorization header if redirected to a different hostname
 | |
|                     if (parsedRedirectUrl.hostname !== parsedUrl.hostname) {
 | |
|                         for (const header in headers) {
 | |
|                             // header names are case insensitive
 | |
|                             if (header.toLowerCase() === 'authorization') {
 | |
|                                 delete headers[header];
 | |
|                             }
 | |
|                         }
 | |
|                     }
 | |
|                     // let's make the request with the new redirectUrl
 | |
|                     info = this._prepareRequest(verb, parsedRedirectUrl, headers);
 | |
|                     response = yield this.requestRaw(info, data);
 | |
|                     redirectsRemaining--;
 | |
|                 }
 | |
|                 if (!response.message.statusCode ||
 | |
|                     !HttpResponseRetryCodes.includes(response.message.statusCode)) {
 | |
|                     // If not a retry code, return immediately instead of retrying
 | |
|                     return response;
 | |
|                 }
 | |
|                 numTries += 1;
 | |
|                 if (numTries < maxTries) {
 | |
|                     yield response.readBody();
 | |
|                     yield this._performExponentialBackoff(numTries);
 | |
|                 }
 | |
|             } while (numTries < maxTries);
 | |
|             return response;
 | |
|         });
 | |
|     }
 | |
|     /**
 | |
|      * Needs to be called if keepAlive is set to true in request options.
 | |
|      */
 | |
|     dispose() {
 | |
|         if (this._agent) {
 | |
|             this._agent.destroy();
 | |
|         }
 | |
|         this._disposed = true;
 | |
|     }
 | |
|     /**
 | |
|      * Raw request.
 | |
|      * @param info
 | |
|      * @param data
 | |
|      */
 | |
|     requestRaw(info, data) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             return new Promise((resolve, reject) => {
 | |
|                 function callbackForResult(err, res) {
 | |
|                     if (err) {
 | |
|                         reject(err);
 | |
|                     }
 | |
|                     else if (!res) {
 | |
|                         // If `err` is not passed, then `res` must be passed.
 | |
|                         reject(new Error('Unknown error'));
 | |
|                     }
 | |
|                     else {
 | |
|                         resolve(res);
 | |
|                     }
 | |
|                 }
 | |
|                 this.requestRawWithCallback(info, data, callbackForResult);
 | |
|             });
 | |
|         });
 | |
|     }
 | |
|     /**
 | |
|      * Raw request with callback.
 | |
|      * @param info
 | |
|      * @param data
 | |
|      * @param onResult
 | |
|      */
 | |
|     requestRawWithCallback(info, data, onResult) {
 | |
|         if (typeof data === 'string') {
 | |
|             if (!info.options.headers) {
 | |
|                 info.options.headers = {};
 | |
|             }
 | |
|             info.options.headers['Content-Length'] = Buffer.byteLength(data, 'utf8');
 | |
|         }
 | |
|         let callbackCalled = false;
 | |
|         function handleResult(err, res) {
 | |
|             if (!callbackCalled) {
 | |
|                 callbackCalled = true;
 | |
|                 onResult(err, res);
 | |
|             }
 | |
|         }
 | |
|         const req = info.httpModule.request(info.options, (msg) => {
 | |
|             const res = new HttpClientResponse(msg);
 | |
|             handleResult(undefined, res);
 | |
|         });
 | |
|         let socket;
 | |
|         req.on('socket', sock => {
 | |
|             socket = sock;
 | |
|         });
 | |
|         // If we ever get disconnected, we want the socket to timeout eventually
 | |
|         req.setTimeout(this._socketTimeout || 3 * 60000, () => {
 | |
|             if (socket) {
 | |
|                 socket.end();
 | |
|             }
 | |
|             handleResult(new Error(`Request timeout: ${info.options.path}`));
 | |
|         });
 | |
|         req.on('error', function (err) {
 | |
|             // err has statusCode property
 | |
|             // res should have headers
 | |
|             handleResult(err);
 | |
|         });
 | |
|         if (data && typeof data === 'string') {
 | |
|             req.write(data, 'utf8');
 | |
|         }
 | |
|         if (data && typeof data !== 'string') {
 | |
|             data.on('close', function () {
 | |
|                 req.end();
 | |
|             });
 | |
|             data.pipe(req);
 | |
|         }
 | |
|         else {
 | |
|             req.end();
 | |
|         }
 | |
|     }
 | |
|     /**
 | |
|      * Gets an http agent. This function is useful when you need an http agent that handles
 | |
|      * routing through a proxy server - depending upon the url and proxy environment variables.
 | |
|      * @param serverUrl  The server URL where the request will be sent. For example, https://api.github.com
 | |
|      */
 | |
|     getAgent(serverUrl) {
 | |
|         const parsedUrl = new URL(serverUrl);
 | |
|         return this._getAgent(parsedUrl);
 | |
|     }
 | |
|     _prepareRequest(method, requestUrl, headers) {
 | |
|         const info = {};
 | |
|         info.parsedUrl = requestUrl;
 | |
|         const usingSsl = info.parsedUrl.protocol === 'https:';
 | |
|         info.httpModule = usingSsl ? https : http;
 | |
|         const defaultPort = usingSsl ? 443 : 80;
 | |
|         info.options = {};
 | |
|         info.options.host = info.parsedUrl.hostname;
 | |
|         info.options.port = info.parsedUrl.port
 | |
|             ? parseInt(info.parsedUrl.port)
 | |
|             : defaultPort;
 | |
|         info.options.path =
 | |
|             (info.parsedUrl.pathname || '') + (info.parsedUrl.search || '');
 | |
|         info.options.method = method;
 | |
|         info.options.headers = this._mergeHeaders(headers);
 | |
|         if (this.userAgent != null) {
 | |
|             info.options.headers['user-agent'] = this.userAgent;
 | |
|         }
 | |
|         info.options.agent = this._getAgent(info.parsedUrl);
 | |
|         // gives handlers an opportunity to participate
 | |
|         if (this.handlers) {
 | |
|             for (const handler of this.handlers) {
 | |
|                 handler.prepareRequest(info.options);
 | |
|             }
 | |
|         }
 | |
|         return info;
 | |
|     }
 | |
|     _mergeHeaders(headers) {
 | |
|         if (this.requestOptions && this.requestOptions.headers) {
 | |
|             return Object.assign({}, lowercaseKeys(this.requestOptions.headers), lowercaseKeys(headers || {}));
 | |
|         }
 | |
|         return lowercaseKeys(headers || {});
 | |
|     }
 | |
|     _getExistingOrDefaultHeader(additionalHeaders, header, _default) {
 | |
|         let clientHeader;
 | |
|         if (this.requestOptions && this.requestOptions.headers) {
 | |
|             clientHeader = lowercaseKeys(this.requestOptions.headers)[header];
 | |
|         }
 | |
|         return additionalHeaders[header] || clientHeader || _default;
 | |
|     }
 | |
|     _getAgent(parsedUrl) {
 | |
|         let agent;
 | |
|         const proxyUrl = pm.getProxyUrl(parsedUrl);
 | |
|         const useProxy = proxyUrl && proxyUrl.hostname;
 | |
|         if (this._keepAlive && useProxy) {
 | |
|             agent = this._proxyAgent;
 | |
|         }
 | |
|         if (this._keepAlive && !useProxy) {
 | |
|             agent = this._agent;
 | |
|         }
 | |
|         // if agent is already assigned use that agent.
 | |
|         if (agent) {
 | |
|             return agent;
 | |
|         }
 | |
|         const usingSsl = parsedUrl.protocol === 'https:';
 | |
|         let maxSockets = 100;
 | |
|         if (this.requestOptions) {
 | |
|             maxSockets = this.requestOptions.maxSockets || http.globalAgent.maxSockets;
 | |
|         }
 | |
|         // This is `useProxy` again, but we need to check `proxyURl` directly for TypeScripts's flow analysis.
 | |
|         if (proxyUrl && proxyUrl.hostname) {
 | |
|             const agentOptions = {
 | |
|                 maxSockets,
 | |
|                 keepAlive: this._keepAlive,
 | |
|                 proxy: Object.assign(Object.assign({}, ((proxyUrl.username || proxyUrl.password) && {
 | |
|                     proxyAuth: `${proxyUrl.username}:${proxyUrl.password}`
 | |
|                 })), { host: proxyUrl.hostname, port: proxyUrl.port })
 | |
|             };
 | |
|             let tunnelAgent;
 | |
|             const overHttps = proxyUrl.protocol === 'https:';
 | |
|             if (usingSsl) {
 | |
|                 tunnelAgent = overHttps ? tunnel.httpsOverHttps : tunnel.httpsOverHttp;
 | |
|             }
 | |
|             else {
 | |
|                 tunnelAgent = overHttps ? tunnel.httpOverHttps : tunnel.httpOverHttp;
 | |
|             }
 | |
|             agent = tunnelAgent(agentOptions);
 | |
|             this._proxyAgent = agent;
 | |
|         }
 | |
|         // if reusing agent across request and tunneling agent isn't assigned create a new agent
 | |
|         if (this._keepAlive && !agent) {
 | |
|             const options = { keepAlive: this._keepAlive, maxSockets };
 | |
|             agent = usingSsl ? new https.Agent(options) : new http.Agent(options);
 | |
|             this._agent = agent;
 | |
|         }
 | |
|         // if not using private agent and tunnel agent isn't setup then use global agent
 | |
|         if (!agent) {
 | |
|             agent = usingSsl ? https.globalAgent : http.globalAgent;
 | |
|         }
 | |
|         if (usingSsl && this._ignoreSslError) {
 | |
|             // we don't want to set NODE_TLS_REJECT_UNAUTHORIZED=0 since that will affect request for entire process
 | |
|             // http.RequestOptions doesn't expose a way to modify RequestOptions.agent.options
 | |
|             // we have to cast it to any and change it directly
 | |
|             agent.options = Object.assign(agent.options || {}, {
 | |
|                 rejectUnauthorized: false
 | |
|             });
 | |
|         }
 | |
|         return agent;
 | |
|     }
 | |
|     _performExponentialBackoff(retryNumber) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             retryNumber = Math.min(ExponentialBackoffCeiling, retryNumber);
 | |
|             const ms = ExponentialBackoffTimeSlice * Math.pow(2, retryNumber);
 | |
|             return new Promise(resolve => setTimeout(() => resolve(), ms));
 | |
|         });
 | |
|     }
 | |
|     _processResponse(res, options) {
 | |
|         return __awaiter(this, void 0, void 0, function* () {
 | |
|             return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {
 | |
|                 const statusCode = res.message.statusCode || 0;
 | |
|                 const response = {
 | |
|                     statusCode,
 | |
|                     result: null,
 | |
|                     headers: {}
 | |
|                 };
 | |
|                 // not found leads to null obj returned
 | |
|                 if (statusCode === HttpCodes.NotFound) {
 | |
|                     resolve(response);
 | |
|                 }
 | |
|                 // get the result from the body
 | |
|                 function dateTimeDeserializer(key, value) {
 | |
|                     if (typeof value === 'string') {
 | |
|                         const a = new Date(value);
 | |
|                         if (!isNaN(a.valueOf())) {
 | |
|                             return a;
 | |
|                         }
 | |
|                     }
 | |
|                     return value;
 | |
|                 }
 | |
|                 let obj;
 | |
|                 let contents;
 | |
|                 try {
 | |
|                     contents = yield res.readBody();
 | |
|                     if (contents && contents.length > 0) {
 | |
|                         if (options && options.deserializeDates) {
 | |
|                             obj = JSON.parse(contents, dateTimeDeserializer);
 | |
|                         }
 | |
|                         else {
 | |
|                             obj = JSON.parse(contents);
 | |
|                         }
 | |
|                         response.result = obj;
 | |
|                     }
 | |
|                     response.headers = res.message.headers;
 | |
|                 }
 | |
|                 catch (err) {
 | |
|                     // Invalid resource (contents not json);  leaving result obj null
 | |
|                 }
 | |
|                 // note that 3xx redirects are handled by the http layer.
 | |
|                 if (statusCode > 299) {
 | |
|                     let msg;
 | |
|                     // if exception/error in body, attempt to get better error
 | |
|                     if (obj && obj.message) {
 | |
|                         msg = obj.message;
 | |
|                     }
 | |
|                     else if (contents && contents.length > 0) {
 | |
|                         // it may be the case that the exception is in the body message as string
 | |
|                         msg = contents;
 | |
|                     }
 | |
|                     else {
 | |
|                         msg = `Failed request: (${statusCode})`;
 | |
|                     }
 | |
|                     const err = new HttpClientError(msg, statusCode);
 | |
|                     err.result = response.result;
 | |
|                     reject(err);
 | |
|                 }
 | |
|                 else {
 | |
|                     resolve(response);
 | |
|                 }
 | |
|             }));
 | |
|         });
 | |
|     }
 | |
| }
 | |
| exports.HttpClient = HttpClient;
 | |
| const lowercaseKeys = (obj) => Object.keys(obj).reduce((c, k) => ((c[k.toLowerCase()] = obj[k]), c), {});
 | |
| //# sourceMappingURL=index.js.map
 | |
| 
 | |
| /***/ })
 | |
| 
 | |
| /******/ }); |