2019-11-09 08:24:47 +00:00
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
2020-08-19 03:20:28 +00:00
/******/ var threw = true ;
/******/ try {
/******/ modules [ moduleId ] . call ( module . exports , module , module . exports , _ _webpack _require _ _ ) ;
/******/ threw = false ;
/******/ } finally {
/******/ if ( threw ) delete installedModules [ moduleId ] ;
/******/ }
2019-11-09 08:24:47 +00:00
/******/
/******/ // 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
2020-05-17 09:26:30 +00:00
/******/ return _ _webpack _require _ _ ( 198 ) ;
2019-11-09 08:24:47 +00:00
/******/ } ;
/******/
/******/ // 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
2020-07-16 08:57:13 +00:00
/***/ } ) ,
/***/ 9 :
2020-08-19 03:20:28 +00:00
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
"use strict" ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
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 ( ) ) ;
} ) ;
2020-07-16 08:57:13 +00:00
} ;
2020-08-19 03:20:28 +00:00
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 ;
2020-07-16 08:57:13 +00:00
} ;
2020-08-19 03:20:28 +00:00
Object . defineProperty ( exports , "__esModule" , { value : true } ) ;
const os = _ _importStar ( _ _webpack _require _ _ ( 87 ) ) ;
const events = _ _importStar ( _ _webpack _require _ _ ( 614 ) ) ;
const child = _ _importStar ( _ _webpack _require _ _ ( 129 ) ) ;
const path = _ _importStar ( _ _webpack _require _ _ ( 622 ) ) ;
const io = _ _importStar ( _ _webpack _require _ _ ( 1 ) ) ;
const ioUtil = _ _importStar ( _ _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 || { } ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
_debug ( message ) {
if ( this . options . listeners && this . options . listeners . debug ) {
this . options . listeners . debug ( message ) ;
}
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
_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 ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
_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 ) ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
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 } ` ) ;
2019-11-09 08:24:47 +00:00
}
}
2020-08-19 03:20:28 +00:00
_getSpawnFileName ( ) {
if ( IS _WINDOWS ) {
if ( this . _isCmdFile ( ) ) {
return process . env [ 'COMSPEC' ] || 'cmd.exe' ;
}
}
return this . toolPath ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
_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 ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
_endsWith ( str , end ) {
return str . endsWith ( end ) ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
_isCmdFile ( ) {
const upperToolPath = this . toolPath . toUpperCase ( ) ;
return ( this . _endsWith ( upperToolPath , '.CMD' ) ||
this . _endsWith ( upperToolPath , '.BAT' ) ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
_windowsQuoteCmdArg ( arg ) {
// for .exe, apply the normal quoting rules that libuv applies
if ( ! this . _isCmdFile ( ) ) {
return this . _uvQuoteCmdArg ( arg ) ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
// 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 '""' ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
// 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 ;
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
// short-circuit if quotes not needed
if ( ! needsQuotes ) {
return arg ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
// 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
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
else if ( arg [ i - 1 ] === '"' ) {
quoteHit = true ;
reverse += '"' ; // double the quote
2020-07-16 08:57:13 +00:00
}
else {
2020-08-19 03:20:28 +00:00
quoteHit = false ;
2020-07-16 08:57:13 +00:00
}
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
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 += '\\' ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
else if ( arg [ i - 1 ] === '"' ) {
quoteHit = true ;
reverse += '\\' ;
2019-11-09 08:24:47 +00:00
}
else {
2020-08-19 03:20:28 +00:00
quoteHit = false ;
2019-11-09 08:24:47 +00:00
}
}
2020-08-19 03:20:28 +00:00
reverse += '"' ;
return reverse
. split ( '' )
. reverse ( )
. join ( '' ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
_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 ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
_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 ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
/ * *
* 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 ) ;
}
} ) ;
if ( this . options . input ) {
if ( ! cp . stdin ) {
throw new Error ( 'child process missing stdin' ) ;
}
cp . stdin . end ( this . options . input ) ;
}
} ) ;
} ) ;
2020-07-16 08:57:13 +00:00
}
}
2020-08-19 03:20:28 +00:00
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 ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
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 ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
if ( arg . length > 0 ) {
args . push ( arg . trim ( ) ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
return args ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
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 ;
}
2020-07-17 11:54:39 +00:00
}
2020-08-19 03:20:28 +00:00
CheckComplete ( ) {
if ( this . done ) {
return ;
}
if ( this . processClosed ) {
this . _setResult ( ) ;
}
else if ( this . processExited ) {
this . timeout = setTimeout ( ExecState . HandleTimeout , this . delay , this ) ;
}
2020-07-17 11:54:39 +00:00
}
2020-08-19 03:20:28 +00:00
_debug ( message ) {
this . emit ( 'debug' , message ) ;
2020-07-17 11:54:39 +00:00
}
2020-08-19 03:20:28 +00:00
_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 } ` ) ;
2020-07-17 11:54:39 +00:00
}
2020-08-19 03:20:28 +00:00
else if ( this . processExitCode !== 0 && ! this . options . ignoreReturnCode ) {
error = new Error ( ` The process ' ${ this . toolPath } ' failed with exit code ${ this . processExitCode } ` ) ;
2020-07-17 11:54:39 +00:00
}
2020-08-19 03:20:28 +00:00
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 ) ;
2020-07-17 11:54:39 +00:00
}
2020-08-19 03:20:28 +00:00
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 ( ) ;
2020-07-17 11:54:39 +00:00
}
}
2020-08-19 03:20:28 +00:00
//# sourceMappingURL=toolrunner.js.map
/***/ } ) ,
/***/ 11 :
/***/ ( function ( module ) {
// Returns a wrapper function that returns a wrapped callback
// The wrapper function should do some stuff, and return a
// presumably different callback function.
// This makes sure that own properties are retained, so that
// decorations and such are not lost along the way.
module . exports = wrappy
function wrappy ( fn , cb ) {
if ( fn && cb ) return wrappy ( fn ) ( cb )
if ( typeof fn !== 'function' )
throw new TypeError ( 'need wrapper function' )
Object . keys ( fn ) . forEach ( function ( k ) {
wrapper [ k ] = fn [ k ]
} )
return wrapper
function wrapper ( ) {
var args = new Array ( arguments . length )
for ( var i = 0 ; i < args . length ; i ++ ) {
args [ i ] = arguments [ i ]
}
var ret = fn . apply ( this , args )
var cb = args [ args . length - 1 ]
if ( typeof ret === 'function' && ret !== cb ) {
Object . keys ( cb ) . forEach ( function ( k ) {
ret [ k ] = cb [ k ]
} )
}
return ret
}
}
2020-07-17 11:54:39 +00:00
2020-07-16 08:57:13 +00:00
/***/ } ) ,
2020-08-19 03:20:28 +00:00
/***/ 18 :
/***/ ( function ( module ) {
module . exports = eval ( "require" ) ( "encoding" ) ;
/***/ } ) ,
/***/ 22 :
2020-07-16 08:57:13 +00:00
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
"use strict" ;
2020-08-19 03:20:28 +00:00
Object . defineProperty ( exports , "__esModule" , {
value : true
2020-07-16 08:57:13 +00:00
} ) ;
2020-08-19 03:20:28 +00:00
exports . default = void 0 ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _validate = _interopRequireDefault ( _ _webpack _require _ _ ( 78 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function parse ( uuid ) {
if ( ! ( 0 , _validate . default ) ( uuid ) ) {
throw TypeError ( 'Invalid UUID' ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
let v ;
const arr = new Uint8Array ( 16 ) ; // Parse ########-....-....-....-............
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
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 ........-####-....-....-............
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
arr [ 4 ] = ( v = parseInt ( uuid . slice ( 9 , 13 ) , 16 ) ) >>> 8 ;
arr [ 5 ] = v & 0xff ; // Parse ........-....-####-....-............
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
arr [ 6 ] = ( v = parseInt ( uuid . slice ( 14 , 18 ) , 16 ) ) >>> 8 ;
arr [ 7 ] = v & 0xff ; // Parse ........-....-....-####-............
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
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)
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
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 ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
var _default = parse ;
exports . default = _default ;
2020-07-16 08:57:13 +00:00
/***/ } ) ,
2020-08-19 03:20:28 +00:00
/***/ 49 :
2020-07-16 08:57:13 +00:00
/***/ ( function ( module , _ _unusedexports , _ _webpack _require _ _ ) {
2020-08-19 03:20:28 +00:00
var wrappy = _ _webpack _require _ _ ( 11 )
module . exports = wrappy ( once )
module . exports . strict = wrappy ( onceStrict )
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
once . proto = once ( function ( ) {
Object . defineProperty ( Function . prototype , 'once' , {
value : function ( ) {
return once ( this )
} ,
configurable : true
} )
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( Function . prototype , 'onceStrict' , {
value : function ( ) {
return onceStrict ( this )
} ,
configurable : true
} )
} )
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function once ( fn ) {
var f = function ( ) {
if ( f . called ) return f . value
f . called = true
return f . value = fn . apply ( this , arguments )
}
f . called = false
return f
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
function onceStrict ( fn ) {
var f = function ( ) {
if ( f . called )
throw new Error ( f . onceError )
f . called = true
return f . value = fn . apply ( this , arguments )
}
var name = fn . name || 'Function wrapped with `once`'
f . onceError = name + " shouldn't be called more than once"
f . called = false
return f
}
2020-07-16 08:57:13 +00:00
/***/ } ) ,
2020-08-19 03:20:28 +00:00
/***/ 62 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
2020-07-16 08:57:13 +00:00
"use strict" ;
2020-08-19 03:20:28 +00:00
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 ;
}
} ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _v = _interopRequireDefault ( _ _webpack _require _ _ ( 893 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _v2 = _interopRequireDefault ( _ _webpack _require _ _ ( 209 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _v3 = _interopRequireDefault ( _ _webpack _require _ _ ( 733 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _v4 = _interopRequireDefault ( _ _webpack _require _ _ ( 384 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _nil = _interopRequireDefault ( _ _webpack _require _ _ ( 327 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _version = _interopRequireDefault ( _ _webpack _require _ _ ( 695 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _validate = _interopRequireDefault ( _ _webpack _require _ _ ( 78 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _stringify = _interopRequireDefault ( _ _webpack _require _ _ ( 411 ) ) ;
var _parse = _interopRequireDefault ( _ _webpack _require _ _ ( 22 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
2020-07-16 08:57:13 +00:00
/***/ } ) ,
2020-08-19 03:20:28 +00:00
/***/ 78 :
2020-07-16 08:57:13 +00:00
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , {
value : true
} ) ;
exports . default = void 0 ;
2020-08-19 03:20:28 +00:00
var _regex = _interopRequireDefault ( _ _webpack _require _ _ ( 456 ) ) ;
2020-07-16 08:57:13 +00:00
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
2020-08-19 03:20:28 +00:00
function validate ( uuid ) {
return typeof uuid === 'string' && _regex . default . test ( uuid ) ;
}
var _default = validate ;
2020-07-16 08:57:13 +00:00
exports . default = _default ;
/***/ } ) ,
2020-08-19 03:20:28 +00:00
/***/ 87 :
/***/ ( function ( module ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
module . exports = require ( "os" ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ 129 :
/***/ ( function ( module ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
module . exports = require ( "child_process" ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ 159 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
"use strict" ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
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 . createOrUpdateBranch = exports . tryFetch = void 0 ;
const core = _ _importStar ( _ _webpack _require _ _ ( 470 ) ) ;
const uuid _1 = _ _webpack _require _ _ ( 62 ) ;
const CHERRYPICK _EMPTY = 'The previous cherry-pick is now empty, possibly due to conflict resolution.' ;
function tryFetch ( git , remote , branch ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
try {
yield git . fetch ( [ ` ${ branch } :refs/remotes/ ${ remote } / ${ branch } ` ] , remote ) ;
return true ;
}
catch ( _a ) {
return false ;
}
} ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
exports . tryFetch = tryFetch ;
// Return true if branch2 is ahead of branch1
function isAhead ( git , branch1 , branch2 ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const result = yield git . revList ( [ ` ${ branch1 } ... ${ branch2 } ` ] , [ '--right-only' , '--count' ] ) ;
return Number ( result ) > 0 ;
} ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
// Return true if branch2 is behind branch1
function isBehind ( git , branch1 , branch2 ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const result = yield git . revList ( [ ` ${ branch1 } ... ${ branch2 } ` ] , [ '--left-only' , '--count' ] ) ;
return Number ( result ) > 0 ;
} ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
// Return true if branch2 is even with branch1
function isEven ( git , branch1 , branch2 ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return ( ! ( yield isAhead ( git , branch1 , branch2 ) ) &&
! ( yield isBehind ( git , branch1 , branch2 ) ) ) ;
} ) ;
}
function hasDiff ( git , branch1 , branch2 ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const result = yield git . diff ( [ ` ${ branch1 } .. ${ branch2 } ` ] ) ;
return result . length > 0 ;
} ) ;
}
function splitLines ( multilineString ) {
return multilineString
. split ( '\n' )
. map ( s => s . trim ( ) )
. filter ( x => x !== '' ) ;
}
function createOrUpdateBranch ( git , commitMessage , base , branch , branchRemoteName , signoff ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
// Get the working base. This may or may not be the actual base.
const workingBase = yield git . symbolicRef ( 'HEAD' , [ '--short' ] ) ;
// If the base is not specified it is assumed to be the working base.
base = base ? base : workingBase ;
const baseRemote = 'origin' ;
// Set the default return values
const result = {
action : 'none' ,
base : base ,
hasDiffWithBase : false
} ;
// Save the working base changes to a temporary branch
const tempBranch = uuid _1 . v4 ( ) ;
yield git . checkout ( tempBranch , 'HEAD' ) ;
// Commit any uncommitted changes
if ( yield git . isDirty ( true ) ) {
core . info ( 'Uncommitted changes found. Adding a commit.' ) ;
yield git . exec ( [ 'add' , '-A' ] ) ;
const params = [ '-m' , commitMessage ] ;
if ( signoff ) {
params . push ( '--signoff' ) ;
}
yield git . commit ( params ) ;
}
// Perform fetch and reset the working base
// Commits made during the workflow will be removed
yield git . fetch ( [ ` ${ workingBase } : ${ workingBase } ` ] , baseRemote , [ '--force' ] ) ;
// If the working base is not the base, rebase the temp branch commits
if ( workingBase != base ) {
core . info ( ` Rebasing commits made to branch ' ${ workingBase } ' on to base branch ' ${ base } ' ` ) ;
// Checkout the actual base
yield git . fetch ( [ ` ${ base } : ${ base } ` ] , baseRemote , [ '--force' ] ) ;
yield git . checkout ( base ) ;
// Cherrypick commits from the temporary branch starting from the working base
const commits = yield git . revList ( [ ` ${ workingBase } .. ${ tempBranch } ` , '.' ] , [ '--reverse' ] ) ;
for ( const commit of splitLines ( commits ) ) {
const result = yield git . cherryPick ( [ '--strategy=recursive' , '--strategy-option=theirs' , commit ] , true ) ;
if ( result . exitCode != 0 && ! result . stderr . includes ( CHERRYPICK _EMPTY ) ) {
throw new Error ( ` Unexpected error: ${ result . stderr } ` ) ;
}
}
// Reset the temp branch to the working index
yield git . checkout ( tempBranch , 'HEAD' ) ;
// Reset the base
yield git . fetch ( [ ` ${ base } : ${ base } ` ] , baseRemote , [ '--force' ] ) ;
}
// Try to fetch the pull request branch
if ( ! ( yield tryFetch ( git , branchRemoteName , branch ) ) ) {
// The pull request branch does not exist
core . info ( ` Pull request branch ' ${ branch } ' does not exist yet. ` ) ;
// Create the pull request branch
yield git . checkout ( branch , 'HEAD' ) ;
// Check if the pull request branch is ahead of the base
result . hasDiffWithBase = yield isAhead ( git , base , branch ) ;
if ( result . hasDiffWithBase ) {
result . action = 'created' ;
core . info ( ` Created branch ' ${ branch } ' ` ) ;
}
else {
core . info ( ` Branch ' ${ branch } ' is not ahead of base ' ${ base } ' and will not be created ` ) ;
}
}
else {
// The pull request branch exists
core . info ( ` Pull request branch ' ${ branch } ' already exists as remote branch ' ${ branchRemoteName } / ${ branch } ' ` ) ;
// Checkout the pull request branch
yield git . checkout ( branch ) ;
if ( yield hasDiff ( git , branch , tempBranch ) ) {
// If the branch differs from the recreated temp version then the branch is reset
// For changes on base this action is similar to a rebase of the pull request branch
core . info ( ` Resetting ' ${ branch } ' ` ) ;
// Alternatively, git switch -C branch tempBranch
yield git . checkout ( branch , tempBranch ) ;
}
// Check if the pull request branch has been updated
// If the branch was reset or updated it will be ahead
// It may be behind if a reset now results in no diff with the base
if ( ! ( yield isEven ( git , ` ${ branchRemoteName } / ${ branch } ` , branch ) ) ) {
result . action = 'updated' ;
core . info ( ` Updated branch ' ${ branch } ' ` ) ;
}
else {
core . info ( ` Branch ' ${ branch } ' is even with its remote and will not be updated ` ) ;
}
// Check if the pull request branch is ahead of the base
result . hasDiffWithBase = yield isAhead ( git , base , branch ) ;
}
// Delete the temporary branch
yield git . exec ( [ 'branch' , '--delete' , '--force' , tempBranch ] ) ;
return result ;
} ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
exports . createOrUpdateBranch = createOrUpdateBranch ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ 198 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
"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 } ) ;
const core = _ _importStar ( _ _webpack _require _ _ ( 470 ) ) ;
const create _pull _request _1 = _ _webpack _require _ _ ( 940 ) ;
const util _1 = _ _webpack _require _ _ ( 669 ) ;
const utils = _ _importStar ( _ _webpack _require _ _ ( 611 ) ) ;
function run ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
try {
const inputs = {
token : core . getInput ( 'token' ) ,
path : core . getInput ( 'path' ) ,
commitMessage : core . getInput ( 'commit-message' ) ,
committer : core . getInput ( 'committer' ) ,
author : core . getInput ( 'author' ) ,
signoff : core . getInput ( 'signoff' ) === 'true' ,
branch : core . getInput ( 'branch' ) ,
branchSuffix : core . getInput ( 'branch-suffix' ) ,
base : core . getInput ( 'base' ) ,
pushToFork : core . getInput ( 'push-to-fork' ) ,
title : core . getInput ( 'title' ) ,
body : core . getInput ( 'body' ) ,
labels : utils . getInputAsArray ( 'labels' ) ,
assignees : utils . getInputAsArray ( 'assignees' ) ,
reviewers : utils . getInputAsArray ( 'reviewers' ) ,
teamReviewers : utils . getInputAsArray ( 'team-reviewers' ) ,
milestone : Number ( core . getInput ( 'milestone' ) ) ,
draft : core . getInput ( 'draft' ) === 'true'
} ;
core . debug ( ` Inputs: ${ util _1 . inspect ( inputs ) } ` ) ;
yield create _pull _request _1 . createPullRequest ( inputs ) ;
}
catch ( error ) {
core . setFailed ( error . message ) ;
}
} ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
run ( ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ 209 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
"use strict" ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( exports , "__esModule" , {
value : true
} ) ;
exports . default = void 0 ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _v = _interopRequireDefault ( _ _webpack _require _ _ ( 212 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _md = _interopRequireDefault ( _ _webpack _require _ _ ( 803 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const v3 = ( 0 , _v . default ) ( 'v3' , 0x30 , _md . default ) ;
var _default = v3 ;
exports . default = _default ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ 211 :
/***/ ( function ( module ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
module . exports = require ( "https" ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ 212 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
"use strict" ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( exports , "__esModule" , {
value : true
} ) ;
exports . default = _default ;
exports . URL = exports . DNS = void 0 ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _stringify = _interopRequireDefault ( _ _webpack _require _ _ ( 411 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _parse = _interopRequireDefault ( _ _webpack _require _ _ ( 22 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function stringToBytes ( str ) {
str = unescape ( encodeURIComponent ( str ) ) ; // UTF8 escape
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const bytes = [ ] ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
for ( let i = 0 ; i < str . length ; ++ i ) {
bytes . push ( str . charCodeAt ( i ) ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return bytes ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8' ;
exports . DNS = DNS ;
const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8' ;
exports . URL = URL ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function _default ( name , version , hashfunc ) {
function generateUUID ( value , namespace , buf , offset ) {
if ( typeof value === 'string' ) {
value = stringToBytes ( value ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
if ( typeof namespace === 'string' ) {
namespace = ( 0 , _parse . default ) ( namespace ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
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])`
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
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 ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( buf ) {
offset = offset || 0 ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
for ( let i = 0 ; i < 16 ; ++ i ) {
buf [ offset + i ] = bytes [ i ] ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return buf ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return ( 0 , _stringify . default ) ( bytes ) ;
} // Function#name is not settable on some platforms (#270)
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
try {
generateUUID . name = name ; // eslint-disable-next-line no-empty
} catch ( err ) { } // For CommonJS default export support
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
generateUUID . DNS = DNS ;
generateUUID . URL = URL ;
return generateUUID ;
2020-07-16 08:57:13 +00:00
}
/***/ } ) ,
2020-08-19 03:20:28 +00:00
/***/ 280 :
2020-07-16 08:57:13 +00:00
/***/ ( function ( module ) {
2020-08-19 03:20:28 +00:00
module . exports = register
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function register ( state , name , method , options ) {
if ( typeof method !== 'function' ) {
throw new Error ( 'method for before hook must be a function' )
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( ! options ) {
options = { }
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( Array . isArray ( name ) ) {
return name . reverse ( ) . reduce ( function ( callback , name ) {
return register . bind ( null , state , name , callback , options )
} , method ) ( )
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return Promise . resolve ( )
. then ( function ( ) {
if ( ! state . registry [ name ] ) {
return method ( options )
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return ( state . registry [ name ] ) . reduce ( function ( method , registered ) {
return registered . hook . bind ( null , method , options )
} , method ) ( )
} )
2020-07-16 08:57:13 +00:00
}
/***/ } ) ,
2020-08-19 03:20:28 +00:00
/***/ 287 :
2020-07-16 08:57:13 +00:00
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
"use strict" ;
2020-08-19 03:20:28 +00:00
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 ;
} ) ;
2020-07-16 08:57:13 +00:00
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
2020-08-19 03:20:28 +00:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
2020-07-16 08:57:13 +00:00
return result ;
} ;
2020-08-19 03:20:28 +00:00
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 ( ) ) ;
} ) ;
} ;
2020-07-16 08:57:13 +00:00
Object . defineProperty ( exports , "__esModule" , { value : true } ) ;
2020-08-19 03:20:28 +00:00
exports . GitAuthHelper = void 0 ;
const core = _ _importStar ( _ _webpack _require _ _ ( 470 ) ) ;
const fs = _ _importStar ( _ _webpack _require _ _ ( 747 ) ) ;
const path = _ _importStar ( _ _webpack _require _ _ ( 622 ) ) ;
const url _1 = _ _webpack _require _ _ ( 835 ) ;
class GitAuthHelper {
constructor ( git ) {
this . extraheaderConfigPlaceholderValue = 'AUTHORIZATION: basic ***' ;
this . extraheaderConfigValueRegex = '^AUTHORIZATION:' ;
this . persistedExtraheaderConfigValue = '' ;
this . git = git ;
this . gitConfigPath = path . join ( this . git . getWorkingDirectory ( ) , '.git' , 'config' ) ;
const serverUrl = this . getServerUrl ( ) ;
this . extraheaderConfigKey = ` http. ${ serverUrl . origin } /.extraheader ` ;
}
savePersistedAuth ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
// Save and unset persisted extraheader credential in git config if it exists
this . persistedExtraheaderConfigValue = yield this . getAndUnset ( ) ;
} ) ;
}
restorePersistedAuth ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( this . persistedExtraheaderConfigValue ) {
try {
yield this . setExtraheaderConfig ( this . persistedExtraheaderConfigValue ) ;
core . info ( 'Persisted git credentials restored' ) ;
}
catch ( e ) {
core . warning ( e ) ;
2020-05-02 08:45:04 +00:00
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
} ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
configureToken ( token ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
// Encode and configure the basic credential for HTTPS access
const basicCredential = Buffer . from ( ` x-access-token: ${ token } ` , 'utf8' ) . toString ( 'base64' ) ;
core . setSecret ( basicCredential ) ;
const extraheaderConfigValue = ` AUTHORIZATION: basic ${ basicCredential } ` ;
yield this . setExtraheaderConfig ( extraheaderConfigValue ) ;
} ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
removeAuth ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
yield this . getAndUnset ( ) ;
} ) ;
}
setExtraheaderConfig ( extraheaderConfigValue ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
// Configure a placeholder value. This approach avoids the credential being captured
// by process creation audit events, which are commonly logged. For more information,
// refer to https://docs.microsoft.com/en-us/windows-server/identity/ad-ds/manage/component-updates/command-line-process-auditing
// See https://github.com/actions/checkout/blob/main/src/git-auth-helper.ts#L267-L274
yield this . git . config ( this . extraheaderConfigKey , this . extraheaderConfigPlaceholderValue ) ;
// Replace the placeholder
yield this . gitConfigStringReplace ( this . extraheaderConfigPlaceholderValue , extraheaderConfigValue ) ;
} ) ;
}
getAndUnset ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
let configValue = '' ;
// Save and unset persisted extraheader credential in git config if it exists
if ( yield this . git . configExists ( this . extraheaderConfigKey , this . extraheaderConfigValueRegex ) ) {
configValue = yield this . git . getConfigValue ( this . extraheaderConfigKey , this . extraheaderConfigValueRegex ) ;
if ( yield this . git . tryConfigUnset ( this . extraheaderConfigKey , this . extraheaderConfigValueRegex ) ) {
core . info ( ` Unset config key ' ${ this . extraheaderConfigKey } ' ` ) ;
}
else {
core . warning ( ` Failed to unset config key ' ${ this . extraheaderConfigKey } ' ` ) ;
}
}
return configValue ;
} ) ;
}
gitConfigStringReplace ( find , replace ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
let content = ( yield fs . promises . readFile ( this . gitConfigPath ) ) . toString ( ) ;
const index = content . indexOf ( find ) ;
if ( index < 0 || index != content . lastIndexOf ( find ) ) {
throw new Error ( ` Unable to replace ' ${ find } ' in ${ this . gitConfigPath } ` ) ;
}
content = content . replace ( find , replace ) ;
yield fs . promises . writeFile ( this . gitConfigPath , content ) ;
} ) ;
}
getServerUrl ( ) {
// todo: remove GITHUB_URL after support for GHES Alpha is no longer needed
// See https://github.com/actions/checkout/blob/main/src/url-helper.ts#L22-L29
return new url _1 . URL ( process . env [ 'GITHUB_SERVER_URL' ] ||
process . env [ 'GITHUB_URL' ] ||
'https://github.com' ) ;
2020-07-16 08:57:13 +00:00
}
}
2020-08-19 03:20:28 +00:00
exports . GitAuthHelper = GitAuthHelper ;
2020-07-16 08:57:13 +00:00
/***/ } ) ,
2020-08-19 03:20:28 +00:00
/***/ 289 :
2020-07-16 08:57:13 +00:00
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
"use strict" ;
2020-08-19 03:20:28 +00:00
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 ( ) ) ;
2020-07-16 08:57:13 +00:00
} ) ;
2020-08-19 03:20:28 +00:00
} ;
Object . defineProperty ( exports , "__esModule" , { value : true } ) ;
exports . GitCommandManager = void 0 ;
const exec = _ _importStar ( _ _webpack _require _ _ ( 986 ) ) ;
const io = _ _importStar ( _ _webpack _require _ _ ( 1 ) ) ;
const utils = _ _importStar ( _ _webpack _require _ _ ( 611 ) ) ;
const path = _ _importStar ( _ _webpack _require _ _ ( 622 ) ) ;
const tagsRefSpec = '+refs/tags/*:refs/tags/*' ;
class GitCommandManager {
constructor ( workingDirectory , gitPath ) {
this . workingDirectory = workingDirectory ;
this . gitPath = gitPath ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
static create ( workingDirectory ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const gitPath = yield io . which ( 'git' , true ) ;
return new GitCommandManager ( workingDirectory , gitPath ) ;
} ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
setIdentityGitOptions ( identityGitOptions ) {
this . identityGitOptions = identityGitOptions ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
checkout ( ref , startPoint ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const args = [ 'checkout' , '--progress' ] ;
if ( startPoint ) {
args . push ( '-B' , ref , startPoint ) ;
}
else {
args . push ( ref ) ;
}
yield this . exec ( args ) ;
2020-07-16 08:57:13 +00:00
} ) ;
2020-08-19 03:20:28 +00:00
}
cherryPick ( options , allowAllExitCodes = false ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const args = [ 'cherry-pick' ] ;
if ( this . identityGitOptions ) {
args . unshift ( ... this . identityGitOptions ) ;
}
if ( options ) {
args . push ( ... options ) ;
}
return yield this . exec ( args , allowAllExitCodes ) ;
} ) ;
}
commit ( options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const args = [ 'commit' ] ;
if ( this . identityGitOptions ) {
args . unshift ( ... this . identityGitOptions ) ;
}
if ( options ) {
args . push ( ... options ) ;
}
yield this . exec ( args ) ;
} ) ;
}
config ( configKey , configValue , globalConfig ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
yield this . exec ( [
'config' ,
globalConfig ? '--global' : '--local' ,
configKey ,
configValue
] ) ;
} ) ;
}
configExists ( configKey , configValue = '.' , globalConfig ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const output = yield this . exec ( [
'config' ,
globalConfig ? '--global' : '--local' ,
'--name-only' ,
'--get-regexp' ,
configKey ,
configValue
] , true ) ;
return output . exitCode === 0 ;
} ) ;
}
diff ( options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const args = [ '-c' , 'core.pager=cat' , 'diff' ] ;
if ( options ) {
args . push ( ... options ) ;
}
const output = yield this . exec ( args ) ;
return output . stdout . trim ( ) ;
} ) ;
}
fetch ( refSpec , remoteName , options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const args = [ '-c' , 'protocol.version=2' , 'fetch' ] ;
if ( ! refSpec . some ( x => x === tagsRefSpec ) ) {
args . push ( '--no-tags' ) ;
}
args . push ( '--progress' , '--no-recurse-submodules' ) ;
if ( utils . fileExistsSync ( path . join ( this . workingDirectory , '.git' , 'shallow' ) ) ) {
args . push ( '--unshallow' ) ;
}
if ( options ) {
args . push ( ... options ) ;
}
if ( remoteName ) {
args . push ( remoteName ) ;
}
else {
args . push ( 'origin' ) ;
}
for ( const arg of refSpec ) {
args . push ( arg ) ;
}
yield this . exec ( args ) ;
} ) ;
}
getConfigValue ( configKey , configValue = '.' ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const output = yield this . exec ( [
'config' ,
'--local' ,
'--get-regexp' ,
configKey ,
configValue
] ) ;
return output . stdout . trim ( ) . split ( ` ${ configKey } ` ) [ 1 ] ;
} ) ;
}
getWorkingDirectory ( ) {
return this . workingDirectory ;
}
isDirty ( untracked ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const diffArgs = [ '--abbrev=40' , '--full-index' , '--raw' ] ;
// Check staged changes
if ( yield this . diff ( [ ... diffArgs , '--staged' ] ) ) {
return true ;
}
// Check working index changes
if ( yield this . diff ( diffArgs ) ) {
return true ;
}
// Check untracked changes
if ( untracked && ( yield this . status ( [ '--porcelain' , '-unormal' ] ) ) ) {
return true ;
}
return false ;
} ) ;
}
push ( options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const args = [ 'push' ] ;
if ( options ) {
args . push ( ... options ) ;
}
yield this . exec ( args ) ;
} ) ;
}
revList ( commitExpression , options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const args = [ 'rev-list' ] ;
if ( options ) {
args . push ( ... options ) ;
}
args . push ( ... commitExpression ) ;
const output = yield this . exec ( args ) ;
return output . stdout . trim ( ) ;
} ) ;
}
revParse ( ref , options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const args = [ 'rev-parse' ] ;
if ( options ) {
args . push ( ... options ) ;
}
args . push ( ref ) ;
const output = yield this . exec ( args ) ;
return output . stdout . trim ( ) ;
} ) ;
}
status ( options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const args = [ 'status' ] ;
if ( options ) {
args . push ( ... options ) ;
}
const output = yield this . exec ( args ) ;
return output . stdout . trim ( ) ;
} ) ;
}
symbolicRef ( ref , options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const args = [ 'symbolic-ref' , ref ] ;
if ( options ) {
args . push ( ... options ) ;
}
const output = yield this . exec ( args ) ;
return output . stdout . trim ( ) ;
} ) ;
}
tryConfigUnset ( configKey , configValue = '.' , globalConfig ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const output = yield this . exec ( [
'config' ,
globalConfig ? '--global' : '--local' ,
'--unset' ,
configKey ,
configValue
] , true ) ;
return output . exitCode === 0 ;
} ) ;
}
tryGetRemoteUrl ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const output = yield this . exec ( [ 'config' , '--local' , '--get' , 'remote.origin.url' ] , true ) ;
if ( output . exitCode !== 0 ) {
return '' ;
}
const stdout = output . stdout . trim ( ) ;
if ( stdout . includes ( '\n' ) ) {
return '' ;
}
return stdout ;
} ) ;
}
exec ( args , allowAllExitCodes = false ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const result = new GitOutput ( ) ;
const env = { } ;
for ( const key of Object . keys ( process . env ) ) {
env [ key ] = process . env [ key ] ;
}
const stdout = [ ] ;
const stderr = [ ] ;
const options = {
cwd : this . workingDirectory ,
env ,
ignoreReturnCode : allowAllExitCodes ,
listeners : {
stdout : ( data ) => {
stdout . push ( data . toString ( ) ) ;
} ,
stderr : ( data ) => {
stderr . push ( data . toString ( ) ) ;
}
}
} ;
result . exitCode = yield exec . exec ( ` " ${ this . gitPath } " ` , args , options ) ;
result . stdout = stdout . join ( '' ) ;
result . stderr = stderr . join ( '' ) ;
return result ;
} ) ;
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
exports . GitCommandManager = GitCommandManager ;
class GitOutput {
constructor ( ) {
this . stdout = '' ;
this . stderr = '' ;
this . exitCode = 0 ;
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ 299 :
/***/ ( function ( _ _unusedmodule , exports ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
"use strict" ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( exports , '__esModule' , { value : true } ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const VERSION = "2.3.0" ;
2020-07-16 08:57:13 +00:00
/ * *
2020-08-19 03:20:28 +00:00
* Some “ list ” response that can be paginated have a different response structure
2020-07-16 08:57:13 +00:00
*
2020-08-19 03:20:28 +00:00
* They have a ` total_count ` key in the response ( search also has ` incomplete_results ` ,
* / i n s t a l l a t i o n / r e p o s i t o r i e s a l s o h a s ` r e p o s i t o r y _ s e l e c t i o n ` ) , a s w e l l a s a k e y w i t h
* the list of the items which name varies from endpoint to endpoint .
2020-07-16 08:57:13 +00:00
*
2020-08-19 03:20:28 +00:00
* Octokit normalizes these responses so that paginated results are always returned following
* the same structure . One challenge is that if the list response has only one page , no Link
* header is provided , so this header alone is not sufficient to check wether a response is
* paginated or not .
*
* We check if a "total_count" key is present in the response data , but also make sure that
* a "url" property is not , as the "Get the combined status for a specific ref" endpoint would
* otherwise match : https : //developer.github.com/v3/repos/statuses/#get-the-combined-status-for-a-specific-ref
2020-07-16 08:57:13 +00:00
* /
2020-08-19 03:20:28 +00:00
function normalizePaginatedListResponse ( response ) {
const responseNeedsNormalization = "total_count" in response . data && ! ( "url" in response . data ) ;
if ( ! responseNeedsNormalization ) return response ; // keep the additional properties intact as there is currently no other way
// to retrieve the same information.
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const incompleteResults = response . data . incomplete _results ;
const repositorySelection = response . data . repository _selection ;
const totalCount = response . data . total _count ;
delete response . data . incomplete _results ;
delete response . data . repository _selection ;
delete response . data . total _count ;
const namespaceKey = Object . keys ( response . data ) [ 0 ] ;
const data = response . data [ namespaceKey ] ;
response . data = data ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( typeof incompleteResults !== "undefined" ) {
response . data . incomplete _results = incompleteResults ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( typeof repositorySelection !== "undefined" ) {
response . data . repository _selection = repositorySelection ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
response . data . total _count = totalCount ;
return response ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function iterator ( octokit , route , parameters ) {
const options = typeof route === "function" ? route . endpoint ( parameters ) : octokit . request . endpoint ( route , parameters ) ;
const requestMethod = typeof route === "function" ? route : octokit . request ;
const method = options . method ;
const headers = options . headers ;
let url = options . url ;
return {
[ Symbol . asyncIterator ] : ( ) => ( {
next ( ) {
if ( ! url ) {
return Promise . resolve ( {
done : true
} ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return requestMethod ( {
method ,
url ,
headers
} ) . then ( normalizePaginatedListResponse ) . then ( response => {
// `response.headers.link` format:
// '<https://api.github.com/users/aseemk/followers?page=2>; rel="next", <https://api.github.com/users/aseemk/followers?page=2>; rel="last"'
// sets `url` to undefined if "next" URL is not present or `link` header is not set
url = ( ( response . headers . link || "" ) . match ( /<([^>]+)>;\s*rel="next"/ ) || [ ] ) [ 1 ] ;
return {
value : response
} ;
} ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
} )
} ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function paginate ( octokit , route , parameters , mapFn ) {
if ( typeof parameters === "function" ) {
mapFn = parameters ;
parameters = undefined ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return gather ( octokit , [ ] , iterator ( octokit , route , parameters ) [ Symbol . asyncIterator ] ( ) , mapFn ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function gather ( octokit , results , iterator , mapFn ) {
return iterator . next ( ) . then ( result => {
if ( result . done ) {
return results ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
let earlyExit = false ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function done ( ) {
earlyExit = true ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
results = results . concat ( mapFn ? mapFn ( result . value , done ) : result . value . data ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( earlyExit ) {
return results ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return gather ( octokit , results , iterator , mapFn ) ;
} ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* @ param octokit Octokit instance
* @ param options Options passed to Octokit constructor
* /
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function paginateRest ( octokit ) {
return {
paginate : Object . assign ( paginate . bind ( null , octokit ) , {
iterator : iterator . bind ( null , octokit )
} )
} ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
paginateRest . VERSION = VERSION ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
exports . paginateRest = paginateRest ;
//# sourceMappingURL=index.js.map
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ 327 :
/***/ ( function ( _ _unusedmodule , exports ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
"use strict" ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( exports , "__esModule" , {
value : true
} ) ;
exports . default = void 0 ;
var _default = '00000000-0000-0000-0000-000000000000' ;
exports . default = _default ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ 357 :
/***/ ( function ( module ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
module . exports = require ( "assert" ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ } ) ,
/***/ 384 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
"use strict" ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( exports , "__esModule" , {
value : true
} ) ;
exports . default = void 0 ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _v = _interopRequireDefault ( _ _webpack _require _ _ ( 212 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _sha = _interopRequireDefault ( _ _webpack _require _ _ ( 498 ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const v5 = ( 0 , _v . default ) ( 'v5' , 0x50 , _sha . default ) ;
var _default = v5 ;
exports . default = _default ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/***/ 385 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
"use strict" ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( exports , '__esModule' , { value : true } ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function _interopDefault ( ex ) { return ( ex && ( typeof ex === 'object' ) && 'default' in ex ) ? ex [ 'default' ] : ex ; }
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var isPlainObject = _interopDefault ( _ _webpack _require _ _ ( 626 ) ) ;
var universalUserAgent = _ _webpack _require _ _ ( 796 ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function lowercaseKeys ( object ) {
if ( ! object ) {
return { } ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return Object . keys ( object ) . reduce ( ( newObj , key ) => {
newObj [ key . toLowerCase ( ) ] = object [ key ] ;
return newObj ;
} , { } ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function mergeDeep ( defaults , options ) {
const result = Object . assign ( { } , defaults ) ;
Object . keys ( options ) . forEach ( key => {
if ( isPlainObject ( options [ key ] ) ) {
if ( ! ( key in defaults ) ) Object . assign ( result , {
[ key ] : options [ key ]
} ) ; else result [ key ] = mergeDeep ( defaults [ key ] , options [ key ] ) ;
} else {
Object . assign ( result , {
[ key ] : options [ key ]
} ) ;
}
} ) ;
return result ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function merge ( defaults , route , options ) {
if ( typeof route === "string" ) {
let [ method , url ] = route . split ( " " ) ;
options = Object . assign ( url ? {
method ,
url
} : {
url : method
} , options ) ;
} else {
options = Object . assign ( { } , route ) ;
} // lowercase header names before merging with defaults to avoid duplicates
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
options . headers = lowercaseKeys ( options . headers ) ;
const mergedOptions = mergeDeep ( defaults || { } , options ) ; // mediaType.previews arrays are merged, instead of overwritten
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( defaults && defaults . mediaType . previews . length ) {
mergedOptions . mediaType . previews = defaults . mediaType . previews . filter ( preview => ! mergedOptions . mediaType . previews . includes ( preview ) ) . concat ( mergedOptions . mediaType . previews ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
mergedOptions . mediaType . previews = mergedOptions . mediaType . previews . map ( preview => preview . replace ( /-preview/ , "" ) ) ;
return mergedOptions ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function addQueryParameters ( url , parameters ) {
const separator = /\?/ . test ( url ) ? "&" : "?" ;
const names = Object . keys ( parameters ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( names . length === 0 ) {
return url ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return url + separator + names . map ( name => {
if ( name === "q" ) {
return "q=" + parameters . q . split ( "+" ) . map ( encodeURIComponent ) . join ( "+" ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return ` ${ name } = ${ encodeURIComponent ( parameters [ name ] ) } ` ;
} ) . join ( "&" ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const urlVariableRegex = /\{[^}]+\}/g ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function removeNonChars ( variableName ) {
return variableName . replace ( /^\W+|\W+$/g , "" ) . split ( /,/ ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function extractUrlVariableNames ( url ) {
const matches = url . match ( urlVariableRegex ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( ! matches ) {
return [ ] ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return matches . map ( removeNonChars ) . reduce ( ( a , b ) => a . concat ( b ) , [ ] ) ;
}
function omit ( object , keysToOmit ) {
return Object . keys ( object ) . filter ( option => ! keysToOmit . includes ( option ) ) . reduce ( ( obj , key ) => {
obj [ key ] = object [ key ] ;
return obj ;
} , { } ) ;
}
// Based on https://github.com/bramstein/url-template, licensed under BSD
// TODO: create separate package.
//
// Copyright (c) 2012-2014, Bram Stein
// All rights reserved.
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions
// are met:
// 1. Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// 2. Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
// 3. The name of the author may not be used to endorse or promote products
// derived from this software without specific prior written permission.
// THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED
// WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
// EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
// INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
// BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/* istanbul ignore file */
function encodeReserved ( str ) {
return str . split ( /(%[0-9A-Fa-f]{2})/g ) . map ( function ( part ) {
if ( ! /%[0-9A-Fa-f]/ . test ( part ) ) {
part = encodeURI ( part ) . replace ( /%5B/g , "[" ) . replace ( /%5D/g , "]" ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return part ;
} ) . join ( "" ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function encodeUnreserved ( str ) {
return encodeURIComponent ( str ) . replace ( /[!'()*]/g , function ( c ) {
return "%" + c . charCodeAt ( 0 ) . toString ( 16 ) . toUpperCase ( ) ;
} ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function encodeValue ( operator , value , key ) {
value = operator === "+" || operator === "#" ? encodeReserved ( value ) : encodeUnreserved ( value ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( key ) {
return encodeUnreserved ( key ) + "=" + value ;
} else {
return value ;
}
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function isDefined ( value ) {
return value !== undefined && value !== null ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function isKeyOperator ( operator ) {
return operator === ";" || operator === "&" || operator === "?" ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function getValues ( context , operator , key , modifier ) {
var value = context [ key ] ,
result = [ ] ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( isDefined ( value ) && value !== "" ) {
if ( typeof value === "string" || typeof value === "number" || typeof value === "boolean" ) {
value = value . toString ( ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( modifier && modifier !== "*" ) {
value = value . substring ( 0 , parseInt ( modifier , 10 ) ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
result . push ( encodeValue ( operator , value , isKeyOperator ( operator ) ? key : "" ) ) ;
} else {
if ( modifier === "*" ) {
if ( Array . isArray ( value ) ) {
value . filter ( isDefined ) . forEach ( function ( value ) {
result . push ( encodeValue ( operator , value , isKeyOperator ( operator ) ? key : "" ) ) ;
} ) ;
} else {
Object . keys ( value ) . forEach ( function ( k ) {
if ( isDefined ( value [ k ] ) ) {
result . push ( encodeValue ( operator , value [ k ] , k ) ) ;
}
} ) ;
}
} else {
const tmp = [ ] ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( Array . isArray ( value ) ) {
value . filter ( isDefined ) . forEach ( function ( value ) {
tmp . push ( encodeValue ( operator , value ) ) ;
} ) ;
} else {
Object . keys ( value ) . forEach ( function ( k ) {
if ( isDefined ( value [ k ] ) ) {
tmp . push ( encodeUnreserved ( k ) ) ;
tmp . push ( encodeValue ( operator , value [ k ] . toString ( ) ) ) ;
}
} ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( isKeyOperator ( operator ) ) {
result . push ( encodeUnreserved ( key ) + "=" + tmp . join ( "," ) ) ;
} else if ( tmp . length !== 0 ) {
result . push ( tmp . join ( "," ) ) ;
}
}
}
} else {
if ( operator === ";" ) {
if ( isDefined ( value ) ) {
result . push ( encodeUnreserved ( key ) ) ;
}
} else if ( value === "" && ( operator === "&" || operator === "?" ) ) {
result . push ( encodeUnreserved ( key ) + "=" ) ;
} else if ( value === "" ) {
result . push ( "" ) ;
}
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return result ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
function parseUrl ( template ) {
return {
expand : expand . bind ( null , template )
} ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function expand ( template , context ) {
var operators = [ "+" , "#" , "." , "/" , ";" , "?" , "&" ] ;
return template . replace ( /\{([^\{\}]+)\}|([^\{\}]+)/g , function ( _ , expression , literal ) {
if ( expression ) {
let operator = "" ;
const values = [ ] ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( operators . indexOf ( expression . charAt ( 0 ) ) !== - 1 ) {
operator = expression . charAt ( 0 ) ;
expression = expression . substr ( 1 ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
expression . split ( /,/g ) . forEach ( function ( variable ) {
var tmp = /([^:\*]*)(?::(\d+)|(\*))?/ . exec ( variable ) ;
values . push ( getValues ( context , operator , tmp [ 1 ] , tmp [ 2 ] || tmp [ 3 ] ) ) ;
} ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( operator && operator !== "+" ) {
var separator = "," ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( operator === "?" ) {
separator = "&" ;
} else if ( operator !== "#" ) {
separator = operator ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return ( values . length !== 0 ? operator : "" ) + values . join ( separator ) ;
} else {
return values . join ( "," ) ;
}
} else {
return encodeReserved ( literal ) ;
}
} ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function parse ( options ) {
// https://fetch.spec.whatwg.org/#methods
let method = options . method . toUpperCase ( ) ; // replace :varname with {varname} to make it RFC 6570 compatible
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
let url = ( options . url || "/" ) . replace ( /:([a-z]\w+)/g , "{+$1}" ) ;
let headers = Object . assign ( { } , options . headers ) ;
let body ;
let parameters = omit ( options , [ "method" , "baseUrl" , "url" , "headers" , "request" , "mediaType" ] ) ; // extract variable names from URL to calculate remaining variables later
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const urlVariableNames = extractUrlVariableNames ( url ) ;
url = parseUrl ( url ) . expand ( parameters ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( ! /^http/ . test ( url ) ) {
url = options . baseUrl + url ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const omittedParameters = Object . keys ( options ) . filter ( option => urlVariableNames . includes ( option ) ) . concat ( "baseUrl" ) ;
const remainingParameters = omit ( parameters , omittedParameters ) ;
const isBinaryRequset = /application\/octet-stream/i . test ( headers . accept ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( ! isBinaryRequset ) {
if ( options . mediaType . format ) {
// e.g. application/vnd.github.v3+json => application/vnd.github.v3.raw
headers . accept = headers . accept . split ( /,/ ) . map ( preview => preview . replace ( /application\/vnd(\.\w+)(\.v3)?(\.\w+)?(\+json)?$/ , ` application/vnd $ 1 $ 2. ${ options . mediaType . format } ` ) ) . join ( "," ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( options . mediaType . previews . length ) {
const previewsFromAcceptHeader = headers . accept . match ( /[\w-]+(?=-preview)/g ) || [ ] ;
headers . accept = previewsFromAcceptHeader . concat ( options . mediaType . previews ) . map ( preview => {
const format = options . mediaType . format ? ` . ${ options . mediaType . format } ` : "+json" ;
return ` application/vnd.github. ${ preview } -preview ${ format } ` ;
} ) . join ( "," ) ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
} // for GET/HEAD requests, set URL query parameters from remaining parameters
// for PATCH/POST/PUT/DELETE requests, set request body from remaining parameters
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( [ "GET" , "HEAD" ] . includes ( method ) ) {
url = addQueryParameters ( url , remainingParameters ) ;
} else {
if ( "data" in remainingParameters ) {
body = remainingParameters . data ;
} else {
if ( Object . keys ( remainingParameters ) . length ) {
body = remainingParameters ;
} else {
headers [ "content-length" ] = 0 ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
}
} // default content-type for JSON if body is set
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( ! headers [ "content-type" ] && typeof body !== "undefined" ) {
headers [ "content-type" ] = "application/json; charset=utf-8" ;
} // GitHub expects 'content-length: 0' header for PUT/PATCH requests without body.
// fetch does not allow to set `content-length` header, but we can set body to an empty string
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( [ "PATCH" , "PUT" ] . includes ( method ) && typeof body === "undefined" ) {
body = "" ;
} // Only return body/request keys if present
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return Object . assign ( {
method ,
url ,
headers
} , typeof body !== "undefined" ? {
body
} : null , options . request ? {
request : options . request
} : null ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function endpointWithDefaults ( defaults , route , options ) {
return parse ( merge ( defaults , route , options ) ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function withDefaults ( oldDefaults , newDefaults ) {
const DEFAULTS = merge ( oldDefaults , newDefaults ) ;
const endpoint = endpointWithDefaults . bind ( null , DEFAULTS ) ;
return Object . assign ( endpoint , {
DEFAULTS ,
defaults : withDefaults . bind ( null , DEFAULTS ) ,
merge : merge . bind ( null , DEFAULTS ) ,
parse
} ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const VERSION = "6.0.5" ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const userAgent = ` octokit-endpoint.js/ ${ VERSION } ${ universalUserAgent . getUserAgent ( ) } ` ; // DEFAULTS has all properties set that EndpointOptions has, except url.
// So we use RequestParameters and add method as additional required property.
const DEFAULTS = {
method : "GET" ,
baseUrl : "https://api.github.com" ,
headers : {
accept : "application/vnd.github.v3+json" ,
"user-agent" : userAgent
} ,
mediaType : {
format : "" ,
previews : [ ]
}
} ;
const endpoint = withDefaults ( null , DEFAULTS ) ;
exports . endpoint = endpoint ;
//# sourceMappingURL=index.js.map
/***/ } ) ,
/***/ 411 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , {
value : true
} ) ;
exports . default = void 0 ;
var _validate = _interopRequireDefault ( _ _webpack _require _ _ ( 78 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
2020-07-16 08:57:13 +00:00
/ * *
2020-08-19 03:20:28 +00:00
* Convert array of 16 byte values to UUID string format of the form :
* XXXXXXXX - XXXX - XXXX - XXXX - XXXXXXXXXXXX
2020-07-16 08:57:13 +00:00
* /
2020-08-19 03:20:28 +00:00
const byteToHex = [ ] ;
for ( let i = 0 ; i < 256 ; ++ i ) {
byteToHex . push ( ( i + 0x100 ) . toString ( 16 ) . substr ( 1 ) ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
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 ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
var _default = stringify ;
exports . default = _default ;
/***/ } ) ,
/***/ 413 :
/***/ ( function ( module ) {
module . exports = require ( "stream" ) ;
/***/ } ) ,
/***/ 417 :
/***/ ( function ( module ) {
module . exports = require ( "crypto" ) ;
/***/ } ) ,
/***/ 431 :
/***/ ( 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 os = _ _importStar ( _ _webpack _require _ _ ( 87 ) ) ;
2020-07-16 08:57:13 +00:00
/ * *
2020-08-19 03:20:28 +00:00
* Commands
2020-07-16 08:57:13 +00:00
*
2020-08-19 03:20:28 +00:00
* Command Format :
* : : name key = value , key = value : : message
2020-07-16 08:57:13 +00:00
*
2020-08-19 03:20:28 +00:00
* Examples :
* : : warning : : This is the message
* : : set - env name = MY _VAR : : some value
2020-07-16 08:57:13 +00:00
* /
2020-08-19 03:20:28 +00:00
function issueCommand ( command , properties , message ) {
const cmd = new Command ( command , properties , message ) ;
process . stdout . write ( cmd . toString ( ) + os . EOL ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
exports . issueCommand = issueCommand ;
function issue ( name , message = '' ) {
issueCommand ( name , { } , message ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
exports . issue = issue ;
const CMD _STRING = '::' ;
class Command {
constructor ( command , properties , message ) {
if ( ! command ) {
command = 'missing.command' ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
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 ) } ` ;
}
}
}
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
cmdStr += ` ${ CMD _STRING } ${ escapeData ( this . message ) } ` ;
return cmdStr ;
}
2019-11-09 08:24:47 +00:00
}
2020-07-16 08:57:13 +00:00
/ * *
2020-08-19 03:20:28 +00:00
* Sanitizes an input into a string so it can be passed into issueCommand safely
* @ param input input to sanitize into a string
2020-07-16 08:57:13 +00:00
* /
2020-08-19 03:20:28 +00:00
function toCommandValue ( input ) {
if ( input === null || input === undefined ) {
return '' ;
}
else if ( typeof input === 'string' || input instanceof String ) {
return input ;
}
return JSON . stringify ( input ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
exports . toCommandValue = toCommandValue ;
function escapeData ( s ) {
return toCommandValue ( s )
. replace ( /%/g , '%25' )
. replace ( /\r/g , '%0D' )
. replace ( /\n/g , '%0A' ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
function escapeProperty ( s ) {
return toCommandValue ( s )
. replace ( /%/g , '%25' )
. replace ( /\r/g , '%0D' )
. replace ( /\n/g , '%0A' )
. replace ( /:/g , '%3A' )
. replace ( /,/g , '%2C' ) ;
}
//# sourceMappingURL=command.js.map
/***/ } ) ,
/***/ 448 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
"use strict" ;
Object . defineProperty ( exports , '__esModule' , { value : true } ) ;
var universalUserAgent = _ _webpack _require _ _ ( 796 ) ;
var beforeAfterHook = _ _webpack _require _ _ ( 523 ) ;
var request = _ _webpack _require _ _ ( 753 ) ;
var graphql = _ _webpack _require _ _ ( 898 ) ;
var authToken = _ _webpack _require _ _ ( 813 ) ;
function _defineProperty ( obj , key , value ) {
if ( key in obj ) {
Object . defineProperty ( obj , key , {
value : value ,
enumerable : true ,
configurable : true ,
writable : true
} ) ;
} else {
obj [ key ] = value ;
}
return obj ;
}
function ownKeys ( object , enumerableOnly ) {
var keys = Object . keys ( object ) ;
if ( Object . getOwnPropertySymbols ) {
var symbols = Object . getOwnPropertySymbols ( object ) ;
if ( enumerableOnly ) symbols = symbols . filter ( function ( sym ) {
return Object . getOwnPropertyDescriptor ( object , sym ) . enumerable ;
} ) ;
keys . push . apply ( keys , symbols ) ;
}
return keys ;
}
function _objectSpread2 ( target ) {
for ( var i = 1 ; i < arguments . length ; i ++ ) {
var source = arguments [ i ] != null ? arguments [ i ] : { } ;
if ( i % 2 ) {
ownKeys ( Object ( source ) , true ) . forEach ( function ( key ) {
_defineProperty ( target , key , source [ key ] ) ;
} ) ;
} else if ( Object . getOwnPropertyDescriptors ) {
Object . defineProperties ( target , Object . getOwnPropertyDescriptors ( source ) ) ;
} else {
ownKeys ( Object ( source ) ) . forEach ( function ( key ) {
Object . defineProperty ( target , key , Object . getOwnPropertyDescriptor ( source , key ) ) ;
} ) ;
}
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
return target ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const VERSION = "3.1.2" ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
class Octokit {
constructor ( options = { } ) {
const hook = new beforeAfterHook . Collection ( ) ;
const requestDefaults = {
baseUrl : request . request . endpoint . DEFAULTS . baseUrl ,
headers : { } ,
request : Object . assign ( { } , options . request , {
hook : hook . bind ( null , "request" )
} ) ,
mediaType : {
previews : [ ] ,
format : ""
}
} ; // prepend default user agent with `options.userAgent` if set
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
requestDefaults . headers [ "user-agent" ] = [ options . userAgent , ` octokit-core.js/ ${ VERSION } ${ universalUserAgent . getUserAgent ( ) } ` ] . filter ( Boolean ) . join ( " " ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( options . baseUrl ) {
requestDefaults . baseUrl = options . baseUrl ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( options . previews ) {
requestDefaults . mediaType . previews = options . previews ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( options . timeZone ) {
requestDefaults . headers [ "time-zone" ] = options . timeZone ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
this . request = request . request . defaults ( requestDefaults ) ;
this . graphql = graphql . withCustomRequest ( this . request ) . defaults ( _objectSpread2 ( _objectSpread2 ( { } , requestDefaults ) , { } , {
baseUrl : requestDefaults . baseUrl . replace ( /\/api\/v3$/ , "/api" )
} ) ) ;
this . log = Object . assign ( {
debug : ( ) => { } ,
info : ( ) => { } ,
warn : console . warn . bind ( console ) ,
error : console . error . bind ( console )
} , options . log ) ;
this . hook = hook ; // (1) If neither `options.authStrategy` nor `options.auth` are set, the `octokit` instance
// is unauthenticated. The `this.auth()` method is a no-op and no request hook is registred.
// (2) If only `options.auth` is set, use the default token authentication strategy.
// (3) If `options.authStrategy` is set then use it and pass in `options.auth`. Always pass own request as many strategies accept a custom request instance.
// TODO: type `options.auth` based on `options.authStrategy`.
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( ! options . authStrategy ) {
if ( ! options . auth ) {
// (1)
this . auth = async ( ) => ( {
type : "unauthenticated"
} ) ;
} else {
// (2)
const auth = authToken . createTokenAuth ( options . auth ) ; // @ts-ignore ¯\_(ツ)_/¯
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
hook . wrap ( "request" , auth . hook ) ;
this . auth = auth ;
}
} else {
const auth = options . authStrategy ( Object . assign ( {
request : this . request
} , options . auth ) ) ; // @ts-ignore ¯\_(ツ)_/¯
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
hook . wrap ( "request" , auth . hook ) ;
this . auth = auth ;
} // apply plugins
// https://stackoverflow.com/a/16345172
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const classConstructor = this . constructor ;
classConstructor . plugins . forEach ( plugin => {
Object . assign ( this , plugin ( this , options ) ) ;
} ) ;
2020-07-16 08:57:13 +00:00
}
2020-05-17 09:26:30 +00:00
2020-08-19 03:20:28 +00:00
static defaults ( defaults ) {
const OctokitWithDefaults = class extends this {
constructor ( ... args ) {
const options = args [ 0 ] || { } ;
2020-02-22 05:08:54 +00:00
2020-08-19 03:20:28 +00:00
if ( typeof defaults === "function" ) {
super ( defaults ( options ) ) ;
return ;
}
2020-02-22 05:08:54 +00:00
2020-08-19 03:20:28 +00:00
super ( Object . assign ( { } , defaults , options , options . userAgent && defaults . userAgent ? {
userAgent : ` ${ options . userAgent } ${ defaults . userAgent } `
} : null ) ) ;
}
2020-02-22 05:08:54 +00:00
2020-08-19 03:20:28 +00:00
} ;
return OctokitWithDefaults ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
/ * *
* Attach a plugin ( or many ) to your Octokit instance .
*
* @ example
* const API = Octokit . plugin ( plugin1 , plugin2 , plugin3 , ... )
* /
2020-02-22 05:08:54 +00:00
2020-08-19 03:20:28 +00:00
static plugin ( ... newPlugins ) {
var _a ;
2020-02-22 05:08:54 +00:00
2020-08-19 03:20:28 +00:00
const currentPlugins = this . plugins ;
const NewOctokit = ( _a = class extends this { } , _a . plugins = currentPlugins . concat ( newPlugins . filter ( plugin => ! currentPlugins . includes ( plugin ) ) ) , _a ) ;
return NewOctokit ;
2020-07-16 08:57:13 +00:00
}
2020-02-22 05:08:54 +00:00
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
Octokit . VERSION = VERSION ;
Octokit . plugins = [ ] ;
2020-02-22 05:08:54 +00:00
2020-08-19 03:20:28 +00:00
exports . Octokit = Octokit ;
//# sourceMappingURL=index.js.map
2020-02-22 05:08:54 +00:00
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/***/ } ) ,
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/***/ 454 :
/***/ ( function ( module , exports , _ _webpack _require _ _ ) {
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
"use strict" ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( exports , '__esModule' , { value : true } ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
function _interopDefault ( ex ) { return ( ex && ( typeof ex === 'object' ) && 'default' in ex ) ? ex [ 'default' ] : ex ; }
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
var Stream = _interopDefault ( _ _webpack _require _ _ ( 413 ) ) ;
var http = _interopDefault ( _ _webpack _require _ _ ( 605 ) ) ;
var Url = _interopDefault ( _ _webpack _require _ _ ( 835 ) ) ;
var https = _interopDefault ( _ _webpack _require _ _ ( 211 ) ) ;
var zlib = _interopDefault ( _ _webpack _require _ _ ( 761 ) ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// Based on https://github.com/tmpvar/jsdom/blob/aa85b2abf07766ff7bf5c1f6daafb3726f2f2db5/lib/jsdom/living/blob.js
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// fix for "Readable" isn't a named export issue
const Readable = Stream . Readable ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const BUFFER = Symbol ( 'buffer' ) ;
const TYPE = Symbol ( 'type' ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
class Blob {
constructor ( ) {
this [ TYPE ] = '' ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const blobParts = arguments [ 0 ] ;
const options = arguments [ 1 ] ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const buffers = [ ] ;
let size = 0 ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( blobParts ) {
const a = blobParts ;
const length = Number ( a . length ) ;
for ( let i = 0 ; i < length ; i ++ ) {
const element = a [ i ] ;
let buffer ;
if ( element instanceof Buffer ) {
buffer = element ;
} else if ( ArrayBuffer . isView ( element ) ) {
buffer = Buffer . from ( element . buffer , element . byteOffset , element . byteLength ) ;
} else if ( element instanceof ArrayBuffer ) {
buffer = Buffer . from ( element ) ;
} else if ( element instanceof Blob ) {
buffer = element [ BUFFER ] ;
} else {
buffer = Buffer . from ( typeof element === 'string' ? element : String ( element ) ) ;
}
size += buffer . length ;
buffers . push ( buffer ) ;
}
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
this [ BUFFER ] = Buffer . concat ( buffers ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
let type = options && options . type !== undefined && String ( options . type ) . toLowerCase ( ) ;
if ( type && ! /[^\u0020-\u007E]/ . test ( type ) ) {
this [ TYPE ] = type ;
}
}
get size ( ) {
return this [ BUFFER ] . length ;
}
get type ( ) {
return this [ TYPE ] ;
}
text ( ) {
return Promise . resolve ( this [ BUFFER ] . toString ( ) ) ;
}
arrayBuffer ( ) {
const buf = this [ BUFFER ] ;
const ab = buf . buffer . slice ( buf . byteOffset , buf . byteOffset + buf . byteLength ) ;
return Promise . resolve ( ab ) ;
}
stream ( ) {
const readable = new Readable ( ) ;
readable . _read = function ( ) { } ;
readable . push ( this [ BUFFER ] ) ;
readable . push ( null ) ;
return readable ;
}
toString ( ) {
return '[object Blob]' ;
}
slice ( ) {
const size = this . size ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const start = arguments [ 0 ] ;
const end = arguments [ 1 ] ;
let relativeStart , relativeEnd ;
if ( start === undefined ) {
relativeStart = 0 ;
} else if ( start < 0 ) {
relativeStart = Math . max ( size + start , 0 ) ;
} else {
relativeStart = Math . min ( start , size ) ;
}
if ( end === undefined ) {
relativeEnd = size ;
} else if ( end < 0 ) {
relativeEnd = Math . max ( size + end , 0 ) ;
} else {
relativeEnd = Math . min ( end , size ) ;
}
const span = Math . max ( relativeEnd - relativeStart , 0 ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const buffer = this [ BUFFER ] ;
const slicedBuffer = buffer . slice ( relativeStart , relativeStart + span ) ;
const blob = new Blob ( [ ] , { type : arguments [ 2 ] } ) ;
blob [ BUFFER ] = slicedBuffer ;
return blob ;
}
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperties ( Blob . prototype , {
size : { enumerable : true } ,
type : { enumerable : true } ,
slice : { enumerable : true }
} ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( Blob . prototype , Symbol . toStringTag , {
value : 'Blob' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* fetch - error . js
*
* FetchError interface for operational errors
* /
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Create FetchError instance
*
* @ param String message Error message for human
* @ param String type Error type for machine
* @ param String systemError For Node . js system error
* @ return FetchError
* /
function FetchError ( message , type , systemError ) {
Error . call ( this , message ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
this . message = message ;
this . type = type ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// when err.type is `system`, err.code contains system error code
if ( systemError ) {
this . code = this . errno = systemError . code ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// hide custom error implementation details from end-users
Error . captureStackTrace ( this , this . constructor ) ;
2020-07-16 08:57:13 +00:00
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
FetchError . prototype = Object . create ( Error . prototype ) ;
FetchError . prototype . constructor = FetchError ;
FetchError . prototype . name = 'FetchError' ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
let convert ;
try {
convert = _ _webpack _require _ _ ( 18 ) . convert ;
} catch ( e ) { }
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const INTERNALS = Symbol ( 'Body internals' ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// fix an issue where "PassThrough" isn't a named export for node <10
const PassThrough = Stream . PassThrough ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Body mixin
2020-07-16 08:57:13 +00:00
*
2020-08-19 03:20:28 +00:00
* Ref : https : //fetch.spec.whatwg.org/#body
2020-07-16 08:57:13 +00:00
*
2020-08-19 03:20:28 +00:00
* @ param Stream body Readable stream
* @ param Object opts Response options
* @ return Void
2020-07-16 08:57:13 +00:00
* /
2020-08-19 03:20:28 +00:00
function Body ( body ) {
var _this = this ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
var _ref = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : { } ,
_ref$size = _ref . size ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
let size = _ref$size === undefined ? 0 : _ref$size ;
var _ref$timeout = _ref . timeout ;
let timeout = _ref$timeout === undefined ? 0 : _ref$timeout ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( body == null ) {
// body is undefined or null
body = null ;
} else if ( isURLSearchParams ( body ) ) {
// body is a URLSearchParams
body = Buffer . from ( body . toString ( ) ) ;
} else if ( isBlob ( body ) ) ; else if ( Buffer . isBuffer ( body ) ) ; else if ( Object . prototype . toString . call ( body ) === '[object ArrayBuffer]' ) {
// body is ArrayBuffer
body = Buffer . from ( body ) ;
} else if ( ArrayBuffer . isView ( body ) ) {
// body is ArrayBufferView
body = Buffer . from ( body . buffer , body . byteOffset , body . byteLength ) ;
} else if ( body instanceof Stream ) ; else {
// none of the above
// coerce to string then buffer
body = Buffer . from ( String ( body ) ) ;
}
this [ INTERNALS ] = {
body ,
disturbed : false ,
error : null
} ;
this . size = size ;
this . timeout = timeout ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( body instanceof Stream ) {
body . on ( 'error' , function ( err ) {
const error = err . name === 'AbortError' ? err : new FetchError ( ` Invalid response body while trying to fetch ${ _this . url } : ${ err . message } ` , 'system' , err ) ;
_this [ INTERNALS ] . error = error ;
} ) ;
}
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Body . prototype = {
get body ( ) {
return this [ INTERNALS ] . body ;
} ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
get bodyUsed ( ) {
return this [ INTERNALS ] . disturbed ;
} ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Decode response as ArrayBuffer
*
* @ return Promise
* /
arrayBuffer ( ) {
return consumeBody . call ( this ) . then ( function ( buf ) {
return buf . buffer . slice ( buf . byteOffset , buf . byteOffset + buf . byteLength ) ;
} ) ;
} ,
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Return raw response as Blob
*
* @ return Promise
* /
blob ( ) {
let ct = this . headers && this . headers . get ( 'content-type' ) || '' ;
return consumeBody . call ( this ) . then ( function ( buf ) {
return Object . assign (
// Prevent copying
new Blob ( [ ] , {
type : ct . toLowerCase ( )
} ) , {
[ BUFFER ] : buf
} ) ;
} ) ;
} ,
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Decode response as json
*
* @ return Promise
* /
json ( ) {
var _this2 = this ;
2020-02-13 07:26:04 +00:00
2020-08-19 03:20:28 +00:00
return consumeBody . call ( this ) . then ( function ( buffer ) {
try {
return JSON . parse ( buffer . toString ( ) ) ;
} catch ( err ) {
return Body . Promise . reject ( new FetchError ( ` invalid json response body at ${ _this2 . url } reason: ${ err . message } ` , 'invalid-json' ) ) ;
}
} ) ;
} ,
2020-02-13 07:26:04 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Decode response as text
*
* @ return Promise
* /
text ( ) {
return consumeBody . call ( this ) . then ( function ( buffer ) {
return buffer . toString ( ) ;
} ) ;
} ,
2020-02-13 07:26:04 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Decode response as buffer ( non - spec api )
*
* @ return Promise
* /
buffer ( ) {
return consumeBody . call ( this ) ;
} ,
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Decode response as text , while automatically detecting the encoding and
* trying to decode to UTF - 8 ( non - spec api )
*
* @ return Promise
* /
textConverted ( ) {
var _this3 = this ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return consumeBody . call ( this ) . then ( function ( buffer ) {
return convertBody ( buffer , _this3 . headers ) ;
} ) ;
2020-07-16 08:57:13 +00:00
}
2020-02-13 07:26:04 +00:00
} ;
2020-08-19 03:20:28 +00:00
// In browsers, all properties are enumerable.
Object . defineProperties ( Body . prototype , {
body : { enumerable : true } ,
bodyUsed : { enumerable : true } ,
arrayBuffer : { enumerable : true } ,
blob : { enumerable : true } ,
json : { enumerable : true } ,
text : { enumerable : true }
} ) ;
2020-02-13 07:26:04 +00:00
2020-08-19 03:20:28 +00:00
Body . mixIn = function ( proto ) {
for ( const name of Object . getOwnPropertyNames ( Body . prototype ) ) {
// istanbul ignore else: future proof
if ( ! ( name in proto ) ) {
const desc = Object . getOwnPropertyDescriptor ( Body . prototype , name ) ;
Object . defineProperty ( proto , name , desc ) ;
}
}
} ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Consume and convert an entire Body to a Buffer .
*
* Ref : https : //fetch.spec.whatwg.org/#concept-body-consume-body
*
* @ return Promise
* /
function consumeBody ( ) {
var _this4 = this ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( this [ INTERNALS ] . disturbed ) {
return Body . Promise . reject ( new TypeError ( ` body used already for: ${ this . url } ` ) ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
this [ INTERNALS ] . disturbed = true ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( this [ INTERNALS ] . error ) {
return Body . Promise . reject ( this [ INTERNALS ] . error ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
let body = this . body ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// body is null
if ( body === null ) {
return Body . Promise . resolve ( Buffer . alloc ( 0 ) ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// body is blob
if ( isBlob ( body ) ) {
body = body . stream ( ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// body is buffer
if ( Buffer . isBuffer ( body ) ) {
return Body . Promise . resolve ( body ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// istanbul ignore if: should never happen
if ( ! ( body instanceof Stream ) ) {
return Body . Promise . resolve ( Buffer . alloc ( 0 ) ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// body is stream
// get ready to actually consume the body
let accum = [ ] ;
let accumBytes = 0 ;
let abort = false ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
return new Body . Promise ( function ( resolve , reject ) {
let resTimeout ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// allow timeout on slow response body
if ( _this4 . timeout ) {
resTimeout = setTimeout ( function ( ) {
abort = true ;
reject ( new FetchError ( ` Response timeout while trying to fetch ${ _this4 . url } (over ${ _this4 . timeout } ms) ` , 'body-timeout' ) ) ;
} , _this4 . timeout ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// handle stream errors
body . on ( 'error' , function ( err ) {
if ( err . name === 'AbortError' ) {
// if the request was aborted, reject with this Error
abort = true ;
reject ( err ) ;
} else {
// other errors, such as incorrect content-encoding
reject ( new FetchError ( ` Invalid response body while trying to fetch ${ _this4 . url } : ${ err . message } ` , 'system' , err ) ) ;
}
} ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
body . on ( 'data' , function ( chunk ) {
if ( abort || chunk === null ) {
return ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( _this4 . size && accumBytes + chunk . length > _this4 . size ) {
abort = true ;
reject ( new FetchError ( ` content size at ${ _this4 . url } over limit: ${ _this4 . size } ` , 'max-size' ) ) ;
return ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
accumBytes += chunk . length ;
accum . push ( chunk ) ;
} ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
body . on ( 'end' , function ( ) {
if ( abort ) {
return ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
clearTimeout ( resTimeout ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
try {
resolve ( Buffer . concat ( accum , accumBytes ) ) ;
} catch ( err ) {
// handle streams that have accumulated too much data (issue #414)
reject ( new FetchError ( ` Could not create Buffer from response body for ${ _this4 . url } : ${ err . message } ` , 'system' , err ) ) ;
}
} ) ;
} ) ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
/ * *
* Detect buffer encoding and convert to target encoding
* ref : http : //www.w3.org/TR/2011/WD-html5-20110113/parsing.html#determining-the-character-encoding
*
* @ param Buffer buffer Incoming buffer
* @ param String encoding Target encoding
* @ return String
* /
function convertBody ( buffer , headers ) {
if ( typeof convert !== 'function' ) {
throw new Error ( 'The package `encoding` must be installed to use the textConverted() function' ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const ct = headers . get ( 'content-type' ) ;
let charset = 'utf-8' ;
let res , str ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// header
if ( ct ) {
res = /charset=([^;]*)/i . exec ( ct ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// no charset in content type, peek at response body for at most 1024 bytes
str = buffer . slice ( 0 , 1024 ) . toString ( ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// html5
if ( ! res && str ) {
res = /<meta.+?charset=(['"])(.+?)\1/i . exec ( str ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// html4
if ( ! res && str ) {
res = /<meta[\s]+?http-equiv=(['"])content-type\1[\s]+?content=(['"])(.+?)\2/i . exec ( str ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( res ) {
res = /charset=(.*)/i . exec ( res . pop ( ) ) ;
}
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// xml
if ( ! res && str ) {
res = /<\?xml.+?encoding=(['"])(.+?)\1/i . exec ( str ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// found charset
if ( res ) {
charset = res . pop ( ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// prevent decode issues when sites use incorrect encoding
// ref: https://hsivonen.fi/encoding-menu/
if ( charset === 'gb2312' || charset === 'gbk' ) {
charset = 'gb18030' ;
}
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// turn raw buffers into a single utf-8 buffer
return convert ( buffer , 'UTF-8' , charset ) . toString ( ) ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
/ * *
* Detect a URLSearchParams object
* ref : https : //github.com/bitinn/node-fetch/issues/296#issuecomment-307598143
*
* @ param Object obj Object to detect by type or brand
* @ return String
* /
function isURLSearchParams ( obj ) {
// Duck-typing as a necessary condition.
if ( typeof obj !== 'object' || typeof obj . append !== 'function' || typeof obj . delete !== 'function' || typeof obj . get !== 'function' || typeof obj . getAll !== 'function' || typeof obj . has !== 'function' || typeof obj . set !== 'function' ) {
return false ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// Brand-checking and more duck-typing as optional condition.
return obj . constructor . name === 'URLSearchParams' || Object . prototype . toString . call ( obj ) === '[object URLSearchParams]' || typeof obj . sort === 'function' ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
/ * *
* Check if ` obj ` is a W3C ` Blob ` object ( which ` File ` inherits from )
* @ param { * } obj
* @ return { boolean }
* /
function isBlob ( obj ) {
return typeof obj === 'object' && typeof obj . arrayBuffer === 'function' && typeof obj . type === 'string' && typeof obj . stream === 'function' && typeof obj . constructor === 'function' && typeof obj . constructor . name === 'string' && /^(Blob|File)$/ . test ( obj . constructor . name ) && /^(Blob|File)$/ . test ( obj [ Symbol . toStringTag ] ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
/ * *
* Clone body given Res / Req instance
*
* @ param Mixed instance Response or Request instance
* @ return Mixed
* /
function clone ( instance ) {
let p1 , p2 ;
let body = instance . body ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// don't allow cloning a used body
if ( instance . bodyUsed ) {
throw new Error ( 'cannot clone body after it is used' ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// check that body is a stream and not form-data object
// note: we can't clone the form-data object without having it as a dependency
if ( body instanceof Stream && typeof body . getBoundary !== 'function' ) {
// tee instance body
p1 = new PassThrough ( ) ;
p2 = new PassThrough ( ) ;
body . pipe ( p1 ) ;
body . pipe ( p2 ) ;
// set instance body to teed body and return the other teed body
instance [ INTERNALS ] . body = p1 ;
body = p2 ;
}
return body ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
/ * *
* Performs the operation "extract a `Content-Type` value from |object|" as
* specified in the specification :
* https : //fetch.spec.whatwg.org/#concept-bodyinit-extract
*
* This function assumes that instance . body is present .
*
* @ param Mixed instance Any options . body input
* /
function extractContentType ( body ) {
if ( body === null ) {
// body is null
return null ;
} else if ( typeof body === 'string' ) {
// body is string
return 'text/plain;charset=UTF-8' ;
} else if ( isURLSearchParams ( body ) ) {
// body is a URLSearchParams
return 'application/x-www-form-urlencoded;charset=UTF-8' ;
} else if ( isBlob ( body ) ) {
// body is blob
return body . type || null ;
} else if ( Buffer . isBuffer ( body ) ) {
// body is buffer
return null ;
} else if ( Object . prototype . toString . call ( body ) === '[object ArrayBuffer]' ) {
// body is ArrayBuffer
return null ;
} else if ( ArrayBuffer . isView ( body ) ) {
// body is ArrayBufferView
return null ;
} else if ( typeof body . getBoundary === 'function' ) {
// detect form data input from form-data module
return ` multipart/form-data;boundary= ${ body . getBoundary ( ) } ` ;
} else if ( body instanceof Stream ) {
// body is stream
// can't really do much about this
return null ;
} else {
// Body constructor defaults other things to string
return 'text/plain;charset=UTF-8' ;
}
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* The Fetch Standard treats this as if "total bytes" is a property on the body .
* For us , we have to explicitly get it with a function .
*
* ref : https : //fetch.spec.whatwg.org/#concept-body-total-bytes
*
* @ param Body instance Instance of Body
* @ return Number ? Number of bytes , or null if not possible
* /
function getTotalBytes ( instance ) {
const body = instance . body ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( body === null ) {
// body is null
return 0 ;
} else if ( isBlob ( body ) ) {
return body . size ;
} else if ( Buffer . isBuffer ( body ) ) {
// body is buffer
return body . length ;
} else if ( body && typeof body . getLengthSync === 'function' ) {
// detect form data input from form-data module
if ( body . _lengthRetrievers && body . _lengthRetrievers . length == 0 || // 1.x
body . hasKnownLength && body . hasKnownLength ( ) ) {
// 2.x
return body . getLengthSync ( ) ;
}
return null ;
} else {
// body is stream
return null ;
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
/ * *
* Write a Body to a Node . js WritableStream ( e . g . http . Request ) object .
*
* @ param Body instance Instance of Body
* @ return Void
* /
function writeToStream ( dest , instance ) {
const body = instance . body ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( body === null ) {
// body is null
dest . end ( ) ;
} else if ( isBlob ( body ) ) {
body . stream ( ) . pipe ( dest ) ;
} else if ( Buffer . isBuffer ( body ) ) {
// body is buffer
dest . write ( body ) ;
dest . end ( ) ;
} else {
// body is stream
body . pipe ( dest ) ;
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
// expose Promise
Body . Promise = global . Promise ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* headers . js
*
* Headers class offers convenient helpers
* /
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const invalidTokenRegex = /[^\^_`a-zA-Z\-0-9!#$%&'*+.|~]/ ;
const invalidHeaderCharRegex = /[^\t\x20-\x7e\x80-\xff]/ ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function validateName ( name ) {
name = ` ${ name } ` ;
if ( invalidTokenRegex . test ( name ) || name === '' ) {
throw new TypeError ( ` ${ name } is not a legal HTTP header name ` ) ;
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
function validateValue ( value ) {
value = ` ${ value } ` ;
if ( invalidHeaderCharRegex . test ( value ) ) {
throw new TypeError ( ` ${ value } is not a legal HTTP header value ` ) ;
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
/ * *
* Find the key in the map object given a header name .
*
* Returns undefined if not found .
*
* @ param String name Header name
* @ return String | Undefined
* /
function find ( map , name ) {
name = name . toLowerCase ( ) ;
for ( const key in map ) {
if ( key . toLowerCase ( ) === name ) {
return key ;
}
}
return undefined ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
const MAP = Symbol ( 'map' ) ;
class Headers {
/ * *
* Headers class
*
* @ param Object headers Response headers
* @ return Void
* /
constructor ( ) {
let init = arguments . length > 0 && arguments [ 0 ] !== undefined ? arguments [ 0 ] : undefined ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
this [ MAP ] = Object . create ( null ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( init instanceof Headers ) {
const rawHeaders = init . raw ( ) ;
const headerNames = Object . keys ( rawHeaders ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
for ( const headerName of headerNames ) {
for ( const value of rawHeaders [ headerName ] ) {
this . append ( headerName , value ) ;
}
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// We don't worry about converting prop to ByteString here as append()
// will handle it.
if ( init == null ) ; else if ( typeof init === 'object' ) {
const method = init [ Symbol . iterator ] ;
if ( method != null ) {
if ( typeof method !== 'function' ) {
throw new TypeError ( 'Header pairs must be iterable' ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// sequence<sequence<ByteString>>
// Note: per spec we have to first exhaust the lists then process them
const pairs = [ ] ;
for ( const pair of init ) {
if ( typeof pair !== 'object' || typeof pair [ Symbol . iterator ] !== 'function' ) {
throw new TypeError ( 'Each header pair must be iterable' ) ;
}
pairs . push ( Array . from ( pair ) ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
for ( const pair of pairs ) {
if ( pair . length !== 2 ) {
throw new TypeError ( 'Each header pair must be a name/value tuple' ) ;
}
this . append ( pair [ 0 ] , pair [ 1 ] ) ;
}
} else {
// record<ByteString, ByteString>
for ( const key of Object . keys ( init ) ) {
const value = init [ key ] ;
this . append ( key , value ) ;
}
}
} else {
throw new TypeError ( 'Provided initializer must be an object' ) ;
}
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Return combined header value given name
*
* @ param String name Header name
* @ return Mixed
* /
get ( name ) {
name = ` ${ name } ` ;
validateName ( name ) ;
const key = find ( this [ MAP ] , name ) ;
if ( key === undefined ) {
return null ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return this [ MAP ] [ key ] . join ( ', ' ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Iterate over all headers
*
* @ param Function callback Executed for each item with parameters ( value , name , thisArg )
* @ param Boolean thisArg ` this ` context for callback function
* @ return Void
* /
forEach ( callback ) {
let thisArg = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : undefined ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
let pairs = getHeaders ( this ) ;
let i = 0 ;
while ( i < pairs . length ) {
var _pairs$i = pairs [ i ] ;
const name = _pairs$i [ 0 ] ,
value = _pairs$i [ 1 ] ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
callback . call ( thisArg , value , name , this ) ;
pairs = getHeaders ( this ) ;
i ++ ;
}
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Overwrite header values given name
*
* @ param String name Header name
* @ param String value Header value
* @ return Void
* /
set ( name , value ) {
name = ` ${ name } ` ;
value = ` ${ value } ` ;
validateName ( name ) ;
validateValue ( value ) ;
const key = find ( this [ MAP ] , name ) ;
this [ MAP ] [ key !== undefined ? key : name ] = [ value ] ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Append a value onto existing header
*
* @ param String name Header name
* @ param String value Header value
* @ return Void
* /
append ( name , value ) {
name = ` ${ name } ` ;
value = ` ${ value } ` ;
validateName ( name ) ;
validateValue ( value ) ;
const key = find ( this [ MAP ] , name ) ;
if ( key !== undefined ) {
this [ MAP ] [ key ] . push ( value ) ;
} else {
this [ MAP ] [ name ] = [ value ] ;
}
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Check for header name existence
*
* @ param String name Header name
* @ return Boolean
* /
has ( name ) {
name = ` ${ name } ` ;
validateName ( name ) ;
return find ( this [ MAP ] , name ) !== undefined ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Delete all header values given name
*
* @ param String name Header name
* @ return Void
* /
delete ( name ) {
name = ` ${ name } ` ;
validateName ( name ) ;
const key = find ( this [ MAP ] , name ) ;
if ( key !== undefined ) {
delete this [ MAP ] [ key ] ;
}
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Return raw headers ( non - spec api )
*
* @ return Object
* /
raw ( ) {
return this [ MAP ] ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Get an iterator on keys .
*
* @ return Iterator
* /
keys ( ) {
return createHeadersIterator ( this , 'key' ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Get an iterator on values .
*
* @ return Iterator
* /
values ( ) {
return createHeadersIterator ( this , 'value' ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Get an iterator on entries .
*
* This is the default iterator of the Headers object .
*
* @ return Iterator
* /
[ Symbol . iterator ] ( ) {
return createHeadersIterator ( this , 'key+value' ) ;
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
Headers . prototype . entries = Headers . prototype [ Symbol . iterator ] ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( Headers . prototype , Symbol . toStringTag , {
value : 'Headers' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperties ( Headers . prototype , {
get : { enumerable : true } ,
forEach : { enumerable : true } ,
set : { enumerable : true } ,
append : { enumerable : true } ,
has : { enumerable : true } ,
delete : { enumerable : true } ,
keys : { enumerable : true } ,
values : { enumerable : true } ,
entries : { enumerable : true }
} ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function getHeaders ( headers ) {
let kind = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : 'key+value' ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const keys = Object . keys ( headers [ MAP ] ) . sort ( ) ;
return keys . map ( kind === 'key' ? function ( k ) {
return k . toLowerCase ( ) ;
} : kind === 'value' ? function ( k ) {
return headers [ MAP ] [ k ] . join ( ', ' ) ;
} : function ( k ) {
return [ k . toLowerCase ( ) , headers [ MAP ] [ k ] . join ( ', ' ) ] ;
} ) ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
const INTERNAL = Symbol ( 'internal' ) ;
function createHeadersIterator ( target , kind ) {
const iterator = Object . create ( HeadersIteratorPrototype ) ;
iterator [ INTERNAL ] = {
target ,
kind ,
index : 0
} ;
return iterator ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
const HeadersIteratorPrototype = Object . setPrototypeOf ( {
next ( ) {
// istanbul ignore if
if ( ! this || Object . getPrototypeOf ( this ) !== HeadersIteratorPrototype ) {
throw new TypeError ( 'Value of `this` is not a HeadersIterator' ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
var _INTERNAL = this [ INTERNAL ] ;
const target = _INTERNAL . target ,
kind = _INTERNAL . kind ,
index = _INTERNAL . index ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const values = getHeaders ( target , kind ) ;
const len = values . length ;
if ( index >= len ) {
return {
value : undefined ,
done : true
} ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
this [ INTERNAL ] . index = index + 1 ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
return {
value : values [ index ] ,
done : false
} ;
}
} , Object . getPrototypeOf ( Object . getPrototypeOf ( [ ] [ Symbol . iterator ] ( ) ) ) ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( HeadersIteratorPrototype , Symbol . toStringTag , {
value : 'HeadersIterator' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Export the Headers object in a form that Node . js can consume .
*
* @ param Headers headers
* @ return Object
* /
function exportNodeCompatibleHeaders ( headers ) {
const obj = Object . assign ( { _ _proto _ _ : null } , headers [ MAP ] ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// http.request() only supports string as Host header. This hack makes
// specifying custom Host header possible.
const hostHeaderKey = find ( headers [ MAP ] , 'Host' ) ;
if ( hostHeaderKey !== undefined ) {
obj [ hostHeaderKey ] = obj [ hostHeaderKey ] [ 0 ] ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
return obj ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Create a Headers object from an object of headers , ignoring those that do
* not conform to HTTP grammar productions .
*
* @ param Object obj Object of headers
* @ return Headers
* /
function createHeadersLenient ( obj ) {
const headers = new Headers ( ) ;
for ( const name of Object . keys ( obj ) ) {
if ( invalidTokenRegex . test ( name ) ) {
continue ;
}
if ( Array . isArray ( obj [ name ] ) ) {
for ( const val of obj [ name ] ) {
if ( invalidHeaderCharRegex . test ( val ) ) {
continue ;
}
if ( headers [ MAP ] [ name ] === undefined ) {
headers [ MAP ] [ name ] = [ val ] ;
} else {
headers [ MAP ] [ name ] . push ( val ) ;
}
}
} else if ( ! invalidHeaderCharRegex . test ( obj [ name ] ) ) {
headers [ MAP ] [ name ] = [ obj [ name ] ] ;
}
}
return headers ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const INTERNALS$1 = Symbol ( 'Response internals' ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// fix an issue where "STATUS_CODES" aren't a named export for node <10
const STATUS _CODES = http . STATUS _CODES ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Response class
*
* @ param Stream body Readable stream
* @ param Object opts Response options
* @ return Void
* /
class Response {
constructor ( ) {
let body = arguments . length > 0 && arguments [ 0 ] !== undefined ? arguments [ 0 ] : null ;
let opts = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : { } ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
Body . call ( this , body , opts ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const status = opts . status || 200 ;
const headers = new Headers ( opts . headers ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( body != null && ! headers . has ( 'Content-Type' ) ) {
const contentType = extractContentType ( body ) ;
if ( contentType ) {
headers . append ( 'Content-Type' , contentType ) ;
}
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
this [ INTERNALS$1 ] = {
url : opts . url ,
status ,
statusText : opts . statusText || STATUS _CODES [ status ] ,
headers ,
counter : opts . counter
} ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
get url ( ) {
return this [ INTERNALS$1 ] . url || '' ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
get status ( ) {
return this [ INTERNALS$1 ] . status ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Convenience property representing if the request ended normally
* /
get ok ( ) {
return this [ INTERNALS$1 ] . status >= 200 && this [ INTERNALS$1 ] . status < 300 ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
get redirected ( ) {
return this [ INTERNALS$1 ] . counter > 0 ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
get statusText ( ) {
return this [ INTERNALS$1 ] . statusText ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
get headers ( ) {
return this [ INTERNALS$1 ] . headers ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Clone this response
*
* @ return Response
* /
clone ( ) {
return new Response ( clone ( this ) , {
url : this . url ,
status : this . status ,
statusText : this . statusText ,
headers : this . headers ,
ok : this . ok ,
redirected : this . redirected
} ) ;
}
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
Body . mixIn ( Response . prototype ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperties ( Response . prototype , {
url : { enumerable : true } ,
status : { enumerable : true } ,
ok : { enumerable : true } ,
redirected : { enumerable : true } ,
statusText : { enumerable : true } ,
headers : { enumerable : true } ,
clone : { enumerable : true }
} ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( Response . prototype , Symbol . toStringTag , {
value : 'Response' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const INTERNALS$2 = Symbol ( 'Request internals' ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// fix an issue where "format", "parse" aren't a named export for node <10
const parse _url = Url . parse ;
const format _url = Url . format ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const streamDestructionSupported = 'destroy' in Stream . Readable . prototype ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Check if a value is an instance of Request .
*
* @ param Mixed input
* @ return Boolean
* /
function isRequest ( input ) {
return typeof input === 'object' && typeof input [ INTERNALS$2 ] === 'object' ;
2020-07-16 08:57:13 +00:00
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
function isAbortSignal ( signal ) {
const proto = signal && typeof signal === 'object' && Object . getPrototypeOf ( signal ) ;
return ! ! ( proto && proto . constructor . name === 'AbortSignal' ) ;
2020-07-16 08:57:13 +00:00
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Request class
*
* @ param Mixed input Url or Request instance
* @ param Object init Custom options
* @ return Void
* /
class Request {
constructor ( input ) {
let init = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : { } ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
let parsedURL ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// normalize input
if ( ! isRequest ( input ) ) {
if ( input && input . href ) {
// in order to support Node.js' Url objects; though WHATWG's URL objects
// will fall into this branch also (since their `toString()` will return
// `href` property anyway)
parsedURL = parse _url ( input . href ) ;
} else {
// coerce input to a string before attempting to parse
parsedURL = parse _url ( ` ${ input } ` ) ;
}
input = { } ;
} else {
parsedURL = parse _url ( input . url ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
let method = init . method || input . method || 'GET' ;
method = method . toUpperCase ( ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( ( init . body != null || isRequest ( input ) && input . body !== null ) && ( method === 'GET' || method === 'HEAD' ) ) {
throw new TypeError ( 'Request with GET/HEAD method cannot have body' ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
let inputBody = init . body != null ? init . body : isRequest ( input ) && input . body !== null ? clone ( input ) : null ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
Body . call ( this , inputBody , {
timeout : init . timeout || input . timeout || 0 ,
size : init . size || input . size || 0
} ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const headers = new Headers ( init . headers || input . headers || { } ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( inputBody != null && ! headers . has ( 'Content-Type' ) ) {
const contentType = extractContentType ( inputBody ) ;
if ( contentType ) {
headers . append ( 'Content-Type' , contentType ) ;
}
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
let signal = isRequest ( input ) ? input . signal : null ;
if ( 'signal' in init ) signal = init . signal ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( signal != null && ! isAbortSignal ( signal ) ) {
throw new TypeError ( 'Expected signal to be an instanceof AbortSignal' ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
this [ INTERNALS$2 ] = {
method ,
redirect : init . redirect || input . redirect || 'follow' ,
headers ,
parsedURL ,
signal
} ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// node-fetch-only options
this . follow = init . follow !== undefined ? init . follow : input . follow !== undefined ? input . follow : 20 ;
this . compress = init . compress !== undefined ? init . compress : input . compress !== undefined ? input . compress : true ;
this . counter = init . counter || input . counter || 0 ;
this . agent = init . agent || input . agent ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
get method ( ) {
return this [ INTERNALS$2 ] . method ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
get url ( ) {
return format _url ( this [ INTERNALS$2 ] . parsedURL ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
get headers ( ) {
return this [ INTERNALS$2 ] . headers ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
get redirect ( ) {
return this [ INTERNALS$2 ] . redirect ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
get signal ( ) {
return this [ INTERNALS$2 ] . signal ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Clone this request
*
* @ return Request
* /
clone ( ) {
return new Request ( this ) ;
}
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
Body . mixIn ( Request . prototype ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( Request . prototype , Symbol . toStringTag , {
value : 'Request' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperties ( Request . prototype , {
method : { enumerable : true } ,
url : { enumerable : true } ,
headers : { enumerable : true } ,
redirect : { enumerable : true } ,
clone : { enumerable : true } ,
signal : { enumerable : true }
} ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Convert a Request to Node . js http request options .
*
* @ param Request A Request instance
* @ return Object The options object to be passed to http . request
* /
function getNodeRequestOptions ( request ) {
const parsedURL = request [ INTERNALS$2 ] . parsedURL ;
const headers = new Headers ( request [ INTERNALS$2 ] . headers ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// fetch step 1.3
if ( ! headers . has ( 'Accept' ) ) {
headers . set ( 'Accept' , '*/*' ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// Basic fetch
if ( ! parsedURL . protocol || ! parsedURL . hostname ) {
throw new TypeError ( 'Only absolute URLs are supported' ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( ! /^https?:$/ . test ( parsedURL . protocol ) ) {
throw new TypeError ( 'Only HTTP(S) protocols are supported' ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( request . signal && request . body instanceof Stream . Readable && ! streamDestructionSupported ) {
throw new Error ( 'Cancellation of streamed requests with AbortSignal is not supported in node < 8' ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// HTTP-network-or-cache fetch steps 2.4-2.7
let contentLengthValue = null ;
if ( request . body == null && /^(POST|PUT)$/i . test ( request . method ) ) {
contentLengthValue = '0' ;
}
if ( request . body != null ) {
const totalBytes = getTotalBytes ( request ) ;
if ( typeof totalBytes === 'number' ) {
contentLengthValue = String ( totalBytes ) ;
}
}
if ( contentLengthValue ) {
headers . set ( 'Content-Length' , contentLengthValue ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// HTTP-network-or-cache fetch step 2.11
if ( ! headers . has ( 'User-Agent' ) ) {
headers . set ( 'User-Agent' , 'node-fetch/1.0 (+https://github.com/bitinn/node-fetch)' ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// HTTP-network-or-cache fetch step 2.15
if ( request . compress && ! headers . has ( 'Accept-Encoding' ) ) {
headers . set ( 'Accept-Encoding' , 'gzip,deflate' ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
let agent = request . agent ;
if ( typeof agent === 'function' ) {
agent = agent ( parsedURL ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( ! headers . has ( 'Connection' ) && ! agent ) {
headers . set ( 'Connection' , 'close' ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// HTTP-network fetch step 4.2
// chunked encoding is handled by Node.js
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
return Object . assign ( { } , parsedURL , {
method : request . method ,
headers : exportNodeCompatibleHeaders ( headers ) ,
agent
} ) ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
/ * *
* abort - error . js
*
* AbortError interface for cancelled requests
* /
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Create AbortError instance
*
* @ param String message Error message for human
* @ return AbortError
* /
function AbortError ( message ) {
Error . call ( this , message ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
this . type = 'aborted' ;
this . message = message ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// hide custom error implementation details from end-users
Error . captureStackTrace ( this , this . constructor ) ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
AbortError . prototype = Object . create ( Error . prototype ) ;
AbortError . prototype . constructor = AbortError ;
AbortError . prototype . name = 'AbortError' ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// fix an issue where "PassThrough", "resolve" aren't a named export for node <10
const PassThrough$1 = Stream . PassThrough ;
const resolve _url = Url . resolve ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/ * *
* Fetch function
*
* @ param Mixed url Absolute url or Request instance
* @ param Object opts Fetch options
* @ return Promise
* /
function fetch ( url , opts ) {
2020-07-18 07:04:36 +00:00
2020-08-19 03:20:28 +00:00
// allow custom promise
if ( ! fetch . Promise ) {
throw new Error ( 'native promise missing, set fetch.Promise to your favorite alternative' ) ;
}
2020-07-18 07:04:36 +00:00
2020-08-19 03:20:28 +00:00
Body . Promise = fetch . Promise ;
2020-07-18 08:55:42 +00:00
2020-08-19 03:20:28 +00:00
// wrap http.request into fetch
return new fetch . Promise ( function ( resolve , reject ) {
// build request object
const request = new Request ( url , opts ) ;
const options = getNodeRequestOptions ( request ) ;
2020-07-18 08:55:42 +00:00
2020-08-19 03:20:28 +00:00
const send = ( options . protocol === 'https:' ? https : http ) . request ;
const signal = request . signal ;
2020-07-18 08:55:42 +00:00
2020-08-19 03:20:28 +00:00
let response = null ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const abort = function abort ( ) {
let error = new AbortError ( 'The user aborted a request.' ) ;
reject ( error ) ;
if ( request . body && request . body instanceof Stream . Readable ) {
request . body . destroy ( error ) ;
}
if ( ! response || ! response . body ) return ;
response . body . emit ( 'error' , error ) ;
} ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( signal && signal . aborted ) {
abort ( ) ;
return ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const abortAndFinalize = function abortAndFinalize ( ) {
abort ( ) ;
finalize ( ) ;
} ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// send request
const req = send ( options ) ;
let reqTimeout ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( signal ) {
signal . addEventListener ( 'abort' , abortAndFinalize ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
function finalize ( ) {
req . abort ( ) ;
if ( signal ) signal . removeEventListener ( 'abort' , abortAndFinalize ) ;
clearTimeout ( reqTimeout ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( request . timeout ) {
req . once ( 'socket' , function ( socket ) {
reqTimeout = setTimeout ( function ( ) {
reject ( new FetchError ( ` network timeout at: ${ request . url } ` , 'request-timeout' ) ) ;
finalize ( ) ;
} , request . timeout ) ;
} ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
req . on ( 'error' , function ( err ) {
reject ( new FetchError ( ` request to ${ request . url } failed, reason: ${ err . message } ` , 'system' , err ) ) ;
finalize ( ) ;
} ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
req . on ( 'response' , function ( res ) {
clearTimeout ( reqTimeout ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
const headers = createHeadersLenient ( res . headers ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// HTTP fetch step 5
if ( fetch . isRedirect ( res . statusCode ) ) {
// HTTP fetch step 5.2
const location = headers . get ( 'Location' ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// HTTP fetch step 5.3
const locationURL = location === null ? null : resolve _url ( request . url , location ) ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// HTTP fetch step 5.5
switch ( request . redirect ) {
case 'error' :
reject ( new FetchError ( ` redirect mode is set to error: ${ request . url } ` , 'no-redirect' ) ) ;
finalize ( ) ;
return ;
case 'manual' :
// node-fetch-specific step: make manual redirect a bit easier to use by setting the Location header value to the resolved URL.
if ( locationURL !== null ) {
// handle corrupted header
try {
headers . set ( 'Location' , locationURL ) ;
} catch ( err ) {
// istanbul ignore next: nodejs server prevent invalid response headers, we can't test this through normal request
reject ( err ) ;
}
}
break ;
case 'follow' :
// HTTP-redirect fetch step 2
if ( locationURL === null ) {
break ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// HTTP-redirect fetch step 5
if ( request . counter >= request . follow ) {
reject ( new FetchError ( ` maximum redirect reached at: ${ request . url } ` , 'max-redirect' ) ) ;
finalize ( ) ;
return ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// HTTP-redirect fetch step 6 (counter increment)
// Create a new Request object.
const requestOpts = {
headers : new Headers ( request . headers ) ,
follow : request . follow ,
counter : request . counter + 1 ,
agent : request . agent ,
compress : request . compress ,
method : request . method ,
body : request . body ,
signal : request . signal ,
timeout : request . timeout
} ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// HTTP-redirect fetch step 9
if ( res . statusCode !== 303 && request . body && getTotalBytes ( request ) === null ) {
reject ( new FetchError ( 'Cannot follow redirect with body being a readable stream' , 'unsupported-redirect' ) ) ;
finalize ( ) ;
return ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// HTTP-redirect fetch step 11
if ( res . statusCode === 303 || ( res . statusCode === 301 || res . statusCode === 302 ) && request . method === 'POST' ) {
requestOpts . method = 'GET' ;
requestOpts . body = undefined ;
requestOpts . headers . delete ( 'content-length' ) ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// HTTP-redirect fetch step 15
resolve ( fetch ( new Request ( locationURL , requestOpts ) ) ) ;
finalize ( ) ;
return ;
}
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// prepare response
res . once ( 'end' , function ( ) {
if ( signal ) signal . removeEventListener ( 'abort' , abortAndFinalize ) ;
} ) ;
let body = res . pipe ( new PassThrough$1 ( ) ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const response _options = {
url : request . url ,
status : res . statusCode ,
statusText : res . statusMessage ,
headers : headers ,
size : request . size ,
timeout : request . timeout ,
counter : request . counter
} ;
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
// HTTP-network fetch step 12.1.1.3
const codings = headers . get ( 'Content-Encoding' ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// HTTP-network fetch step 12.1.1.4: handle content codings
// in following scenarios we ignore compression support
// 1. compression support is disabled
// 2. HEAD request
// 3. no Content-Encoding header
// 4. no content response (204)
// 5. content not modified response (304)
if ( ! request . compress || request . method === 'HEAD' || codings === null || res . statusCode === 204 || res . statusCode === 304 ) {
response = new Response ( body , response _options ) ;
resolve ( response ) ;
return ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// For Node v6+
// Be less strict when decoding compressed responses, since sometimes
// servers send slightly invalid responses that are still accepted
// by common browsers.
// Always using Z_SYNC_FLUSH is what cURL does.
const zlibOptions = {
flush : zlib . Z _SYNC _FLUSH ,
finishFlush : zlib . Z _SYNC _FLUSH
} ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// for gzip
if ( codings == 'gzip' || codings == 'x-gzip' ) {
body = body . pipe ( zlib . createGunzip ( zlibOptions ) ) ;
response = new Response ( body , response _options ) ;
resolve ( response ) ;
return ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// for deflate
if ( codings == 'deflate' || codings == 'x-deflate' ) {
// handle the infamous raw deflate response from old servers
// a hack for old IIS and Apache servers
const raw = res . pipe ( new PassThrough$1 ( ) ) ;
raw . once ( 'data' , function ( chunk ) {
// see http://stackoverflow.com/questions/37519828
if ( ( chunk [ 0 ] & 0x0F ) === 0x08 ) {
body = body . pipe ( zlib . createInflate ( ) ) ;
} else {
body = body . pipe ( zlib . createInflateRaw ( ) ) ;
}
response = new Response ( body , response _options ) ;
resolve ( response ) ;
} ) ;
return ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// for br
if ( codings == 'br' && typeof zlib . createBrotliDecompress === 'function' ) {
body = body . pipe ( zlib . createBrotliDecompress ( ) ) ;
response = new Response ( body , response _options ) ;
resolve ( response ) ;
return ;
}
// otherwise, use response as-is
response = new Response ( body , response _options ) ;
resolve ( response ) ;
} ) ;
writeToStream ( req , request ) ;
} ) ;
}
/ * *
* Redirect code matching
*
* @ param Number code Status code
* @ return Boolean
* /
fetch . isRedirect = function ( code ) {
return code === 301 || code === 302 || code === 303 || code === 307 || code === 308 ;
} ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
// expose Promise
fetch . Promise = global . Promise ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
module . exports = exports = fetch ;
Object . defineProperty ( exports , "__esModule" , { value : true } ) ;
exports . default = exports ;
exports . Headers = Headers ;
exports . Request = Request ;
exports . Response = Response ;
exports . FetchError = FetchError ;
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
/***/ } ) ,
2020-08-19 03:20:28 +00:00
/***/ 456 :
/***/ ( function ( _ _unusedmodule , exports ) {
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
"use strict" ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
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 ;
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
/***/ } ) ,
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
/***/ 463 :
2020-07-16 08:57:13 +00:00
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
"use strict" ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
Object . defineProperty ( exports , '__esModule' , { value : true } ) ;
function _interopDefault ( ex ) { return ( ex && ( typeof ex === 'object' ) && 'default' in ex ) ? ex [ 'default' ] : ex ; }
var deprecation = _ _webpack _require _ _ ( 692 ) ;
var once = _interopDefault ( _ _webpack _require _ _ ( 49 ) ) ;
const logOnce = once ( deprecation => console . warn ( deprecation ) ) ;
2020-07-16 08:57:13 +00:00
/ * *
2020-08-19 03:20:28 +00:00
* Error with extra properties to help with debugging
2020-07-16 08:57:13 +00:00
* /
2020-08-19 03:20:28 +00:00
class RequestError extends Error {
constructor ( message , statusCode , options ) {
super ( message ) ; // Maintains proper stack trace (only available on V8)
/* istanbul ignore next */
if ( Error . captureStackTrace ) {
Error . captureStackTrace ( this , this . constructor ) ;
2020-07-16 08:57:13 +00:00
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
this . name = "HttpError" ;
this . status = statusCode ;
Object . defineProperty ( this , "code" , {
get ( ) {
logOnce ( new deprecation . Deprecation ( "[@octokit/request-error] `error.code` is deprecated, use `error.status`." ) ) ;
return statusCode ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
} ) ;
this . headers = options . headers || { } ; // redact request credentials without mutating original request options
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
const requestCopy = Object . assign ( { } , options . request ) ;
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
if ( options . request . headers . authorization ) {
requestCopy . headers = Object . assign ( { } , options . request . headers , {
authorization : options . request . headers . authorization . replace ( / .*$/ , " [REDACTED]" )
} ) ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
requestCopy . url = requestCopy . url // client_id & client_secret can be passed as URL query parameters to increase rate limit
// see https://developer.github.com/v3/#increasing-the-unauthenticated-rate-limit-for-oauth-applications
. replace ( /\bclient_secret=\w+/g , "client_secret=[REDACTED]" ) // OAuth tokens can be passed as URL query parameters, although it is not recommended
// see https://developer.github.com/v3/#oauth2-token-sent-in-a-header
. replace ( /\baccess_token=\w+/g , "access_token=[REDACTED]" ) ;
this . request = requestCopy ;
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
exports . RequestError = RequestError ;
//# sourceMappingURL=index.js.map
2019-11-09 08:24:47 +00:00
/***/ } ) ,
2020-08-19 03:20:28 +00:00
/***/ 470 :
2019-11-09 08:24:47 +00:00
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
"use strict" ;
2020-07-16 08:57:13 +00:00
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 ( ) ) ;
} ) ;
} ;
2020-05-02 08:45:04 +00:00
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 ;
} ;
2019-11-09 08:24:47 +00:00
Object . defineProperty ( exports , "__esModule" , { value : true } ) ;
2020-08-19 03:20:28 +00:00
const command _1 = _ _webpack _require _ _ ( 431 ) ;
2020-05-02 08:45:04 +00:00
const os = _ _importStar ( _ _webpack _require _ _ ( 87 ) ) ;
2020-07-16 08:57:13 +00:00
const path = _ _importStar ( _ _webpack _require _ _ ( 622 ) ) ;
2020-08-19 03:20:28 +00:00
/ * *
* The code to exit an action
2019-11-09 08:24:47 +00:00
* /
2020-08-19 03:20:28 +00:00
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 = command _1 . toCommandValue ( val ) ;
process . env [ name ] = convertedVal ;
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 ) {
command _1 . issueCommand ( 'add-path' , { } , inputPath ) ;
process . env [ 'PATH' ] = ` ${ inputPath } ${ path . delimiter } ${ process . env [ 'PATH' ] } ` ;
}
exports . addPath = addPath ;
/ * *
* Gets the value of an input . The value is also trimmed .
*
* @ 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 } ` ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
return val . trim ( ) ;
}
exports . getInput = getInput ;
/ * *
* 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 ) {
command _1 . issueCommand ( 'set-output' , { name } , 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 ( )
* /
function error ( message ) {
command _1 . issue ( 'error' , message instanceof Error ? message . toString ( ) : message ) ;
}
exports . error = error ;
/ * *
* Adds an warning issue
* @ param message warning issue message . Errors will be converted to string via toString ( )
* /
function warning ( message ) {
command _1 . issue ( 'warning' , message instanceof Error ? message . toString ( ) : message ) ;
}
exports . warning = warning ;
/ * *
* 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 ( ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
finally {
endGroup ( ) ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
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 ) {
command _1 . issueCommand ( 'save-state' , { name } , 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 ;
//# sourceMappingURL=core.js.map
/***/ } ) ,
/***/ 498 :
/***/ ( 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 ;
/***/ } ) ,
/***/ 510 :
/***/ ( function ( module ) {
module . exports = addHook
function addHook ( state , kind , name , hook ) {
var orig = hook
if ( ! state . registry [ name ] ) {
state . registry [ name ] = [ ]
}
if ( kind === 'before' ) {
hook = function ( method , options ) {
return Promise . resolve ( )
. then ( orig . bind ( null , options ) )
. then ( method . bind ( null , options ) )
2020-05-17 09:26:30 +00:00
}
2020-08-19 03:20:28 +00:00
}
if ( kind === 'after' ) {
hook = function ( method , options ) {
var result
return Promise . resolve ( )
. then ( method . bind ( null , options ) )
. then ( function ( result _ ) {
result = result _
return orig ( result , options )
} )
. then ( function ( ) {
return result
} )
2020-05-17 09:26:30 +00:00
}
2020-08-19 03:20:28 +00:00
}
if ( kind === 'error' ) {
hook = function ( method , options ) {
return Promise . resolve ( )
. then ( method . bind ( null , options ) )
. catch ( function ( error ) {
return orig ( error , options )
} )
2020-05-17 09:26:30 +00:00
}
2020-08-19 03:20:28 +00:00
}
state . registry [ name ] . push ( {
hook : hook ,
orig : orig
} )
}
/***/ } ) ,
/***/ 523 :
/***/ ( function ( module , _ _unusedexports , _ _webpack _require _ _ ) {
var register = _ _webpack _require _ _ ( 280 )
var addHook = _ _webpack _require _ _ ( 510 )
var removeHook = _ _webpack _require _ _ ( 866 )
// bind with array of arguments: https://stackoverflow.com/a/21792913
var bind = Function . bind
var bindable = bind . bind ( bind )
function bindApi ( hook , state , name ) {
var removeHookRef = bindable ( removeHook , null ) . apply ( null , name ? [ state , name ] : [ state ] )
hook . api = { remove : removeHookRef }
hook . remove = removeHookRef
; [ 'before' , 'error' , 'after' , 'wrap' ] . forEach ( function ( kind ) {
var args = name ? [ state , kind , name ] : [ state , kind ]
hook [ kind ] = hook . api [ kind ] = bindable ( addHook , null ) . apply ( null , args )
} )
}
function HookSingular ( ) {
var singularHookName = 'h'
var singularHookState = {
registry : { }
}
var singularHook = register . bind ( null , singularHookState , singularHookName )
bindApi ( singularHook , singularHookState , singularHookName )
return singularHook
}
function HookCollection ( ) {
var state = {
registry : { }
}
var hook = register . bind ( null , state )
bindApi ( hook , state )
return hook
}
var collectionHookDeprecationMessageDisplayed = false
function Hook ( ) {
if ( ! collectionHookDeprecationMessageDisplayed ) {
console . warn ( '[before-after-hook]: "Hook()" repurposing warning, use "Hook.Collection()". Read more: https://git.io/upgrade-before-after-hook-to-1.4' )
collectionHookDeprecationMessageDisplayed = true
}
return HookCollection ( )
}
Hook . Singular = HookSingular . bind ( )
Hook . Collection = HookCollection . bind ( )
module . exports = Hook
// expose constructors as a named property for TypeScript
module . exports . Hook = Hook
module . exports . Singular = Hook . Singular
module . exports . Collection = Hook . Collection
/***/ } ) ,
/***/ 548 :
/***/ ( function ( module ) {
"use strict" ;
/ * !
* is - plain - object < https : //github.com/jonschlinkert/is-plain-object>
*
* Copyright ( c ) 2014 - 2017 , Jon Schlinkert .
* Released under the MIT License .
* /
function isObject ( o ) {
return Object . prototype . toString . call ( o ) === '[object Object]' ;
}
function isPlainObject ( o ) {
var ctor , prot ;
if ( isObject ( o ) === false ) return false ;
// If has modified constructor
ctor = o . constructor ;
if ( ctor === undefined ) return true ;
// If has modified prototype
prot = ctor . prototype ;
if ( isObject ( prot ) === false ) return false ;
// If constructor does not have an Object-specific method
if ( prot . hasOwnProperty ( 'isPrototypeOf' ) === false ) {
return false ;
}
// Most likely a plain Object
return true ;
}
module . exports = isPlainObject ;
/***/ } ) ,
/***/ 605 :
/***/ ( function ( module ) {
module . exports = require ( "http" ) ;
/***/ } ) ,
/***/ 611 :
/***/ ( 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 . fileExistsSync = exports . parseDisplayNameEmail = exports . randomString = exports . secondsSinceEpoch = exports . getRemoteUrl = exports . getRemoteDetail = exports . getRepoPath = exports . getStringAsArray = exports . getInputAsArray = void 0 ;
const core = _ _importStar ( _ _webpack _require _ _ ( 470 ) ) ;
const fs = _ _importStar ( _ _webpack _require _ _ ( 747 ) ) ;
const path = _ _importStar ( _ _webpack _require _ _ ( 622 ) ) ;
function getInputAsArray ( name , options ) {
return getStringAsArray ( core . getInput ( name , options ) ) ;
}
exports . getInputAsArray = getInputAsArray ;
function getStringAsArray ( str ) {
return str
. split ( /[\n,]+/ )
. map ( s => s . trim ( ) )
. filter ( x => x !== '' ) ;
}
exports . getStringAsArray = getStringAsArray ;
function getRepoPath ( relativePath ) {
let githubWorkspacePath = process . env [ 'GITHUB_WORKSPACE' ] ;
if ( ! githubWorkspacePath ) {
throw new Error ( 'GITHUB_WORKSPACE not defined' ) ;
}
githubWorkspacePath = path . resolve ( githubWorkspacePath ) ;
core . debug ( ` githubWorkspacePath: ${ githubWorkspacePath } ` ) ;
let repoPath = githubWorkspacePath ;
if ( relativePath )
repoPath = path . resolve ( repoPath , relativePath ) ;
core . debug ( ` repoPath: ${ repoPath } ` ) ;
return repoPath ;
}
exports . getRepoPath = getRepoPath ;
function getRemoteDetail ( remoteUrl ) {
// Parse the protocol and github repository from a URL
// e.g. HTTPS, peter-evans/create-pull-request
const httpsUrlPattern = /^https:\/\/.*@?github.com\/(.+\/.+)$/i ;
const sshUrlPattern = /^git@github.com:(.+\/.+).git$/i ;
const httpsMatch = remoteUrl . match ( httpsUrlPattern ) ;
if ( httpsMatch ) {
return {
protocol : 'HTTPS' ,
repository : httpsMatch [ 1 ]
} ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
const sshMatch = remoteUrl . match ( sshUrlPattern ) ;
if ( sshMatch ) {
return {
protocol : 'SSH' ,
repository : sshMatch [ 1 ]
2020-05-17 09:26:30 +00:00
} ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
throw new Error ( ` The format of ' ${ remoteUrl } ' is not a valid GitHub repository URL ` ) ;
}
exports . getRemoteDetail = getRemoteDetail ;
function getRemoteUrl ( protocol , repository ) {
return protocol == 'HTTPS'
? ` https://github.com/ ${ repository } `
: ` git@github.com: ${ repository } .git ` ;
}
exports . getRemoteUrl = getRemoteUrl ;
function secondsSinceEpoch ( ) {
const now = new Date ( ) ;
return Math . round ( now . getTime ( ) / 1000 ) ;
}
exports . secondsSinceEpoch = secondsSinceEpoch ;
function randomString ( ) {
return Math . random ( ) . toString ( 36 ) . substr ( 2 , 7 ) ;
}
exports . randomString = randomString ;
function parseDisplayNameEmail ( displayNameEmail ) {
// Parse the name and email address from a string in the following format
// Display Name <email@address.com>
const pattern = /^([^<]+)\s*<([^>]+)>$/i ;
// Check we have a match
const match = displayNameEmail . match ( pattern ) ;
if ( ! match ) {
throw new Error ( ` The format of ' ${ displayNameEmail } ' is not a valid email address with display name ` ) ;
}
// Check that name and email are not just whitespace
const name = match [ 1 ] . trim ( ) ;
const email = match [ 2 ] . trim ( ) ;
if ( ! name || ! email ) {
throw new Error ( ` The format of ' ${ displayNameEmail } ' is not a valid email address with display name ` ) ;
}
return {
name : name ,
email : email
} ;
}
exports . parseDisplayNameEmail = parseDisplayNameEmail ;
function fileExistsSync ( path ) {
if ( ! path ) {
throw new Error ( "Arg 'path' must not be empty" ) ;
}
let stats ;
try {
stats = fs . statSync ( path ) ;
}
catch ( error ) {
if ( error . code === 'ENOENT' ) {
return false ;
2020-05-17 09:26:30 +00:00
}
2020-08-19 03:20:28 +00:00
throw new Error ( ` Encountered an error when checking whether path ' ${ path } ' exists: ${ error . message } ` ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
if ( ! stats . isDirectory ( ) ) {
return true ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
return false ;
}
exports . fileExistsSync = fileExistsSync ;
/***/ } ) ,
/***/ 614 :
/***/ ( function ( module ) {
module . exports = require ( "events" ) ;
/***/ } ) ,
/***/ 622 :
/***/ ( function ( module ) {
module . exports = require ( "path" ) ;
/***/ } ) ,
/***/ 626 :
/***/ ( function ( module ) {
"use strict" ;
/ * !
* is - plain - object < https : //github.com/jonschlinkert/is-plain-object>
*
* Copyright ( c ) 2014 - 2017 , Jon Schlinkert .
* Released under the MIT License .
* /
function isObject ( o ) {
return Object . prototype . toString . call ( o ) === '[object Object]' ;
}
function isPlainObject ( o ) {
var ctor , prot ;
if ( isObject ( o ) === false ) return false ;
// If has modified constructor
ctor = o . constructor ;
if ( ctor === undefined ) return true ;
// If has modified prototype
prot = ctor . prototype ;
if ( isObject ( prot ) === false ) return false ;
// If constructor does not have an Object-specific method
if ( prot . hasOwnProperty ( 'isPrototypeOf' ) === false ) {
return false ;
}
// Most likely a plain Object
return true ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
module . exports = isPlainObject ;
/***/ } ) ,
/***/ 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 ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
catch ( err ) {
if ( err . code === 'ENOENT' ) {
return false ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
throw err ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
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' ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
if ( exports . IS _WINDOWS ) {
return ( p . startsWith ( '\\' ) || /^[A-Z]:/i . test ( p ) // e.g. \ or \hello or \\hello
) ; // e.g. C: or C:\hello
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
return p . startsWith ( '/' ) ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
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 ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
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 ;
}
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
} ) ;
}
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 ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
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 } ` ) ;
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
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 ;
}
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
// try each extension
const originalFilePath = filePath ;
for ( const extension of extensions ) {
filePath = originalFilePath + extension ;
stats = undefined ;
try {
stats = yield exports . stat ( filePath ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
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 } ` ) ;
}
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
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 ;
}
}
2020-07-16 08:57:13 +00:00
}
}
2020-08-19 03:20:28 +00:00
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 , '\\' ) ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
// remove redundant slashes
return p . replace ( /\/\/+/g , '/' ) ;
2019-11-09 08:24:47 +00:00
}
2020-08-19 03:20:28 +00:00
// 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
2020-07-16 08:57:13 +00:00
/***/ } ) ,
/***/ 692 :
/***/ ( function ( _ _unusedmodule , exports ) {
"use strict" ;
Object . defineProperty ( exports , '__esModule' , { value : true } ) ;
class Deprecation extends Error {
constructor ( message ) {
super ( message ) ; // Maintains proper stack trace (only available on V8)
/* istanbul ignore next */
if ( Error . captureStackTrace ) {
Error . captureStackTrace ( this , this . constructor ) ;
}
this . name = 'Deprecation' ;
}
2019-11-09 08:24:47 +00:00
}
2020-07-16 08:57:13 +00:00
exports . Deprecation = Deprecation ;
/***/ } ) ,
2020-08-19 03:20:28 +00:00
/***/ 695 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
2020-07-16 08:57:13 +00:00
"use strict" ;
2020-08-19 03:20:28 +00:00
Object . defineProperty ( exports , "__esModule" , {
value : true
} ) ;
exports . default = void 0 ;
var _validate = _interopRequireDefault ( _ _webpack _require _ _ ( 78 ) ) ;
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 ;
2019-11-09 08:24:47 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
/***/ 718 :
2019-11-09 08:24:47 +00:00
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
"use strict" ;
2020-07-16 08:57:13 +00:00
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 = { } ;
2020-08-19 03:20:28 +00:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
2020-07-16 08:57:13 +00:00
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
2019-11-09 08:24:47 +00:00
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 ( ) ) ;
} ) ;
} ;
2020-07-16 08:57:13 +00:00
Object . defineProperty ( exports , "__esModule" , { value : true } ) ;
exports . GitHubHelper = void 0 ;
const core = _ _importStar ( _ _webpack _require _ _ ( 470 ) ) ;
const octokit _client _1 = _ _webpack _require _ _ ( 921 ) ;
const ERROR _PR _REVIEW _FROM _AUTHOR = 'Review cannot be requested from pull request author' ;
class GitHubHelper {
constructor ( token ) {
const options = { } ;
if ( token ) {
options . auth = ` ${ token } ` ;
}
this . octokit = new octokit _client _1 . Octokit ( options ) ;
}
parseRepository ( repository ) {
const [ owner , repo ] = repository . split ( '/' ) ;
return {
owner : owner ,
repo : repo
} ;
}
createOrUpdate ( inputs , baseRepository , headBranch ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
// Try to create the pull request
try {
const { data : pull } = yield this . octokit . pulls . create ( Object . assign ( Object . assign ( { } , this . parseRepository ( baseRepository ) ) , { title : inputs . title , head : headBranch , base : inputs . base , body : inputs . body , draft : inputs . draft } ) ) ;
core . info ( ` Created pull request # ${ pull . number } ( ${ headBranch } => ${ inputs . base } ) ` ) ;
return pull . number ;
}
catch ( e ) {
if ( ! e . message ||
! e . message . includes ( ` A pull request already exists for ${ headBranch } ` ) ) {
throw e ;
}
}
// Update the pull request that exists for this branch and base
const { data : pulls } = yield this . octokit . pulls . list ( Object . assign ( Object . assign ( { } , this . parseRepository ( baseRepository ) ) , { state : 'open' , head : headBranch , base : inputs . base } ) ) ;
const { data : pull } = yield this . octokit . pulls . update ( Object . assign ( Object . assign ( { } , this . parseRepository ( baseRepository ) ) , { pull _number : pulls [ 0 ] . number , title : inputs . title , body : inputs . body , draft : inputs . draft } ) ) ;
core . info ( ` Updated pull request # ${ pull . number } ( ${ headBranch } => ${ inputs . base } ) ` ) ;
return pull . number ;
} ) ;
}
2020-07-18 06:33:46 +00:00
getRepositoryParent ( headRepository ) {
2020-07-16 08:57:13 +00:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { data : headRepo } = yield this . octokit . repos . get ( Object . assign ( { } , this . parseRepository ( headRepository ) ) ) ;
2020-07-18 06:33:46 +00:00
if ( ! headRepo . parent ) {
throw new Error ( ` Repository ' ${ headRepository } ' is not a fork. Unable to continue. ` ) ;
2020-07-16 08:57:13 +00:00
}
2020-07-18 06:33:46 +00:00
return headRepo . parent . full _name ;
} ) ;
}
createOrUpdatePullRequest ( inputs , baseRepository , headRepository ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const [ headOwner ] = headRepository . split ( '/' ) ;
const headBranch = ` ${ headOwner } : ${ inputs . branch } ` ;
2020-07-16 08:57:13 +00:00
// Create or update the pull request
const pullNumber = yield this . createOrUpdate ( inputs , baseRepository , headBranch ) ;
2020-07-16 10:42:19 +00:00
// Set outputs
core . startGroup ( 'Setting outputs' ) ;
2020-07-16 08:57:13 +00:00
core . setOutput ( 'pull-request-number' , pullNumber ) ;
2020-07-16 10:42:19 +00:00
core . exportVariable ( 'PULL_REQUEST_NUMBER' , pullNumber ) ;
core . endGroup ( ) ;
2020-07-16 08:57:13 +00:00
// Set milestone, labels and assignees
const updateIssueParams = { } ;
if ( inputs . milestone ) {
updateIssueParams [ 'milestone' ] = inputs . milestone ;
core . info ( ` Applying milestone ' ${ inputs . milestone } ' ` ) ;
}
if ( inputs . labels . length > 0 ) {
updateIssueParams [ 'labels' ] = inputs . labels ;
core . info ( ` Applying labels ' ${ inputs . labels } ' ` ) ;
}
if ( inputs . assignees . length > 0 ) {
updateIssueParams [ 'assignees' ] = inputs . assignees ;
core . info ( ` Applying assignees ' ${ inputs . assignees } ' ` ) ;
}
if ( Object . keys ( updateIssueParams ) . length > 0 ) {
yield this . octokit . issues . update ( Object . assign ( Object . assign ( Object . assign ( { } , this . parseRepository ( baseRepository ) ) , { issue _number : pullNumber } ) , updateIssueParams ) ) ;
}
// Request reviewers and team reviewers
const requestReviewersParams = { } ;
if ( inputs . reviewers . length > 0 ) {
requestReviewersParams [ 'reviewers' ] = inputs . reviewers ;
core . info ( ` Requesting reviewers ' ${ inputs . reviewers } ' ` ) ;
}
if ( inputs . teamReviewers . length > 0 ) {
requestReviewersParams [ 'team_reviewers' ] = inputs . teamReviewers ;
core . info ( ` Requesting team reviewers ' ${ inputs . teamReviewers } ' ` ) ;
}
if ( Object . keys ( requestReviewersParams ) . length > 0 ) {
try {
yield this . octokit . pulls . requestReviewers ( Object . assign ( Object . assign ( Object . assign ( { } , this . parseRepository ( baseRepository ) ) , { pull _number : pullNumber } ) , requestReviewersParams ) ) ;
}
catch ( e ) {
if ( e . message && e . message . includes ( ERROR _PR _REVIEW _FROM _AUTHOR ) ) {
core . warning ( ERROR _PR _REVIEW _FROM _AUTHOR ) ;
}
else {
throw e ;
}
}
}
} ) ;
}
}
exports . GitHubHelper = GitHubHelper ;
/***/ } ) ,
/***/ 733 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , {
value : true
} ) ;
exports . default = void 0 ;
var _rng = _interopRequireDefault ( _ _webpack _require _ _ ( 844 ) ) ;
2020-08-19 03:20:28 +00:00
var _stringify = _interopRequireDefault ( _ _webpack _require _ _ ( 411 ) ) ;
2020-07-16 08:57:13 +00:00
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 ;
}
2020-08-19 03:20:28 +00:00
return ( 0 , _stringify . default ) ( rnds ) ;
2020-07-16 08:57:13 +00:00
}
var _default = v4 ;
exports . default = _default ;
/***/ } ) ,
/***/ 747 :
/***/ ( function ( module ) {
module . exports = require ( "fs" ) ;
/***/ } ) ,
/***/ 753 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
"use strict" ;
Object . defineProperty ( exports , '__esModule' , { value : true } ) ;
function _interopDefault ( ex ) { return ( ex && ( typeof ex === 'object' ) && 'default' in ex ) ? ex [ 'default' ] : ex ; }
var endpoint = _ _webpack _require _ _ ( 385 ) ;
var universalUserAgent = _ _webpack _require _ _ ( 796 ) ;
var isPlainObject = _interopDefault ( _ _webpack _require _ _ ( 548 ) ) ;
var nodeFetch = _interopDefault ( _ _webpack _require _ _ ( 454 ) ) ;
var requestError = _ _webpack _require _ _ ( 463 ) ;
2020-08-19 03:20:28 +00:00
const VERSION = "5.4.7" ;
2020-07-16 08:57:13 +00:00
function getBufferResponse ( response ) {
return response . arrayBuffer ( ) ;
}
function fetchWrapper ( requestOptions ) {
if ( isPlainObject ( requestOptions . body ) || Array . isArray ( requestOptions . body ) ) {
requestOptions . body = JSON . stringify ( requestOptions . body ) ;
}
let headers = { } ;
let status ;
let url ;
const fetch = requestOptions . request && requestOptions . request . fetch || nodeFetch ;
return fetch ( requestOptions . url , Object . assign ( {
method : requestOptions . method ,
body : requestOptions . body ,
headers : requestOptions . headers ,
redirect : requestOptions . redirect
} , requestOptions . request ) ) . then ( response => {
url = response . url ;
status = response . status ;
for ( const keyAndValue of response . headers ) {
headers [ keyAndValue [ 0 ] ] = keyAndValue [ 1 ] ;
}
if ( status === 204 || status === 205 ) {
return ;
} // GitHub API returns 200 for HEAD requests
if ( requestOptions . method === "HEAD" ) {
if ( status < 400 ) {
return ;
}
throw new requestError . RequestError ( response . statusText , status , {
headers ,
request : requestOptions
} ) ;
}
if ( status === 304 ) {
throw new requestError . RequestError ( "Not modified" , status , {
headers ,
request : requestOptions
} ) ;
}
if ( status >= 400 ) {
return response . text ( ) . then ( message => {
const error = new requestError . RequestError ( message , status , {
headers ,
request : requestOptions
2020-05-02 11:27:54 +00:00
} ) ;
2020-07-16 08:57:13 +00:00
2020-05-02 11:27:54 +00:00
try {
2020-07-16 08:57:13 +00:00
let responseBody = JSON . parse ( error . message ) ;
Object . assign ( error , responseBody ) ;
let errors = responseBody . errors ; // Assumption `errors` would always be in Array format
error . message = error . message + ": " + errors . map ( JSON . stringify ) . join ( ", " ) ;
} catch ( e ) { // ignore, see octokit/rest.js#684
2020-05-02 11:27:54 +00:00
}
2020-07-16 08:57:13 +00:00
throw error ;
} ) ;
}
const contentType = response . headers . get ( "content-type" ) ;
if ( /application\/json/ . test ( contentType ) ) {
return response . json ( ) ;
}
if ( ! contentType || /^text\/|charset=utf-8$/ . test ( contentType ) ) {
return response . text ( ) ;
}
return getBufferResponse ( response ) ;
} ) . then ( data => {
return {
status ,
url ,
headers ,
data
} ;
} ) . catch ( error => {
if ( error instanceof requestError . RequestError ) {
throw error ;
}
throw new requestError . RequestError ( error . message , 500 , {
headers ,
request : requestOptions
2020-05-02 11:27:54 +00:00
} ) ;
2020-07-16 08:57:13 +00:00
} ) ;
2020-05-02 11:27:54 +00:00
}
2020-07-16 08:57:13 +00:00
function withDefaults ( oldEndpoint , newDefaults ) {
const endpoint = oldEndpoint . defaults ( newDefaults ) ;
const newApi = function ( route , parameters ) {
const endpointOptions = endpoint . merge ( route , parameters ) ;
if ( ! endpointOptions . request || ! endpointOptions . request . hook ) {
return fetchWrapper ( endpoint . parse ( endpointOptions ) ) ;
}
const request = ( route , parameters ) => {
return fetchWrapper ( endpoint . parse ( endpoint . merge ( route , parameters ) ) ) ;
} ;
Object . assign ( request , {
endpoint ,
defaults : withDefaults . bind ( null , endpoint )
2019-11-09 08:24:47 +00:00
} ) ;
2020-07-16 08:57:13 +00:00
return endpointOptions . request . hook ( request , endpointOptions ) ;
} ;
return Object . assign ( newApi , {
endpoint ,
defaults : withDefaults . bind ( null , endpoint )
} ) ;
2019-11-09 08:24:47 +00:00
}
2020-07-16 08:57:13 +00:00
const request = withDefaults ( endpoint . endpoint , {
headers : {
"user-agent" : ` octokit-request.js/ ${ VERSION } ${ universalUserAgent . getUserAgent ( ) } `
}
} ) ;
exports . request = request ;
//# sourceMappingURL=index.js.map
/***/ } ) ,
/***/ 761 :
/***/ ( function ( module ) {
module . exports = require ( "zlib" ) ;
/***/ } ) ,
/***/ 796 :
2020-08-19 03:20:28 +00:00
/***/ ( function ( _ _unusedmodule , exports ) {
2020-07-16 08:57:13 +00:00
"use strict" ;
Object . defineProperty ( exports , '__esModule' , { value : true } ) ;
function getUserAgent ( ) {
2020-08-19 03:20:28 +00:00
if ( typeof navigator === "object" && "userAgent" in navigator ) {
return navigator . userAgent ;
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( typeof process === "object" && "version" in process ) {
return ` Node.js/ ${ process . version . substr ( 1 ) } ( ${ process . platform } ; ${ process . arch } ) ` ;
2020-07-16 08:57:13 +00:00
}
2020-08-19 03:20:28 +00:00
return "<environment undetectable>" ;
2019-11-09 08:24:47 +00:00
}
2020-07-16 08:57:13 +00:00
exports . getUserAgent = getUserAgent ;
//# sourceMappingURL=index.js.map
/***/ } ) ,
/***/ 803 :
/***/ ( 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 ( ) ;
2019-11-09 08:24:47 +00:00
}
2020-07-16 08:57:13 +00:00
var _default = md5 ;
exports . default = _default ;
/***/ } ) ,
/***/ 813 :
/***/ ( function ( _ _unusedmodule , exports ) {
"use strict" ;
Object . defineProperty ( exports , '__esModule' , { value : true } ) ;
async function auth ( token ) {
const tokenType = token . split ( /\./ ) . length === 3 ? "app" : /^v\d+\./ . test ( token ) ? "installation" : "oauth" ;
return {
type : "token" ,
token : token ,
tokenType
} ;
2019-11-09 08:24:47 +00:00
}
2020-07-16 08:57:13 +00:00
2019-11-09 08:24:47 +00:00
/ * *
2020-07-16 08:57:13 +00:00
* Prefix token for usage in the Authorization header
2019-11-09 08:24:47 +00:00
*
2020-07-16 08:57:13 +00:00
* @ param token OAuth token or JSON Web Token
2019-11-09 08:24:47 +00:00
* /
2020-07-16 08:57:13 +00:00
function withAuthorizationPrefix ( token ) {
if ( token . split ( /\./ ) . length === 3 ) {
return ` bearer ${ token } ` ;
}
return ` token ${ token } ` ;
2019-11-09 08:24:47 +00:00
}
2020-07-16 08:57:13 +00:00
async function hook ( token , request , route , parameters ) {
const endpoint = request . endpoint . merge ( route , parameters ) ;
endpoint . headers . authorization = withAuthorizationPrefix ( token ) ;
return request ( endpoint ) ;
2019-11-09 08:24:47 +00:00
}
2020-07-16 08:57:13 +00:00
const createTokenAuth = function createTokenAuth ( token ) {
if ( ! token ) {
throw new Error ( "[@octokit/auth-token] No token passed to createTokenAuth" ) ;
}
if ( typeof token !== "string" ) {
throw new Error ( "[@octokit/auth-token] Token passed to createTokenAuth is not a string" ) ;
}
token = token . replace ( /^(token|bearer) +/i , "" ) ;
return Object . assign ( auth . bind ( null , token ) , {
hook : hook . bind ( null , token )
} ) ;
} ;
exports . createTokenAuth = createTokenAuth ;
//# sourceMappingURL=index.js.map
2020-01-03 03:32:22 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
/***/ 835 :
/***/ ( function ( module ) {
module . exports = require ( "url" ) ;
/***/ } ) ,
/***/ 842 :
/***/ ( function ( _ _unusedmodule , exports ) {
2020-01-03 03:32:22 +00:00
"use strict" ;
2020-07-16 08:57:13 +00:00
Object . defineProperty ( exports , '__esModule' , { value : true } ) ;
const Endpoints = {
actions : {
addSelectedRepoToOrgSecret : [ "PUT /orgs/{org}/actions/secrets/{secret_name}/repositories/{repository_id}" ] ,
cancelWorkflowRun : [ "POST /repos/{owner}/{repo}/actions/runs/{run_id}/cancel" ] ,
createOrUpdateOrgSecret : [ "PUT /orgs/{org}/actions/secrets/{secret_name}" ] ,
createOrUpdateRepoSecret : [ "PUT /repos/{owner}/{repo}/actions/secrets/{secret_name}" ] ,
createRegistrationTokenForOrg : [ "POST /orgs/{org}/actions/runners/registration-token" ] ,
createRegistrationTokenForRepo : [ "POST /repos/{owner}/{repo}/actions/runners/registration-token" ] ,
createRemoveTokenForOrg : [ "POST /orgs/{org}/actions/runners/remove-token" ] ,
createRemoveTokenForRepo : [ "POST /repos/{owner}/{repo}/actions/runners/remove-token" ] ,
2020-08-19 03:20:28 +00:00
createWorkflowDispatch : [ "POST /repos/{owner}/{repo}/actions/workflows/{workflow_id}/dispatches" ] ,
2020-07-16 08:57:13 +00:00
deleteArtifact : [ "DELETE /repos/{owner}/{repo}/actions/artifacts/{artifact_id}" ] ,
deleteOrgSecret : [ "DELETE /orgs/{org}/actions/secrets/{secret_name}" ] ,
deleteRepoSecret : [ "DELETE /repos/{owner}/{repo}/actions/secrets/{secret_name}" ] ,
deleteSelfHostedRunnerFromOrg : [ "DELETE /orgs/{org}/actions/runners/{runner_id}" ] ,
deleteSelfHostedRunnerFromRepo : [ "DELETE /repos/{owner}/{repo}/actions/runners/{runner_id}" ] ,
2020-08-19 03:20:28 +00:00
deleteWorkflowRun : [ "DELETE /repos/{owner}/{repo}/actions/runs/{run_id}" ] ,
2020-07-16 08:57:13 +00:00
deleteWorkflowRunLogs : [ "DELETE /repos/{owner}/{repo}/actions/runs/{run_id}/logs" ] ,
downloadArtifact : [ "GET /repos/{owner}/{repo}/actions/artifacts/{artifact_id}/{archive_format}" ] ,
downloadJobLogsForWorkflowRun : [ "GET /repos/{owner}/{repo}/actions/jobs/{job_id}/logs" ] ,
downloadWorkflowRunLogs : [ "GET /repos/{owner}/{repo}/actions/runs/{run_id}/logs" ] ,
getArtifact : [ "GET /repos/{owner}/{repo}/actions/artifacts/{artifact_id}" ] ,
getJobForWorkflowRun : [ "GET /repos/{owner}/{repo}/actions/jobs/{job_id}" ] ,
getOrgPublicKey : [ "GET /orgs/{org}/actions/secrets/public-key" ] ,
getOrgSecret : [ "GET /orgs/{org}/actions/secrets/{secret_name}" ] ,
getRepoPublicKey : [ "GET /repos/{owner}/{repo}/actions/secrets/public-key" ] ,
getRepoSecret : [ "GET /repos/{owner}/{repo}/actions/secrets/{secret_name}" ] ,
getSelfHostedRunnerForOrg : [ "GET /orgs/{org}/actions/runners/{runner_id}" ] ,
getSelfHostedRunnerForRepo : [ "GET /repos/{owner}/{repo}/actions/runners/{runner_id}" ] ,
getWorkflow : [ "GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}" ] ,
getWorkflowRun : [ "GET /repos/{owner}/{repo}/actions/runs/{run_id}" ] ,
getWorkflowRunUsage : [ "GET /repos/{owner}/{repo}/actions/runs/{run_id}/timing" ] ,
getWorkflowUsage : [ "GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/timing" ] ,
listArtifactsForRepo : [ "GET /repos/{owner}/{repo}/actions/artifacts" ] ,
listJobsForWorkflowRun : [ "GET /repos/{owner}/{repo}/actions/runs/{run_id}/jobs" ] ,
listOrgSecrets : [ "GET /orgs/{org}/actions/secrets" ] ,
listRepoSecrets : [ "GET /repos/{owner}/{repo}/actions/secrets" ] ,
listRepoWorkflows : [ "GET /repos/{owner}/{repo}/actions/workflows" ] ,
listRunnerApplicationsForOrg : [ "GET /orgs/{org}/actions/runners/downloads" ] ,
listRunnerApplicationsForRepo : [ "GET /repos/{owner}/{repo}/actions/runners/downloads" ] ,
listSelectedReposForOrgSecret : [ "GET /orgs/{org}/actions/secrets/{secret_name}/repositories" ] ,
listSelfHostedRunnersForOrg : [ "GET /orgs/{org}/actions/runners" ] ,
listSelfHostedRunnersForRepo : [ "GET /repos/{owner}/{repo}/actions/runners" ] ,
listWorkflowRunArtifacts : [ "GET /repos/{owner}/{repo}/actions/runs/{run_id}/artifacts" ] ,
listWorkflowRuns : [ "GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/runs" ] ,
listWorkflowRunsForRepo : [ "GET /repos/{owner}/{repo}/actions/runs" ] ,
reRunWorkflow : [ "POST /repos/{owner}/{repo}/actions/runs/{run_id}/rerun" ] ,
removeSelectedRepoFromOrgSecret : [ "DELETE /orgs/{org}/actions/secrets/{secret_name}/repositories/{repository_id}" ] ,
setSelectedReposForOrgSecret : [ "PUT /orgs/{org}/actions/secrets/{secret_name}/repositories" ]
} ,
activity : {
checkRepoIsStarredByAuthenticatedUser : [ "GET /user/starred/{owner}/{repo}" ] ,
deleteRepoSubscription : [ "DELETE /repos/{owner}/{repo}/subscription" ] ,
deleteThreadSubscription : [ "DELETE /notifications/threads/{thread_id}/subscription" ] ,
getFeeds : [ "GET /feeds" ] ,
getRepoSubscription : [ "GET /repos/{owner}/{repo}/subscription" ] ,
getThread : [ "GET /notifications/threads/{thread_id}" ] ,
getThreadSubscriptionForAuthenticatedUser : [ "GET /notifications/threads/{thread_id}/subscription" ] ,
listEventsForAuthenticatedUser : [ "GET /users/{username}/events" ] ,
listNotificationsForAuthenticatedUser : [ "GET /notifications" ] ,
listOrgEventsForAuthenticatedUser : [ "GET /users/{username}/events/orgs/{org}" ] ,
listPublicEvents : [ "GET /events" ] ,
listPublicEventsForRepoNetwork : [ "GET /networks/{owner}/{repo}/events" ] ,
listPublicEventsForUser : [ "GET /users/{username}/events/public" ] ,
listPublicOrgEvents : [ "GET /orgs/{org}/events" ] ,
listReceivedEventsForUser : [ "GET /users/{username}/received_events" ] ,
listReceivedPublicEventsForUser : [ "GET /users/{username}/received_events/public" ] ,
listRepoEvents : [ "GET /repos/{owner}/{repo}/events" ] ,
listRepoNotificationsForAuthenticatedUser : [ "GET /repos/{owner}/{repo}/notifications" ] ,
listReposStarredByAuthenticatedUser : [ "GET /user/starred" ] ,
listReposStarredByUser : [ "GET /users/{username}/starred" ] ,
listReposWatchedByUser : [ "GET /users/{username}/subscriptions" ] ,
listStargazersForRepo : [ "GET /repos/{owner}/{repo}/stargazers" ] ,
listWatchedReposForAuthenticatedUser : [ "GET /user/subscriptions" ] ,
listWatchersForRepo : [ "GET /repos/{owner}/{repo}/subscribers" ] ,
markNotificationsAsRead : [ "PUT /notifications" ] ,
markRepoNotificationsAsRead : [ "PUT /repos/{owner}/{repo}/notifications" ] ,
markThreadAsRead : [ "PATCH /notifications/threads/{thread_id}" ] ,
setRepoSubscription : [ "PUT /repos/{owner}/{repo}/subscription" ] ,
setThreadSubscription : [ "PUT /notifications/threads/{thread_id}/subscription" ] ,
starRepoForAuthenticatedUser : [ "PUT /user/starred/{owner}/{repo}" ] ,
unstarRepoForAuthenticatedUser : [ "DELETE /user/starred/{owner}/{repo}" ]
} ,
apps : {
addRepoToInstallation : [ "PUT /user/installations/{installation_id}/repositories/{repository_id}" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
checkToken : [ "POST /applications/{client_id}/token" ] ,
createContentAttachment : [ "POST /content_references/{content_reference_id}/attachments" , {
mediaType : {
previews : [ "corsair" ]
}
} ] ,
createFromManifest : [ "POST /app-manifests/{code}/conversions" ] ,
createInstallationAccessToken : [ "POST /app/installations/{installation_id}/access_tokens" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
deleteAuthorization : [ "DELETE /applications/{client_id}/grant" ] ,
deleteInstallation : [ "DELETE /app/installations/{installation_id}" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
deleteToken : [ "DELETE /applications/{client_id}/token" ] ,
getAuthenticated : [ "GET /app" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
getBySlug : [ "GET /apps/{app_slug}" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
getInstallation : [ "GET /app/installations/{installation_id}" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
getOrgInstallation : [ "GET /orgs/{org}/installation" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
getRepoInstallation : [ "GET /repos/{owner}/{repo}/installation" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
getSubscriptionPlanForAccount : [ "GET /marketplace_listing/accounts/{account_id}" ] ,
getSubscriptionPlanForAccountStubbed : [ "GET /marketplace_listing/stubbed/accounts/{account_id}" ] ,
getUserInstallation : [ "GET /users/{username}/installation" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
listAccountsForPlan : [ "GET /marketplace_listing/plans/{plan_id}/accounts" ] ,
listAccountsForPlanStubbed : [ "GET /marketplace_listing/stubbed/plans/{plan_id}/accounts" ] ,
listInstallationReposForAuthenticatedUser : [ "GET /user/installations/{installation_id}/repositories" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
listInstallations : [ "GET /app/installations" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
listInstallationsForAuthenticatedUser : [ "GET /user/installations" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
listPlans : [ "GET /marketplace_listing/plans" ] ,
listPlansStubbed : [ "GET /marketplace_listing/stubbed/plans" ] ,
listReposAccessibleToInstallation : [ "GET /installation/repositories" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
listSubscriptionsForAuthenticatedUser : [ "GET /user/marketplace_purchases" ] ,
listSubscriptionsForAuthenticatedUserStubbed : [ "GET /user/marketplace_purchases/stubbed" ] ,
removeRepoFromInstallation : [ "DELETE /user/installations/{installation_id}/repositories/{repository_id}" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
resetToken : [ "PATCH /applications/{client_id}/token" ] ,
revokeInstallationAccessToken : [ "DELETE /installation/token" ] ,
suspendInstallation : [ "PUT /app/installations/{installation_id}/suspended" ] ,
unsuspendInstallation : [ "DELETE /app/installations/{installation_id}/suspended" ]
} ,
2020-08-19 03:20:28 +00:00
billing : {
getGithubActionsBillingOrg : [ "GET /orgs/{org}/settings/billing/actions" ] ,
getGithubActionsBillingUser : [ "GET /users/{username}/settings/billing/actions" ] ,
getGithubPackagesBillingOrg : [ "GET /orgs/{org}/settings/billing/packages" ] ,
getGithubPackagesBillingUser : [ "GET /users/{username}/settings/billing/packages" ] ,
getSharedStorageBillingOrg : [ "GET /orgs/{org}/settings/billing/shared-storage" ] ,
getSharedStorageBillingUser : [ "GET /users/{username}/settings/billing/shared-storage" ]
} ,
2020-07-16 08:57:13 +00:00
checks : {
create : [ "POST /repos/{owner}/{repo}/check-runs" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
createSuite : [ "POST /repos/{owner}/{repo}/check-suites" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
get : [ "GET /repos/{owner}/{repo}/check-runs/{check_run_id}" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
getSuite : [ "GET /repos/{owner}/{repo}/check-suites/{check_suite_id}" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
listAnnotations : [ "GET /repos/{owner}/{repo}/check-runs/{check_run_id}/annotations" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
listForRef : [ "GET /repos/{owner}/{repo}/commits/{ref}/check-runs" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
listForSuite : [ "GET /repos/{owner}/{repo}/check-suites/{check_suite_id}/check-runs" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
listSuitesForRef : [ "GET /repos/{owner}/{repo}/commits/{ref}/check-suites" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
rerequestSuite : [ "POST /repos/{owner}/{repo}/check-suites/{check_suite_id}/rerequest" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
setSuitesPreferences : [ "PATCH /repos/{owner}/{repo}/check-suites/preferences" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
update : [ "PATCH /repos/{owner}/{repo}/check-runs/{check_run_id}" , {
mediaType : {
previews : [ "antiope" ]
}
} ]
} ,
codeScanning : {
getAlert : [ "GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_id}" ] ,
listAlertsForRepo : [ "GET /repos/{owner}/{repo}/code-scanning/alerts" ]
} ,
codesOfConduct : {
getAllCodesOfConduct : [ "GET /codes_of_conduct" , {
mediaType : {
previews : [ "scarlet-witch" ]
}
} ] ,
getConductCode : [ "GET /codes_of_conduct/{key}" , {
mediaType : {
previews : [ "scarlet-witch" ]
}
} ] ,
getForRepo : [ "GET /repos/{owner}/{repo}/community/code_of_conduct" , {
mediaType : {
previews : [ "scarlet-witch" ]
}
} ]
} ,
emojis : {
get : [ "GET /emojis" ]
} ,
gists : {
checkIsStarred : [ "GET /gists/{gist_id}/star" ] ,
create : [ "POST /gists" ] ,
createComment : [ "POST /gists/{gist_id}/comments" ] ,
delete : [ "DELETE /gists/{gist_id}" ] ,
deleteComment : [ "DELETE /gists/{gist_id}/comments/{comment_id}" ] ,
fork : [ "POST /gists/{gist_id}/forks" ] ,
get : [ "GET /gists/{gist_id}" ] ,
getComment : [ "GET /gists/{gist_id}/comments/{comment_id}" ] ,
getRevision : [ "GET /gists/{gist_id}/{sha}" ] ,
list : [ "GET /gists" ] ,
listComments : [ "GET /gists/{gist_id}/comments" ] ,
listCommits : [ "GET /gists/{gist_id}/commits" ] ,
listForUser : [ "GET /users/{username}/gists" ] ,
listForks : [ "GET /gists/{gist_id}/forks" ] ,
listPublic : [ "GET /gists/public" ] ,
listStarred : [ "GET /gists/starred" ] ,
star : [ "PUT /gists/{gist_id}/star" ] ,
unstar : [ "DELETE /gists/{gist_id}/star" ] ,
update : [ "PATCH /gists/{gist_id}" ] ,
updateComment : [ "PATCH /gists/{gist_id}/comments/{comment_id}" ]
} ,
git : {
createBlob : [ "POST /repos/{owner}/{repo}/git/blobs" ] ,
createCommit : [ "POST /repos/{owner}/{repo}/git/commits" ] ,
createRef : [ "POST /repos/{owner}/{repo}/git/refs" ] ,
createTag : [ "POST /repos/{owner}/{repo}/git/tags" ] ,
createTree : [ "POST /repos/{owner}/{repo}/git/trees" ] ,
deleteRef : [ "DELETE /repos/{owner}/{repo}/git/refs/{ref}" ] ,
getBlob : [ "GET /repos/{owner}/{repo}/git/blobs/{file_sha}" ] ,
getCommit : [ "GET /repos/{owner}/{repo}/git/commits/{commit_sha}" ] ,
getRef : [ "GET /repos/{owner}/{repo}/git/ref/{ref}" ] ,
getTag : [ "GET /repos/{owner}/{repo}/git/tags/{tag_sha}" ] ,
getTree : [ "GET /repos/{owner}/{repo}/git/trees/{tree_sha}" ] ,
listMatchingRefs : [ "GET /repos/{owner}/{repo}/git/matching-refs/{ref}" ] ,
updateRef : [ "PATCH /repos/{owner}/{repo}/git/refs/{ref}" ]
} ,
gitignore : {
getAllTemplates : [ "GET /gitignore/templates" ] ,
getTemplate : [ "GET /gitignore/templates/{name}" ]
} ,
interactions : {
getRestrictionsForOrg : [ "GET /orgs/{org}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} ] ,
getRestrictionsForRepo : [ "GET /repos/{owner}/{repo}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} ] ,
removeRestrictionsForOrg : [ "DELETE /orgs/{org}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} ] ,
removeRestrictionsForRepo : [ "DELETE /repos/{owner}/{repo}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} ] ,
setRestrictionsForOrg : [ "PUT /orgs/{org}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} ] ,
setRestrictionsForRepo : [ "PUT /repos/{owner}/{repo}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} ]
} ,
issues : {
addAssignees : [ "POST /repos/{owner}/{repo}/issues/{issue_number}/assignees" ] ,
addLabels : [ "POST /repos/{owner}/{repo}/issues/{issue_number}/labels" ] ,
checkUserCanBeAssigned : [ "GET /repos/{owner}/{repo}/assignees/{assignee}" ] ,
create : [ "POST /repos/{owner}/{repo}/issues" ] ,
createComment : [ "POST /repos/{owner}/{repo}/issues/{issue_number}/comments" ] ,
createLabel : [ "POST /repos/{owner}/{repo}/labels" ] ,
createMilestone : [ "POST /repos/{owner}/{repo}/milestones" ] ,
deleteComment : [ "DELETE /repos/{owner}/{repo}/issues/comments/{comment_id}" ] ,
deleteLabel : [ "DELETE /repos/{owner}/{repo}/labels/{name}" ] ,
deleteMilestone : [ "DELETE /repos/{owner}/{repo}/milestones/{milestone_number}" ] ,
get : [ "GET /repos/{owner}/{repo}/issues/{issue_number}" ] ,
getComment : [ "GET /repos/{owner}/{repo}/issues/comments/{comment_id}" ] ,
getEvent : [ "GET /repos/{owner}/{repo}/issues/events/{event_id}" ] ,
getLabel : [ "GET /repos/{owner}/{repo}/labels/{name}" ] ,
getMilestone : [ "GET /repos/{owner}/{repo}/milestones/{milestone_number}" ] ,
list : [ "GET /issues" ] ,
listAssignees : [ "GET /repos/{owner}/{repo}/assignees" ] ,
listComments : [ "GET /repos/{owner}/{repo}/issues/{issue_number}/comments" ] ,
listCommentsForRepo : [ "GET /repos/{owner}/{repo}/issues/comments" ] ,
listEvents : [ "GET /repos/{owner}/{repo}/issues/{issue_number}/events" ] ,
listEventsForRepo : [ "GET /repos/{owner}/{repo}/issues/events" ] ,
listEventsForTimeline : [ "GET /repos/{owner}/{repo}/issues/{issue_number}/timeline" , {
mediaType : {
previews : [ "mockingbird" ]
}
} ] ,
listForAuthenticatedUser : [ "GET /user/issues" ] ,
listForOrg : [ "GET /orgs/{org}/issues" ] ,
listForRepo : [ "GET /repos/{owner}/{repo}/issues" ] ,
listLabelsForMilestone : [ "GET /repos/{owner}/{repo}/milestones/{milestone_number}/labels" ] ,
listLabelsForRepo : [ "GET /repos/{owner}/{repo}/labels" ] ,
listLabelsOnIssue : [ "GET /repos/{owner}/{repo}/issues/{issue_number}/labels" ] ,
listMilestones : [ "GET /repos/{owner}/{repo}/milestones" ] ,
lock : [ "PUT /repos/{owner}/{repo}/issues/{issue_number}/lock" ] ,
removeAllLabels : [ "DELETE /repos/{owner}/{repo}/issues/{issue_number}/labels" ] ,
removeAssignees : [ "DELETE /repos/{owner}/{repo}/issues/{issue_number}/assignees" ] ,
removeLabel : [ "DELETE /repos/{owner}/{repo}/issues/{issue_number}/labels/{name}" ] ,
setLabels : [ "PUT /repos/{owner}/{repo}/issues/{issue_number}/labels" ] ,
unlock : [ "DELETE /repos/{owner}/{repo}/issues/{issue_number}/lock" ] ,
update : [ "PATCH /repos/{owner}/{repo}/issues/{issue_number}" ] ,
updateComment : [ "PATCH /repos/{owner}/{repo}/issues/comments/{comment_id}" ] ,
updateLabel : [ "PATCH /repos/{owner}/{repo}/labels/{name}" ] ,
updateMilestone : [ "PATCH /repos/{owner}/{repo}/milestones/{milestone_number}" ]
} ,
licenses : {
get : [ "GET /licenses/{license}" ] ,
getAllCommonlyUsed : [ "GET /licenses" ] ,
getForRepo : [ "GET /repos/{owner}/{repo}/license" ]
} ,
markdown : {
render : [ "POST /markdown" ] ,
renderRaw : [ "POST /markdown/raw" , {
headers : {
"content-type" : "text/plain; charset=utf-8"
}
} ]
} ,
meta : {
get : [ "GET /meta" ]
} ,
migrations : {
cancelImport : [ "DELETE /repos/{owner}/{repo}/import" ] ,
deleteArchiveForAuthenticatedUser : [ "DELETE /user/migrations/{migration_id}/archive" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
deleteArchiveForOrg : [ "DELETE /orgs/{org}/migrations/{migration_id}/archive" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
downloadArchiveForOrg : [ "GET /orgs/{org}/migrations/{migration_id}/archive" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
getArchiveForAuthenticatedUser : [ "GET /user/migrations/{migration_id}/archive" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
getCommitAuthors : [ "GET /repos/{owner}/{repo}/import/authors" ] ,
getImportStatus : [ "GET /repos/{owner}/{repo}/import" ] ,
getLargeFiles : [ "GET /repos/{owner}/{repo}/import/large_files" ] ,
getStatusForAuthenticatedUser : [ "GET /user/migrations/{migration_id}" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
getStatusForOrg : [ "GET /orgs/{org}/migrations/{migration_id}" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
listForAuthenticatedUser : [ "GET /user/migrations" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
listForOrg : [ "GET /orgs/{org}/migrations" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
listReposForOrg : [ "GET /orgs/{org}/migrations/{migration_id}/repositories" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
2020-08-19 03:20:28 +00:00
listReposForUser : [ "GET /user/migrations/{migration_id}/repositories" , {
2020-07-16 08:57:13 +00:00
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
mapCommitAuthor : [ "PATCH /repos/{owner}/{repo}/import/authors/{author_id}" ] ,
setLfsPreference : [ "PATCH /repos/{owner}/{repo}/import/lfs" ] ,
startForAuthenticatedUser : [ "POST /user/migrations" ] ,
startForOrg : [ "POST /orgs/{org}/migrations" ] ,
startImport : [ "PUT /repos/{owner}/{repo}/import" ] ,
unlockRepoForAuthenticatedUser : [ "DELETE /user/migrations/{migration_id}/repos/{repo_name}/lock" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
unlockRepoForOrg : [ "DELETE /orgs/{org}/migrations/{migration_id}/repos/{repo_name}/lock" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
updateImport : [ "PATCH /repos/{owner}/{repo}/import" ]
} ,
orgs : {
blockUser : [ "PUT /orgs/{org}/blocks/{username}" ] ,
checkBlockedUser : [ "GET /orgs/{org}/blocks/{username}" ] ,
checkMembershipForUser : [ "GET /orgs/{org}/members/{username}" ] ,
checkPublicMembershipForUser : [ "GET /orgs/{org}/public_members/{username}" ] ,
convertMemberToOutsideCollaborator : [ "PUT /orgs/{org}/outside_collaborators/{username}" ] ,
createInvitation : [ "POST /orgs/{org}/invitations" ] ,
createWebhook : [ "POST /orgs/{org}/hooks" ] ,
deleteWebhook : [ "DELETE /orgs/{org}/hooks/{hook_id}" ] ,
get : [ "GET /orgs/{org}" ] ,
getMembershipForAuthenticatedUser : [ "GET /user/memberships/orgs/{org}" ] ,
getMembershipForUser : [ "GET /orgs/{org}/memberships/{username}" ] ,
getWebhook : [ "GET /orgs/{org}/hooks/{hook_id}" ] ,
list : [ "GET /organizations" ] ,
listAppInstallations : [ "GET /orgs/{org}/installations" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
listBlockedUsers : [ "GET /orgs/{org}/blocks" ] ,
listForAuthenticatedUser : [ "GET /user/orgs" ] ,
listForUser : [ "GET /users/{username}/orgs" ] ,
listInvitationTeams : [ "GET /orgs/{org}/invitations/{invitation_id}/teams" ] ,
listMembers : [ "GET /orgs/{org}/members" ] ,
listMembershipsForAuthenticatedUser : [ "GET /user/memberships/orgs" ] ,
listOutsideCollaborators : [ "GET /orgs/{org}/outside_collaborators" ] ,
listPendingInvitations : [ "GET /orgs/{org}/invitations" ] ,
listPublicMembers : [ "GET /orgs/{org}/public_members" ] ,
listWebhooks : [ "GET /orgs/{org}/hooks" ] ,
pingWebhook : [ "POST /orgs/{org}/hooks/{hook_id}/pings" ] ,
removeMember : [ "DELETE /orgs/{org}/members/{username}" ] ,
removeMembershipForUser : [ "DELETE /orgs/{org}/memberships/{username}" ] ,
removeOutsideCollaborator : [ "DELETE /orgs/{org}/outside_collaborators/{username}" ] ,
removePublicMembershipForAuthenticatedUser : [ "DELETE /orgs/{org}/public_members/{username}" ] ,
setMembershipForUser : [ "PUT /orgs/{org}/memberships/{username}" ] ,
setPublicMembershipForAuthenticatedUser : [ "PUT /orgs/{org}/public_members/{username}" ] ,
unblockUser : [ "DELETE /orgs/{org}/blocks/{username}" ] ,
update : [ "PATCH /orgs/{org}" ] ,
updateMembershipForAuthenticatedUser : [ "PATCH /user/memberships/orgs/{org}" ] ,
updateWebhook : [ "PATCH /orgs/{org}/hooks/{hook_id}" ]
} ,
projects : {
addCollaborator : [ "PUT /projects/{project_id}/collaborators/{username}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
createCard : [ "POST /projects/columns/{column_id}/cards" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
createColumn : [ "POST /projects/{project_id}/columns" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
createForAuthenticatedUser : [ "POST /user/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
createForOrg : [ "POST /orgs/{org}/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
createForRepo : [ "POST /repos/{owner}/{repo}/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
delete : [ "DELETE /projects/{project_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
deleteCard : [ "DELETE /projects/columns/cards/{card_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
deleteColumn : [ "DELETE /projects/columns/{column_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
get : [ "GET /projects/{project_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
getCard : [ "GET /projects/columns/cards/{card_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
getColumn : [ "GET /projects/columns/{column_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
getPermissionForUser : [ "GET /projects/{project_id}/collaborators/{username}/permission" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listCards : [ "GET /projects/columns/{column_id}/cards" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listCollaborators : [ "GET /projects/{project_id}/collaborators" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listColumns : [ "GET /projects/{project_id}/columns" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listForOrg : [ "GET /orgs/{org}/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listForRepo : [ "GET /repos/{owner}/{repo}/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listForUser : [ "GET /users/{username}/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
moveCard : [ "POST /projects/columns/cards/{card_id}/moves" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
moveColumn : [ "POST /projects/columns/{column_id}/moves" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
removeCollaborator : [ "DELETE /projects/{project_id}/collaborators/{username}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
update : [ "PATCH /projects/{project_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
updateCard : [ "PATCH /projects/columns/cards/{card_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
updateColumn : [ "PATCH /projects/columns/{column_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ]
} ,
pulls : {
checkIfMerged : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/merge" ] ,
create : [ "POST /repos/{owner}/{repo}/pulls" ] ,
createReplyForReviewComment : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/comments/{comment_id}/replies" ] ,
createReview : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/reviews" ] ,
createReviewComment : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/comments" ] ,
deletePendingReview : [ "DELETE /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}" ] ,
deleteReviewComment : [ "DELETE /repos/{owner}/{repo}/pulls/comments/{comment_id}" ] ,
dismissReview : [ "PUT /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/dismissals" ] ,
get : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}" ] ,
getReview : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}" ] ,
getReviewComment : [ "GET /repos/{owner}/{repo}/pulls/comments/{comment_id}" ] ,
list : [ "GET /repos/{owner}/{repo}/pulls" ] ,
listCommentsForReview : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/comments" ] ,
listCommits : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/commits" ] ,
listFiles : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/files" ] ,
listRequestedReviewers : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers" ] ,
listReviewComments : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/comments" ] ,
listReviewCommentsForRepo : [ "GET /repos/{owner}/{repo}/pulls/comments" ] ,
listReviews : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews" ] ,
merge : [ "PUT /repos/{owner}/{repo}/pulls/{pull_number}/merge" ] ,
removeRequestedReviewers : [ "DELETE /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers" ] ,
requestReviewers : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers" ] ,
submitReview : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/events" ] ,
update : [ "PATCH /repos/{owner}/{repo}/pulls/{pull_number}" ] ,
updateBranch : [ "PUT /repos/{owner}/{repo}/pulls/{pull_number}/update-branch" , {
mediaType : {
previews : [ "lydian" ]
}
} ] ,
updateReview : [ "PUT /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}" ] ,
updateReviewComment : [ "PATCH /repos/{owner}/{repo}/pulls/comments/{comment_id}" ]
} ,
rateLimit : {
get : [ "GET /rate_limit" ]
} ,
reactions : {
createForCommitComment : [ "POST /repos/{owner}/{repo}/comments/{comment_id}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
createForIssue : [ "POST /repos/{owner}/{repo}/issues/{issue_number}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
createForIssueComment : [ "POST /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
createForPullRequestReviewComment : [ "POST /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
createForTeamDiscussionCommentInOrg : [ "POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
createForTeamDiscussionInOrg : [ "POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
deleteForCommitComment : [ "DELETE /repos/{owner}/{repo}/comments/{comment_id}/reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
deleteForIssue : [ "DELETE /repos/{owner}/{repo}/issues/{issue_number}/reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
deleteForIssueComment : [ "DELETE /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
deleteForPullRequestComment : [ "DELETE /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
deleteForTeamDiscussion : [ "DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
deleteForTeamDiscussionComment : [ "DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
2020-08-19 03:20:28 +00:00
deleteLegacy : [ "DELETE /reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} , {
deprecated : "octokit.reactions.deleteLegacy() is deprecated, see https://developer.github.com/v3/reactions/#delete-a-reaction-legacy"
} ] ,
2020-07-16 08:57:13 +00:00
listForCommitComment : [ "GET /repos/{owner}/{repo}/comments/{comment_id}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
listForIssue : [ "GET /repos/{owner}/{repo}/issues/{issue_number}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
listForIssueComment : [ "GET /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
listForPullRequestReviewComment : [ "GET /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
listForTeamDiscussionCommentInOrg : [ "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
listForTeamDiscussionInOrg : [ "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ]
} ,
repos : {
acceptInvitation : [ "PATCH /user/repository_invitations/{invitation_id}" ] ,
addAppAccessRestrictions : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps" , { } , {
mapToData : "apps"
} ] ,
addCollaborator : [ "PUT /repos/{owner}/{repo}/collaborators/{username}" ] ,
addStatusCheckContexts : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts" , { } , {
mapToData : "contexts"
} ] ,
addTeamAccessRestrictions : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams" , { } , {
mapToData : "teams"
} ] ,
addUserAccessRestrictions : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users" , { } , {
mapToData : "users"
} ] ,
checkCollaborator : [ "GET /repos/{owner}/{repo}/collaborators/{username}" ] ,
checkVulnerabilityAlerts : [ "GET /repos/{owner}/{repo}/vulnerability-alerts" , {
mediaType : {
previews : [ "dorian" ]
}
} ] ,
compareCommits : [ "GET /repos/{owner}/{repo}/compare/{base}...{head}" ] ,
createCommitComment : [ "POST /repos/{owner}/{repo}/commits/{commit_sha}/comments" ] ,
createCommitSignatureProtection : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures" , {
mediaType : {
previews : [ "zzzax" ]
}
} ] ,
createCommitStatus : [ "POST /repos/{owner}/{repo}/statuses/{sha}" ] ,
createDeployKey : [ "POST /repos/{owner}/{repo}/keys" ] ,
createDeployment : [ "POST /repos/{owner}/{repo}/deployments" ] ,
createDeploymentStatus : [ "POST /repos/{owner}/{repo}/deployments/{deployment_id}/statuses" ] ,
createDispatchEvent : [ "POST /repos/{owner}/{repo}/dispatches" ] ,
createForAuthenticatedUser : [ "POST /user/repos" ] ,
createFork : [ "POST /repos/{owner}/{repo}/forks" ] ,
createInOrg : [ "POST /orgs/{org}/repos" ] ,
createOrUpdateFileContents : [ "PUT /repos/{owner}/{repo}/contents/{path}" ] ,
createPagesSite : [ "POST /repos/{owner}/{repo}/pages" , {
mediaType : {
previews : [ "switcheroo" ]
}
} ] ,
createRelease : [ "POST /repos/{owner}/{repo}/releases" ] ,
createUsingTemplate : [ "POST /repos/{template_owner}/{template_repo}/generate" , {
mediaType : {
previews : [ "baptiste" ]
}
} ] ,
createWebhook : [ "POST /repos/{owner}/{repo}/hooks" ] ,
declineInvitation : [ "DELETE /user/repository_invitations/{invitation_id}" ] ,
delete : [ "DELETE /repos/{owner}/{repo}" ] ,
deleteAccessRestrictions : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions" ] ,
deleteAdminBranchProtection : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins" ] ,
deleteBranchProtection : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection" ] ,
deleteCommitComment : [ "DELETE /repos/{owner}/{repo}/comments/{comment_id}" ] ,
deleteCommitSignatureProtection : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures" , {
mediaType : {
previews : [ "zzzax" ]
}
} ] ,
deleteDeployKey : [ "DELETE /repos/{owner}/{repo}/keys/{key_id}" ] ,
deleteDeployment : [ "DELETE /repos/{owner}/{repo}/deployments/{deployment_id}" ] ,
deleteFile : [ "DELETE /repos/{owner}/{repo}/contents/{path}" ] ,
deleteInvitation : [ "DELETE /repos/{owner}/{repo}/invitations/{invitation_id}" ] ,
deletePagesSite : [ "DELETE /repos/{owner}/{repo}/pages" , {
mediaType : {
previews : [ "switcheroo" ]
}
} ] ,
deletePullRequestReviewProtection : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews" ] ,
deleteRelease : [ "DELETE /repos/{owner}/{repo}/releases/{release_id}" ] ,
deleteReleaseAsset : [ "DELETE /repos/{owner}/{repo}/releases/assets/{asset_id}" ] ,
deleteWebhook : [ "DELETE /repos/{owner}/{repo}/hooks/{hook_id}" ] ,
disableAutomatedSecurityFixes : [ "DELETE /repos/{owner}/{repo}/automated-security-fixes" , {
mediaType : {
previews : [ "london" ]
}
} ] ,
disableVulnerabilityAlerts : [ "DELETE /repos/{owner}/{repo}/vulnerability-alerts" , {
mediaType : {
previews : [ "dorian" ]
}
} ] ,
downloadArchive : [ "GET /repos/{owner}/{repo}/{archive_format}/{ref}" ] ,
enableAutomatedSecurityFixes : [ "PUT /repos/{owner}/{repo}/automated-security-fixes" , {
mediaType : {
previews : [ "london" ]
}
} ] ,
enableVulnerabilityAlerts : [ "PUT /repos/{owner}/{repo}/vulnerability-alerts" , {
mediaType : {
previews : [ "dorian" ]
}
} ] ,
get : [ "GET /repos/{owner}/{repo}" ] ,
getAccessRestrictions : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions" ] ,
getAdminBranchProtection : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins" ] ,
getAllStatusCheckContexts : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts" ] ,
getAllTopics : [ "GET /repos/{owner}/{repo}/topics" , {
mediaType : {
previews : [ "mercy" ]
}
} ] ,
getAppsWithAccessToProtectedBranch : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps" ] ,
getBranch : [ "GET /repos/{owner}/{repo}/branches/{branch}" ] ,
getBranchProtection : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection" ] ,
getClones : [ "GET /repos/{owner}/{repo}/traffic/clones" ] ,
getCodeFrequencyStats : [ "GET /repos/{owner}/{repo}/stats/code_frequency" ] ,
getCollaboratorPermissionLevel : [ "GET /repos/{owner}/{repo}/collaborators/{username}/permission" ] ,
getCombinedStatusForRef : [ "GET /repos/{owner}/{repo}/commits/{ref}/status" ] ,
getCommit : [ "GET /repos/{owner}/{repo}/commits/{ref}" ] ,
getCommitActivityStats : [ "GET /repos/{owner}/{repo}/stats/commit_activity" ] ,
getCommitComment : [ "GET /repos/{owner}/{repo}/comments/{comment_id}" ] ,
getCommitSignatureProtection : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures" , {
mediaType : {
previews : [ "zzzax" ]
}
} ] ,
2020-08-19 03:20:28 +00:00
getCommunityProfileMetrics : [ "GET /repos/{owner}/{repo}/community/profile" , {
mediaType : {
previews : [ "black-panther" ]
}
} ] ,
2020-07-16 08:57:13 +00:00
getContent : [ "GET /repos/{owner}/{repo}/contents/{path}" ] ,
getContributorsStats : [ "GET /repos/{owner}/{repo}/stats/contributors" ] ,
getDeployKey : [ "GET /repos/{owner}/{repo}/keys/{key_id}" ] ,
getDeployment : [ "GET /repos/{owner}/{repo}/deployments/{deployment_id}" ] ,
getDeploymentStatus : [ "GET /repos/{owner}/{repo}/deployments/{deployment_id}/statuses/{status_id}" ] ,
getLatestPagesBuild : [ "GET /repos/{owner}/{repo}/pages/builds/latest" ] ,
getLatestRelease : [ "GET /repos/{owner}/{repo}/releases/latest" ] ,
getPages : [ "GET /repos/{owner}/{repo}/pages" ] ,
getPagesBuild : [ "GET /repos/{owner}/{repo}/pages/builds/{build_id}" ] ,
getParticipationStats : [ "GET /repos/{owner}/{repo}/stats/participation" ] ,
getPullRequestReviewProtection : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews" ] ,
getPunchCardStats : [ "GET /repos/{owner}/{repo}/stats/punch_card" ] ,
getReadme : [ "GET /repos/{owner}/{repo}/readme" ] ,
getRelease : [ "GET /repos/{owner}/{repo}/releases/{release_id}" ] ,
getReleaseAsset : [ "GET /repos/{owner}/{repo}/releases/assets/{asset_id}" ] ,
getReleaseByTag : [ "GET /repos/{owner}/{repo}/releases/tags/{tag}" ] ,
getStatusChecksProtection : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks" ] ,
getTeamsWithAccessToProtectedBranch : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams" ] ,
getTopPaths : [ "GET /repos/{owner}/{repo}/traffic/popular/paths" ] ,
getTopReferrers : [ "GET /repos/{owner}/{repo}/traffic/popular/referrers" ] ,
getUsersWithAccessToProtectedBranch : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users" ] ,
getViews : [ "GET /repos/{owner}/{repo}/traffic/views" ] ,
getWebhook : [ "GET /repos/{owner}/{repo}/hooks/{hook_id}" ] ,
listBranches : [ "GET /repos/{owner}/{repo}/branches" ] ,
listBranchesForHeadCommit : [ "GET /repos/{owner}/{repo}/commits/{commit_sha}/branches-where-head" , {
mediaType : {
previews : [ "groot" ]
}
} ] ,
listCollaborators : [ "GET /repos/{owner}/{repo}/collaborators" ] ,
listCommentsForCommit : [ "GET /repos/{owner}/{repo}/commits/{commit_sha}/comments" ] ,
listCommitCommentsForRepo : [ "GET /repos/{owner}/{repo}/comments" ] ,
listCommitStatusesForRef : [ "GET /repos/{owner}/{repo}/commits/{ref}/statuses" ] ,
listCommits : [ "GET /repos/{owner}/{repo}/commits" ] ,
listContributors : [ "GET /repos/{owner}/{repo}/contributors" ] ,
listDeployKeys : [ "GET /repos/{owner}/{repo}/keys" ] ,
listDeploymentStatuses : [ "GET /repos/{owner}/{repo}/deployments/{deployment_id}/statuses" ] ,
listDeployments : [ "GET /repos/{owner}/{repo}/deployments" ] ,
listForAuthenticatedUser : [ "GET /user/repos" ] ,
listForOrg : [ "GET /orgs/{org}/repos" ] ,
listForUser : [ "GET /users/{username}/repos" ] ,
listForks : [ "GET /repos/{owner}/{repo}/forks" ] ,
listInvitations : [ "GET /repos/{owner}/{repo}/invitations" ] ,
listInvitationsForAuthenticatedUser : [ "GET /user/repository_invitations" ] ,
listLanguages : [ "GET /repos/{owner}/{repo}/languages" ] ,
listPagesBuilds : [ "GET /repos/{owner}/{repo}/pages/builds" ] ,
listPublic : [ "GET /repositories" ] ,
listPullRequestsAssociatedWithCommit : [ "GET /repos/{owner}/{repo}/commits/{commit_sha}/pulls" , {
mediaType : {
previews : [ "groot" ]
}
} ] ,
listReleaseAssets : [ "GET /repos/{owner}/{repo}/releases/{release_id}/assets" ] ,
listReleases : [ "GET /repos/{owner}/{repo}/releases" ] ,
listTags : [ "GET /repos/{owner}/{repo}/tags" ] ,
listTeams : [ "GET /repos/{owner}/{repo}/teams" ] ,
listWebhooks : [ "GET /repos/{owner}/{repo}/hooks" ] ,
merge : [ "POST /repos/{owner}/{repo}/merges" ] ,
pingWebhook : [ "POST /repos/{owner}/{repo}/hooks/{hook_id}/pings" ] ,
removeAppAccessRestrictions : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps" , { } , {
mapToData : "apps"
} ] ,
removeCollaborator : [ "DELETE /repos/{owner}/{repo}/collaborators/{username}" ] ,
removeStatusCheckContexts : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts" , { } , {
mapToData : "contexts"
} ] ,
removeStatusCheckProtection : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks" ] ,
removeTeamAccessRestrictions : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams" , { } , {
mapToData : "teams"
} ] ,
removeUserAccessRestrictions : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users" , { } , {
mapToData : "users"
} ] ,
replaceAllTopics : [ "PUT /repos/{owner}/{repo}/topics" , {
mediaType : {
previews : [ "mercy" ]
}
} ] ,
requestPagesBuild : [ "POST /repos/{owner}/{repo}/pages/builds" ] ,
setAdminBranchProtection : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins" ] ,
setAppAccessRestrictions : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps" , { } , {
mapToData : "apps"
} ] ,
setStatusCheckContexts : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts" , { } , {
mapToData : "contexts"
} ] ,
setTeamAccessRestrictions : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams" , { } , {
mapToData : "teams"
} ] ,
setUserAccessRestrictions : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users" , { } , {
mapToData : "users"
} ] ,
testPushWebhook : [ "POST /repos/{owner}/{repo}/hooks/{hook_id}/tests" ] ,
transfer : [ "POST /repos/{owner}/{repo}/transfer" ] ,
update : [ "PATCH /repos/{owner}/{repo}" ] ,
updateBranchProtection : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection" ] ,
updateCommitComment : [ "PATCH /repos/{owner}/{repo}/comments/{comment_id}" ] ,
updateInformationAboutPagesSite : [ "PUT /repos/{owner}/{repo}/pages" ] ,
updateInvitation : [ "PATCH /repos/{owner}/{repo}/invitations/{invitation_id}" ] ,
updatePullRequestReviewProtection : [ "PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews" ] ,
updateRelease : [ "PATCH /repos/{owner}/{repo}/releases/{release_id}" ] ,
updateReleaseAsset : [ "PATCH /repos/{owner}/{repo}/releases/assets/{asset_id}" ] ,
updateStatusCheckPotection : [ "PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks" ] ,
updateWebhook : [ "PATCH /repos/{owner}/{repo}/hooks/{hook_id}" ] ,
uploadReleaseAsset : [ "POST /repos/{owner}/{repo}/releases/{release_id}/assets{?name,label}" , {
baseUrl : "https://uploads.github.com"
} ]
} ,
search : {
code : [ "GET /search/code" ] ,
commits : [ "GET /search/commits" , {
mediaType : {
previews : [ "cloak" ]
}
} ] ,
issuesAndPullRequests : [ "GET /search/issues" ] ,
labels : [ "GET /search/labels" ] ,
repos : [ "GET /search/repositories" ] ,
2020-08-19 03:20:28 +00:00
topics : [ "GET /search/topics" , {
mediaType : {
previews : [ "mercy" ]
}
} ] ,
2020-07-16 08:57:13 +00:00
users : [ "GET /search/users" ]
} ,
teams : {
addOrUpdateMembershipForUserInOrg : [ "PUT /orgs/{org}/teams/{team_slug}/memberships/{username}" ] ,
addOrUpdateProjectPermissionsInOrg : [ "PUT /orgs/{org}/teams/{team_slug}/projects/{project_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
addOrUpdateRepoPermissionsInOrg : [ "PUT /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}" ] ,
checkPermissionsForProjectInOrg : [ "GET /orgs/{org}/teams/{team_slug}/projects/{project_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
checkPermissionsForRepoInOrg : [ "GET /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}" ] ,
create : [ "POST /orgs/{org}/teams" ] ,
createDiscussionCommentInOrg : [ "POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments" ] ,
createDiscussionInOrg : [ "POST /orgs/{org}/teams/{team_slug}/discussions" ] ,
deleteDiscussionCommentInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}" ] ,
deleteDiscussionInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}" ] ,
deleteInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}" ] ,
getByName : [ "GET /orgs/{org}/teams/{team_slug}" ] ,
getDiscussionCommentInOrg : [ "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}" ] ,
getDiscussionInOrg : [ "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}" ] ,
getMembershipForUserInOrg : [ "GET /orgs/{org}/teams/{team_slug}/memberships/{username}" ] ,
list : [ "GET /orgs/{org}/teams" ] ,
listChildInOrg : [ "GET /orgs/{org}/teams/{team_slug}/teams" ] ,
listDiscussionCommentsInOrg : [ "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments" ] ,
listDiscussionsInOrg : [ "GET /orgs/{org}/teams/{team_slug}/discussions" ] ,
listForAuthenticatedUser : [ "GET /user/teams" ] ,
listMembersInOrg : [ "GET /orgs/{org}/teams/{team_slug}/members" ] ,
listPendingInvitationsInOrg : [ "GET /orgs/{org}/teams/{team_slug}/invitations" ] ,
listProjectsInOrg : [ "GET /orgs/{org}/teams/{team_slug}/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listReposInOrg : [ "GET /orgs/{org}/teams/{team_slug}/repos" ] ,
removeMembershipForUserInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}/memberships/{username}" ] ,
removeProjectInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}/projects/{project_id}" ] ,
removeRepoInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}" ] ,
updateDiscussionCommentInOrg : [ "PATCH /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}" ] ,
updateDiscussionInOrg : [ "PATCH /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}" ] ,
updateInOrg : [ "PATCH /orgs/{org}/teams/{team_slug}" ]
} ,
users : {
addEmailForAuthenticated : [ "POST /user/emails" ] ,
block : [ "PUT /user/blocks/{username}" ] ,
checkBlocked : [ "GET /user/blocks/{username}" ] ,
checkFollowingForUser : [ "GET /users/{username}/following/{target_user}" ] ,
checkPersonIsFollowedByAuthenticated : [ "GET /user/following/{username}" ] ,
createGpgKeyForAuthenticated : [ "POST /user/gpg_keys" ] ,
createPublicSshKeyForAuthenticated : [ "POST /user/keys" ] ,
deleteEmailForAuthenticated : [ "DELETE /user/emails" ] ,
deleteGpgKeyForAuthenticated : [ "DELETE /user/gpg_keys/{gpg_key_id}" ] ,
deletePublicSshKeyForAuthenticated : [ "DELETE /user/keys/{key_id}" ] ,
follow : [ "PUT /user/following/{username}" ] ,
getAuthenticated : [ "GET /user" ] ,
getByUsername : [ "GET /users/{username}" ] ,
getContextForUser : [ "GET /users/{username}/hovercard" ] ,
getGpgKeyForAuthenticated : [ "GET /user/gpg_keys/{gpg_key_id}" ] ,
getPublicSshKeyForAuthenticated : [ "GET /user/keys/{key_id}" ] ,
list : [ "GET /users" ] ,
listBlockedByAuthenticated : [ "GET /user/blocks" ] ,
listEmailsForAuthenticated : [ "GET /user/emails" ] ,
listFollowedByAuthenticated : [ "GET /user/following" ] ,
listFollowersForAuthenticatedUser : [ "GET /user/followers" ] ,
listFollowersForUser : [ "GET /users/{username}/followers" ] ,
listFollowingForUser : [ "GET /users/{username}/following" ] ,
listGpgKeysForAuthenticated : [ "GET /user/gpg_keys" ] ,
listGpgKeysForUser : [ "GET /users/{username}/gpg_keys" ] ,
listPublicEmailsForAuthenticated : [ "GET /user/public_emails" ] ,
listPublicKeysForUser : [ "GET /users/{username}/keys" ] ,
listPublicSshKeysForAuthenticated : [ "GET /user/keys" ] ,
setPrimaryEmailVisibilityForAuthenticated : [ "PATCH /user/email/visibility" ] ,
unblock : [ "DELETE /user/blocks/{username}" ] ,
unfollow : [ "DELETE /user/following/{username}" ] ,
updateAuthenticated : [ "PATCH /user" ]
}
} ;
2020-08-19 03:20:28 +00:00
const VERSION = "4.1.2" ;
2020-07-16 08:57:13 +00:00
function endpointsToMethods ( octokit , endpointsMap ) {
const newMethods = { } ;
for ( const [ scope , endpoints ] of Object . entries ( endpointsMap ) ) {
for ( const [ methodName , endpoint ] of Object . entries ( endpoints ) ) {
const [ route , defaults , decorations ] = endpoint ;
const [ method , url ] = route . split ( / / ) ;
const endpointDefaults = Object . assign ( {
method ,
url
} , defaults ) ;
if ( ! newMethods [ scope ] ) {
newMethods [ scope ] = { } ;
}
const scopeMethods = newMethods [ scope ] ;
if ( decorations ) {
scopeMethods [ methodName ] = decorate ( octokit , scope , methodName , endpointDefaults , decorations ) ;
continue ;
}
scopeMethods [ methodName ] = octokit . request . defaults ( endpointDefaults ) ;
2020-01-03 03:32:22 +00:00
}
2020-07-16 08:57:13 +00:00
}
return newMethods ;
2020-05-02 11:27:54 +00:00
}
2020-01-03 03:32:22 +00:00
2020-07-16 08:57:13 +00:00
function decorate ( octokit , scope , methodName , defaults , decorations ) {
const requestWithDefaults = octokit . request . defaults ( defaults ) ;
/* istanbul ignore next */
2020-01-03 03:32:22 +00:00
2020-07-16 08:57:13 +00:00
function withDecorations ( ... args ) {
// @ts-ignore https://github.com/microsoft/TypeScript/issues/25488
let options = requestWithDefaults . endpoint . merge ( ... args ) ; // There are currently no other decorations than `.mapToData`
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
if ( decorations . mapToData ) {
options = Object . assign ( { } , options , {
data : options [ decorations . mapToData ] ,
[ decorations . mapToData ] : undefined
} ) ;
return requestWithDefaults ( options ) ;
}
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
if ( decorations . renamed ) {
const [ newScope , newMethodName ] = decorations . renamed ;
octokit . log . warn ( ` octokit. ${ scope } . ${ methodName } () has been renamed to octokit. ${ newScope } . ${ newMethodName } () ` ) ;
}
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
if ( decorations . deprecated ) {
octokit . log . warn ( decorations . deprecated ) ;
}
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
if ( decorations . renamedParameters ) {
// @ts-ignore https://github.com/microsoft/TypeScript/issues/25488
const options = requestWithDefaults . endpoint . merge ( ... args ) ;
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
for ( const [ name , alias ] of Object . entries ( decorations . renamedParameters ) ) {
if ( name in options ) {
octokit . log . warn ( ` " ${ name } " parameter is deprecated for "octokit. ${ scope } . ${ methodName } ()". Use " ${ alias } " instead ` ) ;
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
if ( ! ( alias in options ) ) {
options [ alias ] = options [ name ] ;
}
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
delete options [ name ] ;
}
}
return requestWithDefaults ( options ) ;
} // @ts-ignore https://github.com/microsoft/TypeScript/issues/25488
return requestWithDefaults ( ... args ) ;
}
return Object . assign ( withDecorations , requestWithDefaults ) ;
}
/ * *
* This plugin is a 1 : 1 copy of internal @ octokit / rest plugins . The primary
* goal is to rebuild @ octokit / rest on top of @ octokit / core . Once that is
* done , we will remove the registerEndpoints methods and return the methods
* directly as with the other plugins . At that point we will also remove the
* legacy workarounds and deprecations .
*
* See the plan at
* https : //github.com/octokit/plugin-rest-endpoint-methods.js/pull/1
* /
function restEndpointMethods ( octokit ) {
return endpointsToMethods ( octokit , Endpoints ) ;
}
restEndpointMethods . VERSION = VERSION ;
exports . restEndpointMethods = restEndpointMethods ;
//# sourceMappingURL=index.js.map
2019-11-09 08:24:47 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
/***/ 844 :
/***/ ( 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 rnds8 = new Uint8Array ( 16 ) ;
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
function rng ( ) {
return _crypto . default . randomFillSync ( rnds8 ) ;
}
2019-11-09 08:24:47 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
/***/ 866 :
2019-11-09 08:24:47 +00:00
/***/ ( function ( module ) {
2020-07-16 08:57:13 +00:00
module . exports = removeHook
function removeHook ( state , name , method ) {
if ( ! state . registry [ name ] ) {
2020-08-19 03:20:28 +00:00
return
}
2019-11-09 08:24:47 +00:00
2020-08-19 03:20:28 +00:00
var index = state . registry [ name ]
. map ( function ( registered ) { return registered . orig } )
. indexOf ( method )
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
if ( index === - 1 ) {
return
}
2020-07-16 08:57:13 +00:00
2020-08-19 03:20:28 +00:00
state . registry [ name ] . splice ( index , 1 )
2019-11-09 08:24:47 +00:00
}
/***/ } ) ,
2020-07-16 08:57:13 +00:00
/***/ 893 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
"use strict" ;
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
Object . defineProperty ( exports , "__esModule" , {
value : true
} ) ;
exports . default = void 0 ;
2020-01-03 03:32:22 +00:00
2020-07-16 08:57:13 +00:00
var _rng = _interopRequireDefault ( _ _webpack _require _ _ ( 844 ) ) ;
2020-01-03 03:32:22 +00:00
2020-08-19 03:20:28 +00:00
var _stringify = _interopRequireDefault ( _ _webpack _require _ _ ( 411 ) ) ;
2020-01-03 03:32:22 +00:00
2020-07-16 08:57:13 +00:00
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
// **`v1()` - Generate time-based UUID**
//
// Inspired by https://github.com/LiosK/UUID.js
// and http://docs.python.org/library/uuid.html
let _nodeId ;
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
let _clockseq ; // Previous uuid creation time
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
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 ) ;
2019-11-09 08:24:47 +00:00
options = options || { } ;
2020-07-16 08:57:13 +00:00
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
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
if ( node == null || clockseq == null ) {
const seedBytes = options . random || ( options . rng || _rng . default ) ( ) ;
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
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 ] ] ;
}
2019-11-09 08:24:47 +00:00
2020-07-16 08:57:13 +00:00
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 ] ;
}
2020-08-19 03:20:28 +00:00
return buf || ( 0 , _stringify . default ) ( b ) ;
2020-07-16 08:57:13 +00:00
}
var _default = v1 ;
exports . default = _default ;
/***/ } ) ,
/***/ 898 :
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
"use strict" ;
Object . defineProperty ( exports , '__esModule' , { value : true } ) ;
var request = _ _webpack _require _ _ ( 753 ) ;
var universalUserAgent = _ _webpack _require _ _ ( 796 ) ;
2020-08-19 03:20:28 +00:00
const VERSION = "4.5.3" ;
2020-07-16 08:57:13 +00:00
class GraphqlError extends Error {
constructor ( request , response ) {
const message = response . data . errors [ 0 ] . message ;
super ( message ) ;
Object . assign ( this , response . data ) ;
2020-08-19 03:20:28 +00:00
Object . assign ( this , {
headers : response . headers
} ) ;
2020-07-16 08:57:13 +00:00
this . name = "GraphqlError" ;
this . request = request ; // Maintains proper stack trace (only available on V8)
/* istanbul ignore next */
if ( Error . captureStackTrace ) {
Error . captureStackTrace ( this , this . constructor ) ;
2019-11-09 08:24:47 +00:00
}
}
}
2020-07-16 08:57:13 +00:00
const NON _VARIABLE _OPTIONS = [ "method" , "baseUrl" , "url" , "headers" , "request" , "query" , "mediaType" ] ;
function graphql ( request , query , options ) {
options = typeof query === "string" ? options = Object . assign ( {
query
} , options ) : options = query ;
const requestOptions = Object . keys ( options ) . reduce ( ( result , key ) => {
if ( NON _VARIABLE _OPTIONS . includes ( key ) ) {
result [ key ] = options [ key ] ;
return result ;
}
if ( ! result . variables ) {
result . variables = { } ;
}
result . variables [ key ] = options [ key ] ;
return result ;
} , { } ) ;
return request ( requestOptions ) . then ( response => {
if ( response . data . errors ) {
2020-08-19 03:20:28 +00:00
const headers = { } ;
for ( const key of Object . keys ( response . headers ) ) {
headers [ key ] = response . headers [ key ] ;
}
2020-07-16 08:57:13 +00:00
throw new GraphqlError ( requestOptions , {
2020-08-19 03:20:28 +00:00
headers ,
2020-07-16 08:57:13 +00:00
data : response . data
} ) ;
}
return response . data . data ;
} ) ;
}
function withDefaults ( request$1 , newDefaults ) {
const newRequest = request$1 . defaults ( newDefaults ) ;
const newApi = ( query , options ) => {
return graphql ( newRequest , query , options ) ;
} ;
return Object . assign ( newApi , {
defaults : withDefaults . bind ( null , newRequest ) ,
endpoint : request . request . endpoint
} ) ;
}
const graphql$1 = withDefaults ( request . request , {
headers : {
"user-agent" : ` octokit-graphql.js/ ${ VERSION } ${ universalUserAgent . getUserAgent ( ) } `
} ,
method : "POST" ,
url : "/graphql"
} ) ;
function withCustomRequest ( customRequest ) {
return withDefaults ( customRequest , {
method : "POST" ,
url : "/graphql"
} ) ;
}
exports . graphql = graphql$1 ;
exports . withCustomRequest = withCustomRequest ;
//# sourceMappingURL=index.js.map
2019-11-09 08:24:47 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
/***/ 921 :
2019-11-09 08:24:47 +00:00
/***/ ( function ( _ _unusedmodule , exports , _ _webpack _require _ _ ) {
"use strict" ;
2020-01-03 03:32:22 +00:00
2020-05-02 11:27:54 +00:00
Object . defineProperty ( exports , "__esModule" , { value : true } ) ;
2020-07-16 08:57:13 +00:00
exports . Octokit = void 0 ;
const core _1 = _ _webpack _require _ _ ( 448 ) ;
const plugin _paginate _rest _1 = _ _webpack _require _ _ ( 299 ) ;
const plugin _rest _endpoint _methods _1 = _ _webpack _require _ _ ( 842 ) ;
exports . Octokit = core _1 . Octokit . plugin ( plugin _paginate _rest _1 . paginateRest , plugin _rest _endpoint _methods _1 . restEndpointMethods ) ;
2020-01-03 03:32:22 +00:00
2020-05-17 09:26:30 +00:00
/***/ } ) ,
2020-07-16 08:57:13 +00:00
/***/ 940 :
2020-05-17 09:26:30 +00:00
/***/ ( 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 = { } ;
2020-08-19 03:20:28 +00:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
2020-05-17 09:26:30 +00:00
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
2020-07-16 08:57:13 +00:00
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 ( ) ) ;
} ) ;
} ;
2020-05-17 09:26:30 +00:00
Object . defineProperty ( exports , "__esModule" , { value : true } ) ;
2020-07-16 08:57:13 +00:00
exports . createPullRequest = void 0 ;
2020-05-17 09:26:30 +00:00
const core = _ _importStar ( _ _webpack _require _ _ ( 470 ) ) ;
2020-07-16 08:57:13 +00:00
const create _or _update _branch _1 = _ _webpack _require _ _ ( 159 ) ;
const github _helper _1 = _ _webpack _require _ _ ( 718 ) ;
const git _command _manager _1 = _ _webpack _require _ _ ( 289 ) ;
2020-07-17 11:54:39 +00:00
const git _auth _helper _1 = _ _webpack _require _ _ ( 287 ) ;
2020-07-16 08:57:13 +00:00
const utils = _ _importStar ( _ _webpack _require _ _ ( 611 ) ) ;
function createPullRequest ( inputs ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
2020-07-17 11:54:39 +00:00
let gitAuthHelper ;
2020-07-16 08:57:13 +00:00
try {
// Get the repository path
const repoPath = utils . getRepoPath ( inputs . path ) ;
// Create a git command manager
const git = yield git _command _manager _1 . GitCommandManager . create ( repoPath ) ;
2020-07-17 11:54:39 +00:00
// Save and unset the extraheader auth config if it exists
2020-07-16 10:13:28 +00:00
core . startGroup ( 'Save persisted git credentials' ) ;
2020-07-17 11:54:39 +00:00
gitAuthHelper = new git _auth _helper _1 . GitAuthHelper ( git ) ;
yield gitAuthHelper . savePersistedAuth ( ) ;
2020-07-16 10:13:28 +00:00
core . endGroup ( ) ;
2020-07-18 06:33:46 +00:00
// Init the GitHub client
const githubHelper = new github _helper _1 . GitHubHelper ( inputs . token ) ;
core . startGroup ( 'Determining the base and head repositories' ) ;
// Determine the base repository from git config
2020-07-17 11:54:39 +00:00
const remoteUrl = yield git . tryGetRemoteUrl ( ) ;
2020-07-18 06:33:46 +00:00
const baseRemote = utils . getRemoteDetail ( remoteUrl ) ;
// Determine the head repository; the target for the pull request branch
const branchRemoteName = inputs . pushToFork ? 'fork' : 'origin' ;
const branchRepository = inputs . pushToFork
? inputs . pushToFork
: baseRemote . repository ;
if ( inputs . pushToFork ) {
// Check if the supplied fork is really a fork of the base
const parentRepository = yield githubHelper . getRepositoryParent ( branchRepository ) ;
if ( parentRepository != baseRemote . repository ) {
throw new Error ( ` Repository ' ${ branchRepository } ' is not a fork of ' ${ baseRemote . repository } '. Unable to continue. ` ) ;
}
// Add a remote for the fork
const remoteUrl = utils . getRemoteUrl ( baseRemote . protocol , branchRepository ) ;
yield git . exec ( [ 'remote' , 'add' , 'fork' , remoteUrl ] ) ;
}
2020-07-16 10:13:28 +00:00
core . endGroup ( ) ;
2020-07-18 06:33:46 +00:00
core . info ( ` Pull request branch target repository set to ${ branchRepository } ` ) ;
2020-07-18 07:04:36 +00:00
// Configure auth
2020-07-18 06:33:46 +00:00
if ( baseRemote . protocol == 'HTTPS' ) {
2020-07-16 10:13:28 +00:00
core . startGroup ( 'Configuring credential for HTTPS authentication' ) ;
2020-07-17 12:06:16 +00:00
yield gitAuthHelper . configureToken ( inputs . token ) ;
2020-07-16 10:13:28 +00:00
core . endGroup ( ) ;
2020-07-16 08:57:13 +00:00
}
// Determine if the checked out ref is a valid base for a pull request
// The action needs the checked out HEAD ref to be a branch
// This check will fail in the following cases:
// - HEAD is detached
// - HEAD is a merge commit (pull_request events)
// - HEAD is a tag
2020-07-16 10:13:28 +00:00
core . startGroup ( 'Checking the checked out ref' ) ;
2020-07-16 08:57:13 +00:00
const symbolicRefResult = yield git . exec ( [ 'symbolic-ref' , 'HEAD' , '--short' ] , true ) ;
if ( symbolicRefResult . exitCode != 0 ) {
core . debug ( ` ${ symbolicRefResult . stderr } ` ) ;
throw new Error ( 'The checked out ref is not a valid base for a pull request. Unable to continue.' ) ;
}
const workingBase = symbolicRefResult . stdout . trim ( ) ;
2020-08-19 03:06:41 +00:00
// If the base is not specified it is assumed to be the working base.
const base = inputs . base ? inputs . base : workingBase ;
// Throw an error if the base and branch are not different branches
// of the 'origin' remote. An identically named branch in the `fork`
// remote is perfectly fine.
if ( branchRemoteName == 'origin' && base == inputs . branch ) {
throw new Error ( ` The 'base' and 'branch' for a pull request must be different branches. Unable to continue. ` ) ;
2020-07-16 08:57:13 +00:00
}
2020-07-16 10:13:28 +00:00
core . endGroup ( ) ;
2020-07-20 10:14:42 +00:00
// Apply the branch suffix if set
if ( inputs . branchSuffix ) {
switch ( inputs . branchSuffix ) {
case 'short-commit-hash' :
// Suffix with the short SHA1 hash
inputs . branch = ` ${ inputs . branch } - ${ yield git . revParse ( 'HEAD' , [
'--short'
] ) } ` ;
break ;
case 'timestamp' :
// Suffix with the current timestamp
inputs . branch = ` ${ inputs . branch } - ${ utils . secondsSinceEpoch ( ) } ` ;
break ;
case 'random' :
// Suffix with a 7 character random string
inputs . branch = ` ${ inputs . branch } - ${ utils . randomString ( ) } ` ;
break ;
default :
throw new Error ( ` Branch suffix ' ${ inputs . branchSuffix } ' is not a valid value. Unable to continue. ` ) ;
}
}
2020-07-16 08:57:13 +00:00
// Output head branch
core . info ( ` Pull request branch to create or update set to ' ${ inputs . branch } ' ` ) ;
2020-07-19 11:23:36 +00:00
// Configure the committer and author
2020-07-16 10:13:28 +00:00
core . startGroup ( 'Configuring the committer and author' ) ;
2020-07-19 11:23:36 +00:00
const parsedAuthor = utils . parseDisplayNameEmail ( inputs . author ) ;
const parsedCommitter = utils . parseDisplayNameEmail ( inputs . committer ) ;
2020-07-16 08:57:13 +00:00
git . setIdentityGitOptions ( [
'-c' ,
2020-07-19 11:23:36 +00:00
` author.name= ${ parsedAuthor . name } ` ,
2020-07-16 08:57:13 +00:00
'-c' ,
2020-07-19 11:23:36 +00:00
` author.email= ${ parsedAuthor . email } ` ,
2020-07-16 08:57:13 +00:00
'-c' ,
2020-07-19 11:23:36 +00:00
` committer.name= ${ parsedCommitter . name } ` ,
2020-07-16 08:57:13 +00:00
'-c' ,
2020-07-19 11:23:36 +00:00
` committer.email= ${ parsedCommitter . email } `
2020-07-16 08:57:13 +00:00
] ) ;
2020-07-19 11:23:36 +00:00
core . info ( ` Configured git committer as ' ${ parsedCommitter . name } < ${ parsedCommitter . email } >' ` ) ;
core . info ( ` Configured git author as ' ${ parsedAuthor . name } < ${ parsedAuthor . email } >' ` ) ;
2020-07-16 10:13:28 +00:00
core . endGroup ( ) ;
2020-07-16 08:57:13 +00:00
// Create or update the pull request branch
2020-07-16 10:13:28 +00:00
core . startGroup ( 'Create or update the pull request branch' ) ;
2020-07-30 15:18:17 +00:00
const result = yield create _or _update _branch _1 . createOrUpdateBranch ( git , inputs . commitMessage , inputs . base , inputs . branch , branchRemoteName , inputs . signoff ) ;
2020-07-16 10:13:28 +00:00
core . endGroup ( ) ;
2020-07-16 08:57:13 +00:00
if ( [ 'created' , 'updated' ] . includes ( result . action ) ) {
// The branch was created or updated
2020-07-18 06:33:46 +00:00
core . startGroup ( ` Pushing pull request branch to ' ${ branchRemoteName } / ${ inputs . branch } ' ` ) ;
2020-07-17 01:37:09 +00:00
yield git . push ( [
'--force-with-lease' ,
2020-07-18 06:33:46 +00:00
branchRemoteName ,
2020-07-17 01:37:09 +00:00
` HEAD:refs/heads/ ${ inputs . branch } `
] ) ;
2020-07-16 10:13:28 +00:00
core . endGroup ( ) ;
2020-07-16 08:57:13 +00:00
// Set the base. It would have been '' if not specified as an input
inputs . base = result . base ;
if ( result . hasDiffWithBase ) {
// Create or update the pull request
2020-07-18 06:33:46 +00:00
yield githubHelper . createOrUpdatePullRequest ( inputs , baseRemote . repository , branchRepository ) ;
2020-07-16 08:57:13 +00:00
}
else {
// If there is no longer a diff with the base delete the branch
core . info ( ` Branch ' ${ inputs . branch } ' no longer differs from base branch ' ${ inputs . base } ' ` ) ;
core . info ( ` Closing pull request and deleting branch ' ${ inputs . branch } ' ` ) ;
yield git . push ( [
'--delete' ,
'--force' ,
2020-07-18 06:33:46 +00:00
branchRemoteName ,
2020-07-16 08:57:13 +00:00
` refs/heads/ ${ inputs . branch } `
] ) ;
}
}
2020-05-17 09:26:30 +00:00
}
2020-07-16 08:57:13 +00:00
catch ( error ) {
core . setFailed ( error . message ) ;
2020-05-17 09:26:30 +00:00
}
2020-07-16 08:57:13 +00:00
finally {
2020-07-17 11:54:39 +00:00
// Remove auth and restore persisted auth config if it existed
2020-07-16 10:13:28 +00:00
core . startGroup ( 'Restore persisted git credentials' ) ;
2020-07-17 11:54:39 +00:00
yield gitAuthHelper . removeAuth ( ) ;
yield gitAuthHelper . restorePersistedAuth ( ) ;
2020-07-16 10:13:28 +00:00
core . endGroup ( ) ;
2020-05-17 09:26:30 +00:00
}
} ) ;
}
2020-07-16 08:57:13 +00:00
exports . createPullRequest = createPullRequest ;
2020-05-17 09:26:30 +00:00
2019-11-09 08:24:47 +00:00
/***/ } ) ,
/***/ 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 ( ) ) ;
} ) ;
} ;
2020-05-02 08:45:04 +00:00
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 ;
} ;
2019-11-09 08:24:47 +00:00
Object . defineProperty ( exports , "__esModule" , { value : true } ) ;
2020-08-19 03:20:28 +00:00
const tr = _ _importStar ( _ _webpack _require _ _ ( 9 ) ) ;
2019-11-09 08:24:47 +00:00
/ * *
* 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
/***/ } )
/******/ } ) ;