2022-06-27 14:17:15 -04:00
/******/ ( ( ) => { // webpackBootstrap
/******/ var _ _webpack _modules _ _ = ( {
/***/ 5350 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . issue = exports . issueCommand = void 0 ;
const os = _ _importStar ( _ _nccwpck _require _ _ ( 2037 ) ) ;
const utils _1 = _ _nccwpck _require _ _ ( 7369 ) ;
/ * *
* Commands
*
* Command Format :
* : : name key = value , key = value : : message
*
* Examples :
* : : warning : : This is the message
* : : set - env name = MY _VAR : : some value
* /
function issueCommand ( command , properties , message ) {
const cmd = new Command ( command , properties , message ) ;
process . stdout . write ( cmd . toString ( ) + os . EOL ) ;
}
exports . issueCommand = issueCommand ;
function issue ( name , message = '' ) {
issueCommand ( name , { } , message ) ;
}
exports . issue = issue ;
const CMD _STRING = '::' ;
class Command {
constructor ( command , properties , message ) {
if ( ! command ) {
command = 'missing.command' ;
}
this . command = command ;
this . properties = properties ;
this . message = message ;
}
toString ( ) {
let cmdStr = CMD _STRING + this . command ;
if ( this . properties && Object . keys ( this . properties ) . length > 0 ) {
cmdStr += ' ' ;
let first = true ;
for ( const key in this . properties ) {
if ( this . properties . hasOwnProperty ( key ) ) {
const val = this . properties [ key ] ;
if ( val ) {
if ( first ) {
first = false ;
}
else {
cmdStr += ',' ;
}
cmdStr += ` ${ key } = ${ escapeProperty ( val ) } ` ;
}
}
}
}
cmdStr += ` ${ CMD _STRING } ${ escapeData ( this . message ) } ` ;
return cmdStr ;
}
}
function escapeData ( s ) {
return utils _1 . toCommandValue ( s )
. replace ( /%/g , '%25' )
. replace ( /\r/g , '%0D' )
. replace ( /\n/g , '%0A' ) ;
}
function escapeProperty ( s ) {
return utils _1 . toCommandValue ( s )
. replace ( /%/g , '%25' )
. replace ( /\r/g , '%0D' )
. replace ( /\n/g , '%0A' )
. replace ( /:/g , '%3A' )
. replace ( /,/g , '%2C' ) ;
}
//# sourceMappingURL=command.js.map
/***/ } ) ,
/***/ 6024 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . getIDToken = exports . getState = exports . saveState = exports . group = exports . endGroup = exports . startGroup = exports . info = exports . notice = exports . warning = exports . error = exports . debug = exports . isDebug = exports . setFailed = exports . setCommandEcho = exports . setOutput = exports . getBooleanInput = exports . getMultilineInput = exports . getInput = exports . addPath = exports . setSecret = exports . exportVariable = exports . ExitCode = void 0 ;
const command _1 = _ _nccwpck _require _ _ ( 5350 ) ;
const file _command _1 = _ _nccwpck _require _ _ ( 8466 ) ;
const utils _1 = _ _nccwpck _require _ _ ( 7369 ) ;
const os = _ _importStar ( _ _nccwpck _require _ _ ( 2037 ) ) ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 1017 ) ) ;
const oidc _utils _1 = _ _nccwpck _require _ _ ( 7557 ) ;
/ * *
* The code to exit an action
* /
var ExitCode ;
( function ( ExitCode ) {
/ * *
* A code indicating that the action was successful
* /
ExitCode [ ExitCode [ "Success" ] = 0 ] = "Success" ;
/ * *
* A code indicating that the action was a failure
* /
ExitCode [ ExitCode [ "Failure" ] = 1 ] = "Failure" ;
} ) ( ExitCode = exports . ExitCode || ( exports . ExitCode = { } ) ) ;
//-----------------------------------------------------------------------
// Variables
//-----------------------------------------------------------------------
/ * *
* Sets env variable for this action and future actions in the job
* @ param name the name of the variable to set
* @ param val the value of the variable . Non - string values will be converted to a string via JSON . stringify
* /
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function exportVariable ( name , val ) {
const convertedVal = utils _1 . toCommandValue ( val ) ;
process . env [ name ] = convertedVal ;
const filePath = process . env [ 'GITHUB_ENV' ] || '' ;
if ( filePath ) {
const delimiter = '_GitHubActionsFileCommandDelimeter_' ;
const commandValue = ` ${ name } << ${ delimiter } ${ os . EOL } ${ convertedVal } ${ os . EOL } ${ delimiter } ` ;
file _command _1 . issueCommand ( 'ENV' , commandValue ) ;
}
else {
command _1 . issueCommand ( 'set-env' , { name } , convertedVal ) ;
}
}
exports . exportVariable = exportVariable ;
/ * *
* Registers a secret which will get masked from logs
* @ param secret value of the secret
* /
function setSecret ( secret ) {
command _1 . issueCommand ( 'add-mask' , { } , secret ) ;
}
exports . setSecret = setSecret ;
/ * *
* Prepends inputPath to the PATH ( for this action and future actions )
* @ param inputPath
* /
function addPath ( inputPath ) {
const filePath = process . env [ 'GITHUB_PATH' ] || '' ;
if ( filePath ) {
file _command _1 . issueCommand ( 'PATH' , inputPath ) ;
}
else {
command _1 . issueCommand ( 'add-path' , { } , inputPath ) ;
}
process . env [ 'PATH' ] = ` ${ inputPath } ${ path . delimiter } ${ process . env [ 'PATH' ] } ` ;
}
exports . addPath = addPath ;
/ * *
* Gets the value of an input .
* Unless trimWhitespace is set to false in InputOptions , the value is also trimmed .
* Returns an empty string if the value is not defined .
*
* @ param name name of the input to get
* @ param options optional . See InputOptions .
* @ returns string
* /
function getInput ( name , options ) {
const val = process . env [ ` INPUT_ ${ name . replace ( / /g , '_' ) . toUpperCase ( ) } ` ] || '' ;
if ( options && options . required && ! val ) {
throw new Error ( ` Input required and not supplied: ${ name } ` ) ;
}
if ( options && options . trimWhitespace === false ) {
return val ;
}
return val . trim ( ) ;
}
exports . getInput = getInput ;
/ * *
* Gets the values of an multiline input . Each value is also trimmed .
*
* @ param name name of the input to get
* @ param options optional . See InputOptions .
* @ returns string [ ]
*
* /
function getMultilineInput ( name , options ) {
const inputs = getInput ( name , options )
. split ( '\n' )
. filter ( x => x !== '' ) ;
return inputs ;
}
exports . getMultilineInput = getMultilineInput ;
/ * *
* Gets the input value of the boolean type in the YAML 1.2 "core schema" specification .
* Support boolean input list : ` true | True | TRUE | false | False | FALSE ` .
* The return value is also in boolean type .
* ref : https : //yaml.org/spec/1.2/spec.html#id2804923
*
* @ param name name of the input to get
* @ param options optional . See InputOptions .
* @ returns boolean
* /
function getBooleanInput ( name , options ) {
const trueValue = [ 'true' , 'True' , 'TRUE' ] ;
const falseValue = [ 'false' , 'False' , 'FALSE' ] ;
const val = getInput ( name , options ) ;
if ( trueValue . includes ( val ) )
return true ;
if ( falseValue . includes ( val ) )
return false ;
throw new TypeError ( ` Input does not meet YAML 1.2 "Core Schema" specification: ${ name } \n ` +
` Support boolean input list: \` true | True | TRUE | false | False | FALSE \` ` ) ;
}
exports . getBooleanInput = getBooleanInput ;
/ * *
* Sets the value of an output .
*
* @ param name name of the output to set
* @ param value value to store . Non - string values will be converted to a string via JSON . stringify
* /
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function setOutput ( name , value ) {
process . stdout . write ( os . EOL ) ;
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 ( )
* @ param properties optional properties to add to the annotation .
* /
function error ( message , properties = { } ) {
command _1 . issueCommand ( 'error' , utils _1 . toCommandProperties ( properties ) , message instanceof Error ? message . toString ( ) : message ) ;
}
exports . error = error ;
/ * *
* Adds a warning issue
* @ param message warning issue message . Errors will be converted to string via toString ( )
* @ param properties optional properties to add to the annotation .
* /
function warning ( message , properties = { } ) {
command _1 . issueCommand ( 'warning' , utils _1 . toCommandProperties ( properties ) , message instanceof Error ? message . toString ( ) : message ) ;
}
exports . warning = warning ;
/ * *
* Adds a notice issue
* @ param message notice issue message . Errors will be converted to string via toString ( )
* @ param properties optional properties to add to the annotation .
* /
function notice ( message , properties = { } ) {
command _1 . issueCommand ( 'notice' , utils _1 . toCommandProperties ( properties ) , message instanceof Error ? message . toString ( ) : message ) ;
}
exports . notice = notice ;
/ * *
* Writes info to log with console . log .
* @ param message info message
* /
function info ( message ) {
process . stdout . write ( message + os . EOL ) ;
}
exports . info = info ;
/ * *
* Begin an output group .
*
* Output until the next ` groupEnd ` will be foldable in this group
*
* @ param name The name of the output group
* /
function startGroup ( name ) {
command _1 . issue ( 'group' , name ) ;
}
exports . startGroup = startGroup ;
/ * *
* End an output group .
* /
function endGroup ( ) {
command _1 . issue ( 'endgroup' ) ;
}
exports . endGroup = endGroup ;
/ * *
* Wrap an asynchronous function call in a group .
*
* Returns the same type as the function itself .
*
* @ param name The name of the group
* @ param fn The function to wrap in the group
* /
function group ( name , fn ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
startGroup ( name ) ;
let result ;
try {
result = yield fn ( ) ;
}
finally {
endGroup ( ) ;
}
return result ;
} ) ;
}
exports . group = group ;
//-----------------------------------------------------------------------
// Wrapper action state
//-----------------------------------------------------------------------
/ * *
* Saves state for current action , the state can only be retrieved by this action ' s post job execution .
*
* @ param name name of the state to store
* @ param value value to store . Non - string values will be converted to a string via JSON . stringify
* /
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function saveState ( name , value ) {
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 ;
function getIDToken ( aud ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return yield oidc _utils _1 . OidcClient . getIDToken ( aud ) ;
} ) ;
}
exports . getIDToken = getIDToken ;
2022-07-11 13:48:02 -04:00
/ * *
* Summary exports
* /
var summary _1 = _ _nccwpck _require _ _ ( 9029 ) ;
Object . defineProperty ( exports , "summary" , ( { enumerable : true , get : function ( ) { return summary _1 . summary ; } } ) ) ;
/ * *
* @ deprecated use core . summary
* /
var summary _2 = _ _nccwpck _require _ _ ( 9029 ) ;
Object . defineProperty ( exports , "markdownSummary" , ( { enumerable : true , get : function ( ) { return summary _2 . markdownSummary ; } } ) ) ;
/ * *
* Path exports
* /
var path _utils _1 = _ _nccwpck _require _ _ ( 8064 ) ;
Object . defineProperty ( exports , "toPosixPath" , ( { enumerable : true , get : function ( ) { return path _utils _1 . toPosixPath ; } } ) ) ;
Object . defineProperty ( exports , "toWin32Path" , ( { enumerable : true , get : function ( ) { return path _utils _1 . toWin32Path ; } } ) ) ;
Object . defineProperty ( exports , "toPlatformPath" , ( { enumerable : true , get : function ( ) { return path _utils _1 . toPlatformPath ; } } ) ) ;
2022-06-27 14:17:15 -04:00
//# sourceMappingURL=core.js.map
/***/ } ) ,
/***/ 8466 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
// For internal use, subject to change.
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . issueCommand = void 0 ;
// We use any as a valid input type
/* eslint-disable @typescript-eslint/no-explicit-any */
const fs = _ _importStar ( _ _nccwpck _require _ _ ( 7147 ) ) ;
const os = _ _importStar ( _ _nccwpck _require _ _ ( 2037 ) ) ;
const utils _1 = _ _nccwpck _require _ _ ( 7369 ) ;
function issueCommand ( command , message ) {
const filePath = process . env [ ` GITHUB_ ${ command } ` ] ;
if ( ! filePath ) {
throw new Error ( ` Unable to find environment variable for file command ${ command } ` ) ;
}
if ( ! fs . existsSync ( filePath ) ) {
throw new Error ( ` Missing file at path: ${ filePath } ` ) ;
}
fs . appendFileSync ( filePath , ` ${ utils _1 . toCommandValue ( message ) } ${ os . EOL } ` , {
encoding : 'utf8'
} ) ;
}
exports . issueCommand = issueCommand ;
//# sourceMappingURL=file-command.js.map
/***/ } ) ,
/***/ 7557 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . OidcClient = void 0 ;
2022-07-11 13:48:02 -04:00
const http _client _1 = _ _nccwpck _require _ _ ( 2745 ) ;
const auth _1 = _ _nccwpck _require _ _ ( 2834 ) ;
2022-06-27 14:17:15 -04:00
const core _1 = _ _nccwpck _require _ _ ( 6024 ) ;
class OidcClient {
static createHttpClient ( allowRetry = true , maxRetry = 10 ) {
const requestOptions = {
allowRetries : allowRetry ,
maxRetries : maxRetry
} ;
return new http _client _1 . HttpClient ( 'actions/oidc-client' , [ new auth _1 . BearerCredentialHandler ( OidcClient . getRequestToken ( ) ) ] , requestOptions ) ;
}
static getRequestToken ( ) {
const token = process . env [ 'ACTIONS_ID_TOKEN_REQUEST_TOKEN' ] ;
if ( ! token ) {
throw new Error ( 'Unable to get ACTIONS_ID_TOKEN_REQUEST_TOKEN env variable' ) ;
}
return token ;
}
static getIDTokenUrl ( ) {
const runtimeUrl = process . env [ 'ACTIONS_ID_TOKEN_REQUEST_URL' ] ;
if ( ! runtimeUrl ) {
throw new Error ( 'Unable to get ACTIONS_ID_TOKEN_REQUEST_URL env variable' ) ;
}
return runtimeUrl ;
}
static getCall ( id _token _url ) {
var _a ;
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const httpclient = OidcClient . createHttpClient ( ) ;
const res = yield httpclient
. getJson ( id _token _url )
. catch ( error => {
throw new Error ( ` Failed to get ID Token. \n
Error Code : $ { error . statusCode } \ n
Error Message : $ { error . result . message } ` );
} ) ;
const id _token = ( _a = res . result ) === null || _a === void 0 ? void 0 : _a . value ;
if ( ! id _token ) {
throw new Error ( 'Response json body do not have ID Token field' ) ;
}
return id _token ;
} ) ;
}
static getIDToken ( audience ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
try {
// New ID Token is requested from action service
let id _token _url = OidcClient . getIDTokenUrl ( ) ;
if ( audience ) {
const encodedAudience = encodeURIComponent ( audience ) ;
id _token _url = ` ${ id _token _url } &audience= ${ encodedAudience } ` ;
}
core _1 . debug ( ` ID token url is ${ id _token _url } ` ) ;
const id _token = yield OidcClient . getCall ( id _token _url ) ;
core _1 . setSecret ( id _token ) ;
return id _token ;
}
catch ( error ) {
throw new Error ( ` Error message: ${ error . message } ` ) ;
}
} ) ;
}
}
exports . OidcClient = OidcClient ;
//# sourceMappingURL=oidc-utils.js.map
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 8064 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . toPlatformPath = exports . toWin32Path = exports . toPosixPath = void 0 ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 1017 ) ) ;
/ * *
* toPosixPath converts the given path to the posix form . On Windows , \ \ will be
* replaced with / .
*
* @ param pth . Path to transform .
* @ return string Posix path .
* /
function toPosixPath ( pth ) {
return pth . replace ( /[\\]/g , '/' ) ;
}
exports . toPosixPath = toPosixPath ;
/ * *
* toWin32Path converts the given path to the win32 form . On Linux , / w i l l b e
* replaced with \ \ .
*
* @ param pth . Path to transform .
* @ return string Win32 path .
* /
function toWin32Path ( pth ) {
return pth . replace ( /[/]/g , '\\' ) ;
}
exports . toWin32Path = toWin32Path ;
/ * *
* toPlatformPath converts the given path to a platform - specific path . It does
* this by replacing instances of / a n d \ w i t h t h e p l a t f o r m - s p e c i f i c p a t h
* separator .
*
* @ param pth The path to platformize .
* @ return string The platform - specific path .
* /
function toPlatformPath ( pth ) {
return pth . replace ( /[/\\]/g , path . sep ) ;
}
exports . toPlatformPath = toPlatformPath ;
//# sourceMappingURL=path-utils.js.map
/***/ } ) ,
/***/ 9029 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . summary = exports . markdownSummary = exports . SUMMARY _DOCS _URL = exports . SUMMARY _ENV _VAR = void 0 ;
const os _1 = _ _nccwpck _require _ _ ( 2037 ) ;
const fs _1 = _ _nccwpck _require _ _ ( 7147 ) ;
const { access , appendFile , writeFile } = fs _1 . promises ;
exports . SUMMARY _ENV _VAR = 'GITHUB_STEP_SUMMARY' ;
exports . SUMMARY _DOCS _URL = 'https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#adding-a-job-summary' ;
class Summary {
constructor ( ) {
this . _buffer = '' ;
}
/ * *
* Finds the summary file path from the environment , rejects if env var is not found or file does not exist
* Also checks r / w permissions .
*
* @ returns step summary file path
* /
filePath ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( this . _filePath ) {
return this . _filePath ;
}
const pathFromEnv = process . env [ exports . SUMMARY _ENV _VAR ] ;
if ( ! pathFromEnv ) {
throw new Error ( ` Unable to find environment variable for $ ${ exports . SUMMARY _ENV _VAR } . Check if your runtime environment supports job summaries. ` ) ;
}
try {
yield access ( pathFromEnv , fs _1 . constants . R _OK | fs _1 . constants . W _OK ) ;
}
catch ( _a ) {
throw new Error ( ` Unable to access summary file: ' ${ pathFromEnv } '. Check if the file has correct read/write permissions. ` ) ;
}
this . _filePath = pathFromEnv ;
return this . _filePath ;
} ) ;
}
/ * *
* Wraps content in an HTML tag , adding any HTML attributes
*
* @ param { string } tag HTML tag to wrap
* @ param { string | null } content content within the tag
* @ param { [ attribute : string ] : string } attrs key - value list of HTML attributes to add
*
* @ returns { string } content wrapped in HTML element
* /
wrap ( tag , content , attrs = { } ) {
const htmlAttrs = Object . entries ( attrs )
. map ( ( [ key , value ] ) => ` ${ key } =" ${ value } " ` )
. join ( '' ) ;
if ( ! content ) {
return ` < ${ tag } ${ htmlAttrs } > ` ;
}
return ` < ${ tag } ${ htmlAttrs } > ${ content } </ ${ tag } > ` ;
}
/ * *
* Writes text in the buffer to the summary buffer file and empties buffer . Will append by default .
*
* @ param { SummaryWriteOptions } [ options ] ( optional ) options for write operation
*
* @ returns { Promise < Summary > } summary instance
* /
write ( options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const overwrite = ! ! ( options === null || options === void 0 ? void 0 : options . overwrite ) ;
const filePath = yield this . filePath ( ) ;
const writeFunc = overwrite ? writeFile : appendFile ;
yield writeFunc ( filePath , this . _buffer , { encoding : 'utf8' } ) ;
return this . emptyBuffer ( ) ;
} ) ;
}
/ * *
* Clears the summary buffer and wipes the summary file
*
* @ returns { Summary } summary instance
* /
clear ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . emptyBuffer ( ) . write ( { overwrite : true } ) ;
} ) ;
}
/ * *
* Returns the current summary buffer as a string
*
* @ returns { string } string of summary buffer
* /
stringify ( ) {
return this . _buffer ;
}
/ * *
* If the summary buffer is empty
*
* @ returns { boolen } true if the buffer is empty
* /
isEmptyBuffer ( ) {
return this . _buffer . length === 0 ;
}
/ * *
* Resets the summary buffer without writing to summary file
*
* @ returns { Summary } summary instance
* /
emptyBuffer ( ) {
this . _buffer = '' ;
return this ;
}
/ * *
* Adds raw text to the summary buffer
*
* @ param { string } text content to add
* @ param { boolean } [ addEOL = false ] ( optional ) append an EOL to the raw text ( default : false )
*
* @ returns { Summary } summary instance
* /
addRaw ( text , addEOL = false ) {
this . _buffer += text ;
return addEOL ? this . addEOL ( ) : this ;
}
/ * *
* Adds the operating system - specific end - of - line marker to the buffer
*
* @ returns { Summary } summary instance
* /
addEOL ( ) {
return this . addRaw ( os _1 . EOL ) ;
}
/ * *
* Adds an HTML codeblock to the summary buffer
*
* @ param { string } code content to render within fenced code block
* @ param { string } lang ( optional ) language to syntax highlight code
*
* @ returns { Summary } summary instance
* /
addCodeBlock ( code , lang ) {
const attrs = Object . assign ( { } , ( lang && { lang } ) ) ;
const element = this . wrap ( 'pre' , this . wrap ( 'code' , code ) , attrs ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML list to the summary buffer
*
* @ param { string [ ] } items list of items to render
* @ param { boolean } [ ordered = false ] ( optional ) if the rendered list should be ordered or not ( default : false )
*
* @ returns { Summary } summary instance
* /
addList ( items , ordered = false ) {
const tag = ordered ? 'ol' : 'ul' ;
const listItems = items . map ( item => this . wrap ( 'li' , item ) ) . join ( '' ) ;
const element = this . wrap ( tag , listItems ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML table to the summary buffer
*
* @ param { SummaryTableCell [ ] } rows table rows
*
* @ returns { Summary } summary instance
* /
addTable ( rows ) {
const tableBody = rows
. map ( row => {
const cells = row
. map ( cell => {
if ( typeof cell === 'string' ) {
return this . wrap ( 'td' , cell ) ;
}
const { header , data , colspan , rowspan } = cell ;
const tag = header ? 'th' : 'td' ;
const attrs = Object . assign ( Object . assign ( { } , ( colspan && { colspan } ) ) , ( rowspan && { rowspan } ) ) ;
return this . wrap ( tag , data , attrs ) ;
} )
. join ( '' ) ;
return this . wrap ( 'tr' , cells ) ;
} )
. join ( '' ) ;
const element = this . wrap ( 'table' , tableBody ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds a collapsable HTML details element to the summary buffer
*
* @ param { string } label text for the closed state
* @ param { string } content collapsable content
*
* @ returns { Summary } summary instance
* /
addDetails ( label , content ) {
const element = this . wrap ( 'details' , this . wrap ( 'summary' , label ) + content ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML image tag to the summary buffer
*
* @ param { string } src path to the image you to embed
* @ param { string } alt text description of the image
* @ param { SummaryImageOptions } options ( optional ) addition image attributes
*
* @ returns { Summary } summary instance
* /
addImage ( src , alt , options ) {
const { width , height } = options || { } ;
const attrs = Object . assign ( Object . assign ( { } , ( width && { width } ) ) , ( height && { height } ) ) ;
const element = this . wrap ( 'img' , null , Object . assign ( { src , alt } , attrs ) ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML section heading element
*
* @ param { string } text heading text
* @ param { number | string } [ level = 1 ] ( optional ) the heading level , default : 1
*
* @ returns { Summary } summary instance
* /
addHeading ( text , level ) {
const tag = ` h ${ level } ` ;
const allowedTag = [ 'h1' , 'h2' , 'h3' , 'h4' , 'h5' , 'h6' ] . includes ( tag )
? tag
: 'h1' ;
const element = this . wrap ( allowedTag , text ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML thematic break ( < hr > ) to the summary buffer
*
* @ returns { Summary } summary instance
* /
addSeparator ( ) {
const element = this . wrap ( 'hr' , null ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML line break ( < br > ) to the summary buffer
*
* @ returns { Summary } summary instance
* /
addBreak ( ) {
const element = this . wrap ( 'br' , null ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML blockquote to the summary buffer
*
* @ param { string } text quote text
* @ param { string } cite ( optional ) citation url
*
* @ returns { Summary } summary instance
* /
addQuote ( text , cite ) {
const attrs = Object . assign ( { } , ( cite && { cite } ) ) ;
const element = this . wrap ( 'blockquote' , text , attrs ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML anchor tag to the summary buffer
*
* @ param { string } text link text / content
* @ param { string } href hyperlink
*
* @ returns { Summary } summary instance
* /
addLink ( text , href ) {
const element = this . wrap ( 'a' , text , { href } ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
}
const _summary = new Summary ( ) ;
/ * *
* @ deprecated use ` core.summary `
* /
exports . markdownSummary = _summary ;
exports . summary = _summary ;
//# sourceMappingURL=summary.js.map
/***/ } ) ,
2022-06-27 14:17:15 -04:00
/***/ 7369 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
"use strict" ;
// We use any as a valid input type
/* eslint-disable @typescript-eslint/no-explicit-any */
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . toCommandProperties = exports . toCommandValue = void 0 ;
/ * *
* Sanitizes an input into a string so it can be passed into issueCommand safely
* @ param input input to sanitize into a string
* /
function toCommandValue ( input ) {
if ( input === null || input === undefined ) {
return '' ;
}
else if ( typeof input === 'string' || input instanceof String ) {
return input ;
}
return JSON . stringify ( input ) ;
}
exports . toCommandValue = toCommandValue ;
/ * *
*
* @ param annotationProperties
* @ returns The command properties to send with the actual annotation command
* See IssueCommandProperties : https : //github.com/actions/runner/blob/main/src/Runner.Worker/ActionCommandManager.cs#L646
* /
function toCommandProperties ( annotationProperties ) {
if ( ! Object . keys ( annotationProperties ) . length ) {
return { } ;
}
return {
title : annotationProperties . title ,
file : annotationProperties . file ,
line : annotationProperties . startLine ,
endLine : annotationProperties . endLine ,
col : annotationProperties . startColumn ,
endColumn : annotationProperties . endColumn
} ;
}
exports . toCommandProperties = toCommandProperties ;
//# sourceMappingURL=utils.js.map
/***/ } ) ,
/***/ 2423 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . getExecOutput = exports . exec = void 0 ;
const string _decoder _1 = _ _nccwpck _require _ _ ( 1576 ) ;
const tr = _ _importStar ( _ _nccwpck _require _ _ ( 9216 ) ) ;
/ * *
* 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 ;
/ * *
* Exec a command and get the output .
* Output will be streamed to the live console .
* Returns promise with the exit code and collected stdout and stderr
*
* @ 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 < ExecOutput > exit code , stdout , and stderr
* /
function getExecOutput ( commandLine , args , options ) {
var _a , _b ;
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
let stdout = '' ;
let stderr = '' ;
//Using string decoder covers the case where a mult-byte character is split
const stdoutDecoder = new string _decoder _1 . StringDecoder ( 'utf8' ) ;
const stderrDecoder = new string _decoder _1 . StringDecoder ( 'utf8' ) ;
const originalStdoutListener = ( _a = options === null || options === void 0 ? void 0 : options . listeners ) === null || _a === void 0 ? void 0 : _a . stdout ;
const originalStdErrListener = ( _b = options === null || options === void 0 ? void 0 : options . listeners ) === null || _b === void 0 ? void 0 : _b . stderr ;
const stdErrListener = ( data ) => {
stderr += stderrDecoder . write ( data ) ;
if ( originalStdErrListener ) {
originalStdErrListener ( data ) ;
}
} ;
const stdOutListener = ( data ) => {
stdout += stdoutDecoder . write ( data ) ;
if ( originalStdoutListener ) {
originalStdoutListener ( data ) ;
}
} ;
const listeners = Object . assign ( Object . assign ( { } , options === null || options === void 0 ? void 0 : options . listeners ) , { stdout : stdOutListener , stderr : stdErrListener } ) ;
const exitCode = yield exec ( commandLine , args , Object . assign ( Object . assign ( { } , options ) , { listeners } ) ) ;
//flush any remaining characters
stdout += stdoutDecoder . end ( ) ;
stderr += stderrDecoder . end ( ) ;
return {
exitCode ,
stdout ,
stderr
} ;
} ) ;
}
exports . getExecOutput = getExecOutput ;
//# sourceMappingURL=exec.js.map
/***/ } ) ,
/***/ 9216 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . argStringToArray = exports . ToolRunner = void 0 ;
const os = _ _importStar ( _ _nccwpck _require _ _ ( 2037 ) ) ;
const events = _ _importStar ( _ _nccwpck _require _ _ ( 2361 ) ) ;
const child = _ _importStar ( _ _nccwpck _require _ _ ( 2081 ) ) ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 1017 ) ) ;
const io = _ _importStar ( _ _nccwpck _require _ _ ( 6202 ) ) ;
const ioUtil = _ _importStar ( _ _nccwpck _require _ _ ( 6120 ) ) ;
const timers _1 = _ _nccwpck _require _ _ ( 9512 ) ;
/* eslint-disable @typescript-eslint/unbound-method */
const IS _WINDOWS = process . platform === 'win32' ;
/ *
* Class for running command line tools . Handles quoting and arg parsing in a platform agnostic way .
* /
class ToolRunner extends events . EventEmitter {
constructor ( toolPath , args , options ) {
super ( ) ;
if ( ! toolPath ) {
throw new Error ( "Parameter 'toolPath' cannot be null or empty." ) ;
}
this . toolPath = toolPath ;
this . args = args || [ ] ;
this . options = options || { } ;
}
_debug ( message ) {
if ( this . options . listeners && this . options . listeners . debug ) {
this . options . listeners . debug ( message ) ;
}
}
_getCommandString ( options , noPrefix ) {
const toolPath = this . _getSpawnFileName ( ) ;
const args = this . _getSpawnArgs ( options ) ;
let cmd = noPrefix ? '' : '[command]' ; // omit prefix when piped to a second tool
if ( IS _WINDOWS ) {
// Windows + cmd file
if ( this . _isCmdFile ( ) ) {
cmd += toolPath ;
for ( const a of args ) {
cmd += ` ${ a } ` ;
}
}
// Windows + verbatim
else if ( options . windowsVerbatimArguments ) {
cmd += ` " ${ toolPath } " ` ;
for ( const a of args ) {
cmd += ` ${ a } ` ;
}
}
// Windows (regular)
else {
cmd += this . _windowsQuoteCmdArg ( toolPath ) ;
for ( const a of args ) {
cmd += ` ${ this . _windowsQuoteCmdArg ( a ) } ` ;
}
}
}
else {
// OSX/Linux - this can likely be improved with some form of quoting.
// creating processes on Unix is fundamentally different than Windows.
// on Unix, execvp() takes an arg array.
cmd += toolPath ;
for ( const a of args ) {
cmd += ` ${ a } ` ;
}
}
return cmd ;
}
_processLineBuffer ( data , strBuffer , onLine ) {
try {
let s = strBuffer + data . toString ( ) ;
let n = s . indexOf ( os . EOL ) ;
while ( n > - 1 ) {
const line = s . substring ( 0 , n ) ;
onLine ( line ) ;
// the rest of the string ...
s = s . substring ( n + os . EOL . length ) ;
n = s . indexOf ( os . EOL ) ;
}
return s ;
}
catch ( err ) {
// streaming lines to console is best effort. Don't fail a build.
this . _debug ( ` error processing line. Failed with error ${ err } ` ) ;
return '' ;
}
}
_getSpawnFileName ( ) {
if ( IS _WINDOWS ) {
if ( this . _isCmdFile ( ) ) {
return process . env [ 'COMSPEC' ] || 'cmd.exe' ;
}
}
return this . toolPath ;
}
_getSpawnArgs ( options ) {
if ( IS _WINDOWS ) {
if ( this . _isCmdFile ( ) ) {
let argline = ` /D /S /C " ${ this . _windowsQuoteCmdArg ( this . toolPath ) } ` ;
for ( const a of this . args ) {
argline += ' ' ;
argline += options . windowsVerbatimArguments
? a
: this . _windowsQuoteCmdArg ( a ) ;
}
argline += '"' ;
return [ argline ] ;
}
}
return this . args ;
}
_endsWith ( str , end ) {
return str . endsWith ( end ) ;
}
_isCmdFile ( ) {
const upperToolPath = this . toolPath . toUpperCase ( ) ;
return ( this . _endsWith ( upperToolPath , '.CMD' ) ||
this . _endsWith ( upperToolPath , '.BAT' ) ) ;
}
_windowsQuoteCmdArg ( arg ) {
// for .exe, apply the normal quoting rules that libuv applies
if ( ! this . _isCmdFile ( ) ) {
return this . _uvQuoteCmdArg ( arg ) ;
}
// otherwise apply quoting rules specific to the cmd.exe command line parser.
// the libuv rules are generic and are not designed specifically for cmd.exe
// command line parser.
//
// for a detailed description of the cmd.exe command line parser, refer to
// http://stackoverflow.com/questions/4094699/how-does-the-windows-command-interpreter-cmd-exe-parse-scripts/7970912#7970912
// need quotes for empty arg
if ( ! arg ) {
return '""' ;
}
// determine whether the arg needs to be quoted
const cmdSpecialChars = [
' ' ,
'\t' ,
'&' ,
'(' ,
')' ,
'[' ,
']' ,
'{' ,
'}' ,
'^' ,
'=' ,
';' ,
'!' ,
"'" ,
'+' ,
',' ,
'`' ,
'~' ,
'|' ,
'<' ,
'>' ,
'"'
] ;
let needsQuotes = false ;
for ( const char of arg ) {
if ( cmdSpecialChars . some ( x => x === char ) ) {
needsQuotes = true ;
break ;
}
}
// short-circuit if quotes not needed
if ( ! needsQuotes ) {
return arg ;
}
// the following quoting rules are very similar to the rules that by libuv applies.
//
// 1) wrap the string in quotes
//
// 2) double-up quotes - i.e. " => ""
//
// this is different from the libuv quoting rules. libuv replaces " with \", which unfortunately
// doesn't work well with a cmd.exe command line.
//
// note, replacing " with "" also works well if the arg is passed to a downstream .NET console app.
// for example, the command line:
// foo.exe "myarg:""my val"""
// is parsed by a .NET console app into an arg array:
// [ "myarg:\"my val\"" ]
// which is the same end result when applying libuv quoting rules. although the actual
// command line from libuv quoting rules would look like:
// foo.exe "myarg:\"my val\""
//
// 3) double-up slashes that precede a quote,
// e.g. hello \world => "hello \world"
// hello\"world => "hello\\""world"
// hello\\"world => "hello\\\\""world"
// hello world\ => "hello world\\"
//
// technically this is not required for a cmd.exe command line, or the batch argument parser.
// the reasons for including this as a .cmd quoting rule are:
//
// a) this is optimized for the scenario where the argument is passed from the .cmd file to an
// external program. many programs (e.g. .NET console apps) rely on the slash-doubling rule.
//
// b) it's what we've been doing previously (by deferring to node default behavior) and we
// haven't heard any complaints about that aspect.
//
// note, a weakness of the quoting rules chosen here, is that % is not escaped. in fact, % cannot be
// escaped when used on the command line directly - even though within a .cmd file % can be escaped
// by using %%.
//
// the saving grace is, on the command line, %var% is left as-is if var is not defined. this contrasts
// the line parsing rules within a .cmd file, where if var is not defined it is replaced with nothing.
//
// one option that was explored was replacing % with ^% - i.e. %var% => ^%var^%. this hack would
// often work, since it is unlikely that var^ would exist, and the ^ character is removed when the
// variable is used. the problem, however, is that ^ is not removed when %* is used to pass the args
// to an external program.
//
// an unexplored potential solution for the % escaping problem, is to create a wrapper .cmd file.
// % can be escaped within a .cmd file.
let reverse = '"' ;
let quoteHit = true ;
for ( let i = arg . length ; i > 0 ; i -- ) {
// walk the string in reverse
reverse += arg [ i - 1 ] ;
if ( quoteHit && arg [ i - 1 ] === '\\' ) {
reverse += '\\' ; // double the slash
}
else if ( arg [ i - 1 ] === '"' ) {
quoteHit = true ;
reverse += '"' ; // double the quote
}
else {
quoteHit = false ;
}
}
reverse += '"' ;
return reverse
. split ( '' )
. reverse ( )
. join ( '' ) ;
}
_uvQuoteCmdArg ( arg ) {
// Tool runner wraps child_process.spawn() and needs to apply the same quoting as
// Node in certain cases where the undocumented spawn option windowsVerbatimArguments
// is used.
//
// Since this function is a port of quote_cmd_arg from Node 4.x (technically, lib UV,
// see https://github.com/nodejs/node/blob/v4.x/deps/uv/src/win/process.c for details),
// pasting copyright notice from Node within this function:
//
// Copyright Joyent, Inc. and other Node contributors. All rights reserved.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to
// deal in the Software without restriction, including without limitation the
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
// sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
// IN THE SOFTWARE.
if ( ! arg ) {
// Need double quotation for empty argument
return '""' ;
}
if ( ! arg . includes ( ' ' ) && ! arg . includes ( '\t' ) && ! arg . includes ( '"' ) ) {
// No quotation needed
return arg ;
}
if ( ! arg . includes ( '"' ) && ! arg . includes ( '\\' ) ) {
// No embedded double quotes or backslashes, so I can just wrap
// quote marks around the whole thing.
return ` " ${ arg } " ` ;
}
// Expected input/output:
// input : hello"world
// output: "hello\"world"
// input : hello""world
// output: "hello\"\"world"
// input : hello\world
// output: hello\world
// input : hello\\world
// output: hello\\world
// input : hello\"world
// output: "hello\\\"world"
// input : hello\\"world
// output: "hello\\\\\"world"
// input : hello world\
// output: "hello world\\" - note the comment in libuv actually reads "hello world\"
// but it appears the comment is wrong, it should be "hello world\\"
let reverse = '"' ;
let quoteHit = true ;
for ( let i = arg . length ; i > 0 ; i -- ) {
// walk the string in reverse
reverse += arg [ i - 1 ] ;
if ( quoteHit && arg [ i - 1 ] === '\\' ) {
reverse += '\\' ;
}
else if ( arg [ i - 1 ] === '"' ) {
quoteHit = true ;
reverse += '\\' ;
}
else {
quoteHit = false ;
}
}
reverse += '"' ;
return reverse
. split ( '' )
. reverse ( )
. join ( '' ) ;
}
_cloneExecOptions ( options ) {
options = options || { } ;
const result = {
cwd : options . cwd || process . cwd ( ) ,
env : options . env || process . env ,
silent : options . silent || false ,
windowsVerbatimArguments : options . windowsVerbatimArguments || false ,
failOnStdErr : options . failOnStdErr || false ,
ignoreReturnCode : options . ignoreReturnCode || false ,
delay : options . delay || 10000
} ;
result . outStream = options . outStream || process . stdout ;
result . errStream = options . errStream || process . stderr ;
return result ;
}
_getSpawnOptions ( options , toolPath ) {
options = options || { } ;
const result = { } ;
result . cwd = options . cwd ;
result . env = options . env ;
result [ 'windowsVerbatimArguments' ] =
options . windowsVerbatimArguments || this . _isCmdFile ( ) ;
if ( options . windowsVerbatimArguments ) {
result . argv0 = ` " ${ toolPath } " ` ;
}
return result ;
}
/ * *
* Exec a tool .
* Output will be streamed to the live console .
* Returns promise with return code
*
* @ param tool path to tool to exec
* @ param options optional exec options . See ExecOptions
* @ returns number
* /
exec ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
// root the tool path if it is unrooted and contains relative pathing
if ( ! ioUtil . isRooted ( this . toolPath ) &&
( this . toolPath . includes ( '/' ) ||
( IS _WINDOWS && this . toolPath . includes ( '\\' ) ) ) ) {
// prefer options.cwd if it is specified, however options.cwd may also need to be rooted
this . toolPath = path . resolve ( process . cwd ( ) , this . options . cwd || process . cwd ( ) , this . toolPath ) ;
}
// if the tool is only a file name, then resolve it from the PATH
// otherwise verify it exists (add extension on Windows if necessary)
this . toolPath = yield io . which ( this . toolPath , true ) ;
return new Promise ( ( resolve , reject ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
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 ) ;
} ) ;
if ( this . options . cwd && ! ( yield ioUtil . exists ( this . options . cwd ) ) ) {
return reject ( new Error ( ` The cwd: ${ this . options . cwd } does not exist! ` ) ) ;
}
const fileName = this . _getSpawnFileName ( ) ;
const cp = child . spawn ( fileName , this . _getSpawnArgs ( optionsNonNull ) , this . _getSpawnOptions ( this . options , fileName ) ) ;
let 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 ) ;
}
stdbuffer = this . _processLineBuffer ( data , stdbuffer , ( line ) => {
if ( this . options . listeners && this . options . listeners . stdline ) {
this . options . listeners . stdline ( line ) ;
}
} ) ;
} ) ;
}
let 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 ) ;
}
errbuffer = 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 ) ;
}
} ) ) ;
} ) ;
}
}
exports . ToolRunner = ToolRunner ;
/ * *
* Convert an arg string to an array of args . Handles escaping
*
* @ param argString string of arguments
* @ returns string [ ] array of arguments
* /
function argStringToArray ( argString ) {
const args = [ ] ;
let inQuotes = false ;
let escaped = false ;
let arg = '' ;
function append ( c ) {
// we only escape double quotes.
if ( escaped && c !== '"' ) {
arg += '\\' ;
}
arg += c ;
escaped = false ;
}
for ( let i = 0 ; i < argString . length ; i ++ ) {
const c = argString . charAt ( i ) ;
if ( c === '"' ) {
if ( ! escaped ) {
inQuotes = ! inQuotes ;
}
else {
append ( c ) ;
}
continue ;
}
if ( c === '\\' && escaped ) {
append ( c ) ;
continue ;
}
if ( c === '\\' && inQuotes ) {
escaped = true ;
continue ;
}
if ( c === ' ' && ! inQuotes ) {
if ( arg . length > 0 ) {
args . push ( arg ) ;
arg = '' ;
}
continue ;
}
append ( c ) ;
}
if ( arg . length > 0 ) {
args . push ( arg . trim ( ) ) ;
}
return args ;
}
exports . argStringToArray = argStringToArray ;
class ExecState extends events . EventEmitter {
constructor ( options , toolPath ) {
super ( ) ;
this . processClosed = false ; // tracks whether the process has exited and stdio is closed
this . processError = '' ;
this . processExitCode = 0 ;
this . processExited = false ; // tracks whether the process has exited
this . processStderr = false ; // tracks whether stderr was written to
this . delay = 10000 ; // 10 seconds
this . done = false ;
this . timeout = null ;
if ( ! toolPath ) {
throw new Error ( 'toolPath must not be empty' ) ;
}
this . options = options ;
this . toolPath = toolPath ;
if ( options . delay ) {
this . delay = options . delay ;
}
}
CheckComplete ( ) {
if ( this . done ) {
return ;
}
if ( this . processClosed ) {
this . _setResult ( ) ;
}
else if ( this . processExited ) {
this . timeout = timers _1 . setTimeout ( ExecState . HandleTimeout , this . delay , this ) ;
}
}
_debug ( message ) {
this . emit ( 'debug' , message ) ;
}
_setResult ( ) {
// determine whether there is an error
let error ;
if ( this . processExited ) {
if ( this . processError ) {
error = new Error ( ` There was an error when attempting to execute the process ' ${ this . toolPath } '. This may indicate the process failed to start. Error: ${ this . processError } ` ) ;
}
else if ( this . processExitCode !== 0 && ! this . options . ignoreReturnCode ) {
error = new Error ( ` The process ' ${ this . toolPath } ' failed with exit code ${ this . processExitCode } ` ) ;
}
else if ( this . processStderr && this . options . failOnStdErr ) {
error = new Error ( ` The process ' ${ this . toolPath } ' failed because one or more lines were written to the STDERR stream ` ) ;
}
}
// clear the timeout
if ( this . timeout ) {
clearTimeout ( this . timeout ) ;
this . timeout = null ;
}
this . done = true ;
this . emit ( 'done' , error , this . processExitCode ) ;
}
static HandleTimeout ( state ) {
if ( state . done ) {
return ;
}
if ( ! state . processClosed && state . processExited ) {
const message = ` The STDIO streams did not close within ${ state . delay /
1000 } seconds of the exit event from process '${state.toolPath}' . This may indicate a child process inherited the STDIO streams and has not yet exited . ` ;
state . _debug ( message ) ;
}
state . _setResult ( ) ;
}
}
//# sourceMappingURL=toolrunner.js.map
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 2834 :
/***/ ( function ( _ _unused _webpack _module , exports ) {
2022-06-27 14:17:15 -04:00
"use strict" ;
2022-07-11 13:48:02 -04: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 ( ) ) ;
} ) ;
} ;
2022-06-27 14:17:15 -04:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-07-11 13:48:02 -04:00
exports . PersonalAccessTokenCredentialHandler = exports . BearerCredentialHandler = exports . BasicCredentialHandler = void 0 ;
2022-06-27 14:17:15 -04:00
class BasicCredentialHandler {
constructor ( username , password ) {
this . username = username ;
this . password = password ;
}
prepareRequest ( options ) {
2022-07-11 13:48:02 -04:00
if ( ! options . headers ) {
throw Error ( 'The request has no headers' ) ;
}
options . headers [ 'Authorization' ] = ` Basic ${ Buffer . from ( ` ${ this . username } : ${ this . password } ` ) . toString ( 'base64' ) } ` ;
2022-06-27 14:17:15 -04:00
}
// This handler cannot handle 401
2022-07-11 13:48:02 -04:00
canHandleAuthentication ( ) {
2022-06-27 14:17:15 -04:00
return false ;
}
2022-07-11 13:48:02 -04:00
handleAuthentication ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
throw new Error ( 'not implemented' ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
}
exports . BasicCredentialHandler = BasicCredentialHandler ;
class BearerCredentialHandler {
constructor ( token ) {
this . token = token ;
}
// currently implements pre-authorization
// TODO: support preAuth = false where it hooks on 401
prepareRequest ( options ) {
2022-07-11 13:48:02 -04:00
if ( ! options . headers ) {
throw Error ( 'The request has no headers' ) ;
}
options . headers [ 'Authorization' ] = ` Bearer ${ this . token } ` ;
2022-06-27 14:17:15 -04:00
}
// This handler cannot handle 401
2022-07-11 13:48:02 -04:00
canHandleAuthentication ( ) {
2022-06-27 14:17:15 -04:00
return false ;
}
2022-07-11 13:48:02 -04:00
handleAuthentication ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
throw new Error ( 'not implemented' ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
}
exports . BearerCredentialHandler = BearerCredentialHandler ;
class PersonalAccessTokenCredentialHandler {
constructor ( token ) {
this . token = token ;
}
// currently implements pre-authorization
// TODO: support preAuth = false where it hooks on 401
prepareRequest ( options ) {
2022-07-11 13:48:02 -04:00
if ( ! options . headers ) {
throw Error ( 'The request has no headers' ) ;
}
options . headers [ 'Authorization' ] = ` Basic ${ Buffer . from ( ` PAT: ${ this . token } ` ) . toString ( 'base64' ) } ` ;
2022-06-27 14:17:15 -04:00
}
// This handler cannot handle 401
2022-07-11 13:48:02 -04:00
canHandleAuthentication ( ) {
2022-06-27 14:17:15 -04:00
return false ;
}
2022-07-11 13:48:02 -04:00
handleAuthentication ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
throw new Error ( 'not implemented' ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
}
exports . PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHandler ;
2022-07-11 13:48:02 -04:00
//# sourceMappingURL=auth.js.map
2022-06-27 14:17:15 -04:00
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 2745 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2022-06-27 14:17:15 -04:00
"use strict" ;
2022-07-11 13:48:02 -04:00
/* eslint-disable @typescript-eslint/no-explicit-any */
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
2022-06-27 14:17:15 -04:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-07-11 13:48:02 -04:00
exports . HttpClient = exports . isHttps = exports . HttpClientResponse = exports . HttpClientError = exports . getProxyUrl = exports . MediaTypes = exports . Headers = exports . HttpCodes = void 0 ;
const http = _ _importStar ( _ _nccwpck _require _ _ ( 3685 ) ) ;
const https = _ _importStar ( _ _nccwpck _require _ _ ( 5687 ) ) ;
const pm = _ _importStar ( _ _nccwpck _require _ _ ( 7307 ) ) ;
const tunnel = _ _importStar ( _ _nccwpck _require _ _ ( 9958 ) ) ;
2022-06-27 14:17:15 -04:00
var HttpCodes ;
( function ( HttpCodes ) {
HttpCodes [ HttpCodes [ "OK" ] = 200 ] = "OK" ;
HttpCodes [ HttpCodes [ "MultipleChoices" ] = 300 ] = "MultipleChoices" ;
HttpCodes [ HttpCodes [ "MovedPermanently" ] = 301 ] = "MovedPermanently" ;
HttpCodes [ HttpCodes [ "ResourceMoved" ] = 302 ] = "ResourceMoved" ;
HttpCodes [ HttpCodes [ "SeeOther" ] = 303 ] = "SeeOther" ;
HttpCodes [ HttpCodes [ "NotModified" ] = 304 ] = "NotModified" ;
HttpCodes [ HttpCodes [ "UseProxy" ] = 305 ] = "UseProxy" ;
HttpCodes [ HttpCodes [ "SwitchProxy" ] = 306 ] = "SwitchProxy" ;
HttpCodes [ HttpCodes [ "TemporaryRedirect" ] = 307 ] = "TemporaryRedirect" ;
HttpCodes [ HttpCodes [ "PermanentRedirect" ] = 308 ] = "PermanentRedirect" ;
HttpCodes [ HttpCodes [ "BadRequest" ] = 400 ] = "BadRequest" ;
HttpCodes [ HttpCodes [ "Unauthorized" ] = 401 ] = "Unauthorized" ;
HttpCodes [ HttpCodes [ "PaymentRequired" ] = 402 ] = "PaymentRequired" ;
HttpCodes [ HttpCodes [ "Forbidden" ] = 403 ] = "Forbidden" ;
HttpCodes [ HttpCodes [ "NotFound" ] = 404 ] = "NotFound" ;
HttpCodes [ HttpCodes [ "MethodNotAllowed" ] = 405 ] = "MethodNotAllowed" ;
HttpCodes [ HttpCodes [ "NotAcceptable" ] = 406 ] = "NotAcceptable" ;
HttpCodes [ HttpCodes [ "ProxyAuthenticationRequired" ] = 407 ] = "ProxyAuthenticationRequired" ;
HttpCodes [ HttpCodes [ "RequestTimeout" ] = 408 ] = "RequestTimeout" ;
HttpCodes [ HttpCodes [ "Conflict" ] = 409 ] = "Conflict" ;
HttpCodes [ HttpCodes [ "Gone" ] = 410 ] = "Gone" ;
HttpCodes [ HttpCodes [ "TooManyRequests" ] = 429 ] = "TooManyRequests" ;
HttpCodes [ HttpCodes [ "InternalServerError" ] = 500 ] = "InternalServerError" ;
HttpCodes [ HttpCodes [ "NotImplemented" ] = 501 ] = "NotImplemented" ;
HttpCodes [ HttpCodes [ "BadGateway" ] = 502 ] = "BadGateway" ;
HttpCodes [ HttpCodes [ "ServiceUnavailable" ] = 503 ] = "ServiceUnavailable" ;
HttpCodes [ HttpCodes [ "GatewayTimeout" ] = 504 ] = "GatewayTimeout" ;
} ) ( HttpCodes = exports . HttpCodes || ( exports . HttpCodes = { } ) ) ;
var Headers ;
( function ( Headers ) {
Headers [ "Accept" ] = "accept" ;
Headers [ "ContentType" ] = "content-type" ;
} ) ( Headers = exports . Headers || ( exports . Headers = { } ) ) ;
var MediaTypes ;
( function ( MediaTypes ) {
MediaTypes [ "ApplicationJson" ] = "application/json" ;
} ) ( MediaTypes = exports . MediaTypes || ( exports . MediaTypes = { } ) ) ;
/ * *
* Returns the proxy URL , depending upon the supplied url and proxy environment variables .
* @ param serverUrl The server URL where the request will be sent . For example , https : //api.github.com
* /
function getProxyUrl ( serverUrl ) {
2022-07-11 13:48:02 -04:00
const proxyUrl = pm . getProxyUrl ( new URL ( serverUrl ) ) ;
2022-06-27 14:17:15 -04:00
return proxyUrl ? proxyUrl . href : '' ;
}
exports . getProxyUrl = getProxyUrl ;
const HttpRedirectCodes = [
HttpCodes . MovedPermanently ,
HttpCodes . ResourceMoved ,
HttpCodes . SeeOther ,
HttpCodes . TemporaryRedirect ,
HttpCodes . PermanentRedirect
] ;
const HttpResponseRetryCodes = [
HttpCodes . BadGateway ,
HttpCodes . ServiceUnavailable ,
HttpCodes . GatewayTimeout
] ;
const RetryableHttpVerbs = [ 'OPTIONS' , 'GET' , 'DELETE' , 'HEAD' ] ;
const ExponentialBackoffCeiling = 10 ;
const ExponentialBackoffTimeSlice = 5 ;
class HttpClientError extends Error {
constructor ( message , statusCode ) {
super ( message ) ;
this . name = 'HttpClientError' ;
this . statusCode = statusCode ;
Object . setPrototypeOf ( this , HttpClientError . prototype ) ;
}
}
exports . HttpClientError = HttpClientError ;
class HttpClientResponse {
constructor ( message ) {
this . message = message ;
}
readBody ( ) {
2022-07-11 13:48:02 -04:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return new Promise ( ( resolve ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
let output = Buffer . alloc ( 0 ) ;
this . message . on ( 'data' , ( chunk ) => {
output = Buffer . concat ( [ output , chunk ] ) ;
} ) ;
this . message . on ( 'end' , ( ) => {
resolve ( output . toString ( ) ) ;
} ) ;
} ) ) ;
2022-06-27 14:17:15 -04:00
} ) ;
}
}
exports . HttpClientResponse = HttpClientResponse ;
function isHttps ( requestUrl ) {
2022-07-11 13:48:02 -04:00
const parsedUrl = new URL ( requestUrl ) ;
2022-06-27 14:17:15 -04:00
return parsedUrl . protocol === 'https:' ;
}
exports . isHttps = isHttps ;
class HttpClient {
constructor ( userAgent , handlers , requestOptions ) {
this . _ignoreSslError = false ;
this . _allowRedirects = true ;
this . _allowRedirectDowngrade = false ;
this . _maxRedirects = 50 ;
this . _allowRetries = false ;
this . _maxRetries = 1 ;
this . _keepAlive = false ;
this . _disposed = false ;
this . userAgent = userAgent ;
this . handlers = handlers || [ ] ;
this . requestOptions = requestOptions ;
if ( requestOptions ) {
if ( requestOptions . ignoreSslError != null ) {
this . _ignoreSslError = requestOptions . ignoreSslError ;
}
this . _socketTimeout = requestOptions . socketTimeout ;
if ( requestOptions . allowRedirects != null ) {
this . _allowRedirects = requestOptions . allowRedirects ;
}
if ( requestOptions . allowRedirectDowngrade != null ) {
this . _allowRedirectDowngrade = requestOptions . allowRedirectDowngrade ;
}
if ( requestOptions . maxRedirects != null ) {
this . _maxRedirects = Math . max ( requestOptions . maxRedirects , 0 ) ;
}
if ( requestOptions . keepAlive != null ) {
this . _keepAlive = requestOptions . keepAlive ;
}
if ( requestOptions . allowRetries != null ) {
this . _allowRetries = requestOptions . allowRetries ;
}
if ( requestOptions . maxRetries != null ) {
this . _maxRetries = requestOptions . maxRetries ;
}
}
}
options ( requestUrl , additionalHeaders ) {
2022-07-11 13:48:02 -04:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'OPTIONS' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
get ( requestUrl , additionalHeaders ) {
2022-07-11 13:48:02 -04:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'GET' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
del ( requestUrl , additionalHeaders ) {
2022-07-11 13:48:02 -04:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'DELETE' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
post ( requestUrl , data , additionalHeaders ) {
2022-07-11 13:48:02 -04:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'POST' , requestUrl , data , additionalHeaders || { } ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
patch ( requestUrl , data , additionalHeaders ) {
2022-07-11 13:48:02 -04:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'PATCH' , requestUrl , data , additionalHeaders || { } ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
put ( requestUrl , data , additionalHeaders ) {
2022-07-11 13:48:02 -04:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'PUT' , requestUrl , data , additionalHeaders || { } ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
head ( requestUrl , additionalHeaders ) {
2022-07-11 13:48:02 -04:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'HEAD' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
sendStream ( verb , requestUrl , stream , additionalHeaders ) {
2022-07-11 13:48:02 -04:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( verb , requestUrl , stream , additionalHeaders ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
/ * *
* Gets a typed object from an endpoint
* Be aware that not found returns a null . Other errors ( 4 xx , 5 xx ) reject the promise
* /
2022-07-11 13:48:02 -04:00
getJson ( requestUrl , additionalHeaders = { } ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
additionalHeaders [ Headers . Accept ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . Accept , MediaTypes . ApplicationJson ) ;
const res = yield this . get ( requestUrl , additionalHeaders ) ;
return this . _processResponse ( res , this . requestOptions ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
postJson ( requestUrl , obj , additionalHeaders = { } ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const data = JSON . stringify ( obj , null , 2 ) ;
additionalHeaders [ Headers . Accept ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . Accept , MediaTypes . ApplicationJson ) ;
additionalHeaders [ Headers . ContentType ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . ContentType , MediaTypes . ApplicationJson ) ;
const res = yield this . post ( requestUrl , data , additionalHeaders ) ;
return this . _processResponse ( res , this . requestOptions ) ;
} ) ;
}
putJson ( requestUrl , obj , additionalHeaders = { } ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const data = JSON . stringify ( obj , null , 2 ) ;
additionalHeaders [ Headers . Accept ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . Accept , MediaTypes . ApplicationJson ) ;
additionalHeaders [ Headers . ContentType ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . ContentType , MediaTypes . ApplicationJson ) ;
const res = yield this . put ( requestUrl , data , additionalHeaders ) ;
return this . _processResponse ( res , this . requestOptions ) ;
} ) ;
}
patchJson ( requestUrl , obj , additionalHeaders = { } ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const data = JSON . stringify ( obj , null , 2 ) ;
additionalHeaders [ Headers . Accept ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . Accept , MediaTypes . ApplicationJson ) ;
additionalHeaders [ Headers . ContentType ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . ContentType , MediaTypes . ApplicationJson ) ;
const res = yield this . patch ( requestUrl , data , additionalHeaders ) ;
return this . _processResponse ( res , this . requestOptions ) ;
} ) ;
}
/ * *
* Makes a raw http request .
* All other methods such as get , post , patch , and request ultimately call this .
* Prefer get , del , post and patch
* /
request ( verb , requestUrl , data , headers ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( this . _disposed ) {
throw new Error ( 'Client has already been disposed.' ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
const parsedUrl = new URL ( requestUrl ) ;
let info = this . _prepareRequest ( verb , parsedUrl , headers ) ;
// Only perform retries on reads since writes may not be idempotent.
const maxTries = this . _allowRetries && RetryableHttpVerbs . includes ( verb )
? this . _maxRetries + 1
: 1 ;
let numTries = 0 ;
let response ;
do {
response = yield this . requestRaw ( info , data ) ;
// Check if it's an authentication challenge
if ( response &&
response . message &&
response . message . statusCode === HttpCodes . Unauthorized ) {
let authenticationHandler ;
for ( const handler of this . handlers ) {
if ( handler . canHandleAuthentication ( response ) ) {
authenticationHandler = handler ;
break ;
}
}
if ( authenticationHandler ) {
return authenticationHandler . handleAuthentication ( this , info , data ) ;
}
else {
// We have received an unauthorized response but have no handlers to handle it.
// Let the response return to the caller.
return response ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
let redirectsRemaining = this . _maxRedirects ;
while ( response . message . statusCode &&
HttpRedirectCodes . includes ( response . message . statusCode ) &&
this . _allowRedirects &&
redirectsRemaining > 0 ) {
const redirectUrl = response . message . headers [ 'location' ] ;
if ( ! redirectUrl ) {
// if there's no location to redirect to, we won't
break ;
}
const parsedRedirectUrl = new URL ( redirectUrl ) ;
if ( parsedUrl . protocol === 'https:' &&
parsedUrl . protocol !== parsedRedirectUrl . protocol &&
! this . _allowRedirectDowngrade ) {
throw new Error ( 'Redirect from HTTPS to HTTP protocol. This downgrade is not allowed for security reasons. If you want to allow this behavior, set the allowRedirectDowngrade option to true.' ) ;
}
// we need to finish reading the response before reassigning response
// which will leak the open socket.
yield response . readBody ( ) ;
// strip authorization header if redirected to a different hostname
if ( parsedRedirectUrl . hostname !== parsedUrl . hostname ) {
for ( const header in headers ) {
// header names are case insensitive
if ( header . toLowerCase ( ) === 'authorization' ) {
delete headers [ header ] ;
}
2022-06-27 14:17:15 -04:00
}
}
2022-07-11 13:48:02 -04:00
// let's make the request with the new redirectUrl
info = this . _prepareRequest ( verb , parsedRedirectUrl , headers ) ;
response = yield this . requestRaw ( info , data ) ;
redirectsRemaining -- ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
if ( ! response . message . statusCode ||
! HttpResponseRetryCodes . includes ( response . message . statusCode ) ) {
// If not a retry code, return immediately instead of retrying
return response ;
}
numTries += 1 ;
if ( numTries < maxTries ) {
yield response . readBody ( ) ;
yield this . _performExponentialBackoff ( numTries ) ;
}
} while ( numTries < maxTries ) ;
return response ;
} ) ;
2022-06-27 14:17:15 -04:00
}
/ * *
* Needs to be called if keepAlive is set to true in request options .
* /
dispose ( ) {
if ( this . _agent ) {
this . _agent . destroy ( ) ;
}
this . _disposed = true ;
}
/ * *
* Raw request .
* @ param info
* @ param data
* /
requestRaw ( info , data ) {
2022-07-11 13:48:02 -04:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return new Promise ( ( resolve , reject ) => {
function callbackForResult ( err , res ) {
if ( err ) {
reject ( err ) ;
}
else if ( ! res ) {
// If `err` is not passed, then `res` must be passed.
reject ( new Error ( 'Unknown error' ) ) ;
}
else {
resolve ( res ) ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
this . requestRawWithCallback ( info , data , callbackForResult ) ;
} ) ;
2022-06-27 14:17:15 -04:00
} ) ;
}
/ * *
* Raw request with callback .
* @ param info
* @ param data
* @ param onResult
* /
requestRawWithCallback ( info , data , onResult ) {
if ( typeof data === 'string' ) {
2022-07-11 13:48:02 -04:00
if ( ! info . options . headers ) {
info . options . headers = { } ;
}
2022-06-27 14:17:15 -04:00
info . options . headers [ 'Content-Length' ] = Buffer . byteLength ( data , 'utf8' ) ;
}
let callbackCalled = false ;
2022-07-11 13:48:02 -04:00
function handleResult ( err , res ) {
2022-06-27 14:17:15 -04:00
if ( ! callbackCalled ) {
callbackCalled = true ;
onResult ( err , res ) ;
}
2022-07-11 13:48:02 -04:00
}
const req = info . httpModule . request ( info . options , ( msg ) => {
const res = new HttpClientResponse ( msg ) ;
handleResult ( undefined , res ) ;
2022-06-27 14:17:15 -04:00
} ) ;
2022-07-11 13:48:02 -04:00
let socket ;
2022-06-27 14:17:15 -04:00
req . on ( 'socket' , sock => {
socket = sock ;
} ) ;
// If we ever get disconnected, we want the socket to timeout eventually
req . setTimeout ( this . _socketTimeout || 3 * 60000 , ( ) => {
if ( socket ) {
socket . end ( ) ;
}
2022-07-11 13:48:02 -04:00
handleResult ( new Error ( ` Request timeout: ${ info . options . path } ` ) ) ;
2022-06-27 14:17:15 -04:00
} ) ;
req . on ( 'error' , function ( err ) {
// err has statusCode property
// res should have headers
2022-07-11 13:48:02 -04:00
handleResult ( err ) ;
2022-06-27 14:17:15 -04:00
} ) ;
if ( data && typeof data === 'string' ) {
req . write ( data , 'utf8' ) ;
}
if ( data && typeof data !== 'string' ) {
data . on ( 'close' , function ( ) {
req . end ( ) ;
} ) ;
data . pipe ( req ) ;
}
else {
req . end ( ) ;
}
}
/ * *
* Gets an http agent . This function is useful when you need an http agent that handles
* routing through a proxy server - depending upon the url and proxy environment variables .
* @ param serverUrl The server URL where the request will be sent . For example , https : //api.github.com
* /
getAgent ( serverUrl ) {
2022-07-11 13:48:02 -04:00
const parsedUrl = new URL ( serverUrl ) ;
2022-06-27 14:17:15 -04:00
return this . _getAgent ( parsedUrl ) ;
}
_prepareRequest ( method , requestUrl , headers ) {
const info = { } ;
info . parsedUrl = requestUrl ;
const usingSsl = info . parsedUrl . protocol === 'https:' ;
info . httpModule = usingSsl ? https : http ;
const defaultPort = usingSsl ? 443 : 80 ;
info . options = { } ;
info . options . host = info . parsedUrl . hostname ;
info . options . port = info . parsedUrl . port
? parseInt ( info . parsedUrl . port )
: defaultPort ;
info . options . path =
( info . parsedUrl . pathname || '' ) + ( info . parsedUrl . search || '' ) ;
info . options . method = method ;
info . options . headers = this . _mergeHeaders ( headers ) ;
if ( this . userAgent != null ) {
info . options . headers [ 'user-agent' ] = this . userAgent ;
}
info . options . agent = this . _getAgent ( info . parsedUrl ) ;
// gives handlers an opportunity to participate
if ( this . handlers ) {
2022-07-11 13:48:02 -04:00
for ( const handler of this . handlers ) {
2022-06-27 14:17:15 -04:00
handler . prepareRequest ( info . options ) ;
2022-07-11 13:48:02 -04:00
}
2022-06-27 14:17:15 -04:00
}
return info ;
}
_mergeHeaders ( headers ) {
if ( this . requestOptions && this . requestOptions . headers ) {
2022-07-11 13:48:02 -04:00
return Object . assign ( { } , lowercaseKeys ( this . requestOptions . headers ) , lowercaseKeys ( headers || { } ) ) ;
2022-06-27 14:17:15 -04:00
}
return lowercaseKeys ( headers || { } ) ;
}
_getExistingOrDefaultHeader ( additionalHeaders , header , _default ) {
let clientHeader ;
if ( this . requestOptions && this . requestOptions . headers ) {
clientHeader = lowercaseKeys ( this . requestOptions . headers ) [ header ] ;
}
return additionalHeaders [ header ] || clientHeader || _default ;
}
_getAgent ( parsedUrl ) {
let agent ;
2022-07-11 13:48:02 -04:00
const proxyUrl = pm . getProxyUrl ( parsedUrl ) ;
const useProxy = proxyUrl && proxyUrl . hostname ;
2022-06-27 14:17:15 -04:00
if ( this . _keepAlive && useProxy ) {
agent = this . _proxyAgent ;
}
if ( this . _keepAlive && ! useProxy ) {
agent = this . _agent ;
}
// if agent is already assigned use that agent.
2022-07-11 13:48:02 -04:00
if ( agent ) {
2022-06-27 14:17:15 -04:00
return agent ;
}
const usingSsl = parsedUrl . protocol === 'https:' ;
let maxSockets = 100 ;
2022-07-11 13:48:02 -04:00
if ( this . requestOptions ) {
2022-06-27 14:17:15 -04:00
maxSockets = this . requestOptions . maxSockets || http . globalAgent . maxSockets ;
}
2022-07-11 13:48:02 -04:00
// This is `useProxy` again, but we need to check `proxyURl` directly for TypeScripts's flow analysis.
if ( proxyUrl && proxyUrl . hostname ) {
2022-06-27 14:17:15 -04:00
const agentOptions = {
2022-07-11 13:48:02 -04:00
maxSockets ,
2022-06-27 14:17:15 -04:00
keepAlive : this . _keepAlive ,
2022-07-11 13:48:02 -04:00
proxy : Object . assign ( Object . assign ( { } , ( ( proxyUrl . username || proxyUrl . password ) && {
proxyAuth : ` ${ proxyUrl . username } : ${ proxyUrl . password } `
} ) ) , { host : proxyUrl . hostname , port : proxyUrl . port } )
2022-06-27 14:17:15 -04:00
} ;
let tunnelAgent ;
const overHttps = proxyUrl . protocol === 'https:' ;
if ( usingSsl ) {
tunnelAgent = overHttps ? tunnel . httpsOverHttps : tunnel . httpsOverHttp ;
}
else {
tunnelAgent = overHttps ? tunnel . httpOverHttps : tunnel . httpOverHttp ;
}
agent = tunnelAgent ( agentOptions ) ;
this . _proxyAgent = agent ;
}
// if reusing agent across request and tunneling agent isn't assigned create a new agent
if ( this . _keepAlive && ! agent ) {
2022-07-11 13:48:02 -04:00
const options = { keepAlive : this . _keepAlive , maxSockets } ;
2022-06-27 14:17:15 -04:00
agent = usingSsl ? new https . Agent ( options ) : new http . Agent ( options ) ;
this . _agent = agent ;
}
// if not using private agent and tunnel agent isn't setup then use global agent
if ( ! agent ) {
agent = usingSsl ? https . globalAgent : http . globalAgent ;
}
if ( usingSsl && this . _ignoreSslError ) {
// we don't want to set NODE_TLS_REJECT_UNAUTHORIZED=0 since that will affect request for entire process
// http.RequestOptions doesn't expose a way to modify RequestOptions.agent.options
// we have to cast it to any and change it directly
agent . options = Object . assign ( agent . options || { } , {
rejectUnauthorized : false
} ) ;
}
return agent ;
}
_performExponentialBackoff ( retryNumber ) {
2022-07-11 13:48:02 -04:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
retryNumber = Math . min ( ExponentialBackoffCeiling , retryNumber ) ;
const ms = ExponentialBackoffTimeSlice * Math . pow ( 2 , retryNumber ) ;
return new Promise ( resolve => setTimeout ( ( ) => resolve ( ) , ms ) ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
_processResponse ( res , options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return new Promise ( ( resolve , reject ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const statusCode = res . message . statusCode || 0 ;
const response = {
statusCode ,
result : null ,
headers : { }
} ;
// not found leads to null obj returned
if ( statusCode === HttpCodes . NotFound ) {
resolve ( response ) ;
}
// get the result from the body
function dateTimeDeserializer ( key , value ) {
if ( typeof value === 'string' ) {
const a = new Date ( value ) ;
if ( ! isNaN ( a . valueOf ( ) ) ) {
return a ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return value ;
}
let obj ;
let contents ;
try {
contents = yield res . readBody ( ) ;
if ( contents && contents . length > 0 ) {
if ( options && options . deserializeDates ) {
obj = JSON . parse ( contents , dateTimeDeserializer ) ;
}
else {
obj = JSON . parse ( contents ) ;
}
response . result = obj ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
response . headers = res . message . headers ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
catch ( err ) {
// Invalid resource (contents not json); leaving result obj null
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
// note that 3xx redirects are handled by the http layer.
if ( statusCode > 299 ) {
let msg ;
// if exception/error in body, attempt to get better error
if ( obj && obj . message ) {
msg = obj . message ;
}
else if ( contents && contents . length > 0 ) {
// it may be the case that the exception is in the body message as string
msg = contents ;
}
else {
msg = ` Failed request: ( ${ statusCode } ) ` ;
}
const err = new HttpClientError ( msg , statusCode ) ;
err . result = response . result ;
reject ( err ) ;
2022-06-27 14:17:15 -04:00
}
else {
2022-07-11 13:48:02 -04:00
resolve ( response ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
} ) ) ;
2022-06-27 14:17:15 -04:00
} ) ;
}
}
exports . HttpClient = HttpClient ;
2022-07-11 13:48:02 -04:00
const lowercaseKeys = ( obj ) => Object . keys ( obj ) . reduce ( ( c , k ) => ( ( c [ k . toLowerCase ( ) ] = obj [ k ] ) , c ) , { } ) ;
//# sourceMappingURL=index.js.map
2022-06-27 14:17:15 -04:00
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 7307 :
2022-06-27 14:17:15 -04:00
/***/ ( ( _ _unused _webpack _module , exports ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-07-11 13:48:02 -04:00
exports . checkBypass = exports . getProxyUrl = void 0 ;
2022-06-27 14:17:15 -04:00
function getProxyUrl ( reqUrl ) {
2022-07-11 13:48:02 -04:00
const usingSsl = reqUrl . protocol === 'https:' ;
2022-06-27 14:17:15 -04:00
if ( checkBypass ( reqUrl ) ) {
2022-07-11 13:48:02 -04:00
return undefined ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
const proxyVar = ( ( ) => {
if ( usingSsl ) {
return process . env [ 'https_proxy' ] || process . env [ 'HTTPS_PROXY' ] ;
}
else {
return process . env [ 'http_proxy' ] || process . env [ 'HTTP_PROXY' ] ;
}
} ) ( ) ;
if ( proxyVar ) {
return new URL ( proxyVar ) ;
2022-06-27 14:17:15 -04:00
}
else {
2022-07-11 13:48:02 -04:00
return undefined ;
2022-06-27 14:17:15 -04:00
}
}
exports . getProxyUrl = getProxyUrl ;
function checkBypass ( reqUrl ) {
if ( ! reqUrl . hostname ) {
return false ;
}
2022-07-11 13:48:02 -04:00
const noProxy = process . env [ 'no_proxy' ] || process . env [ 'NO_PROXY' ] || '' ;
2022-06-27 14:17:15 -04:00
if ( ! noProxy ) {
return false ;
}
// Determine the request port
let reqPort ;
if ( reqUrl . port ) {
reqPort = Number ( reqUrl . port ) ;
}
else if ( reqUrl . protocol === 'http:' ) {
reqPort = 80 ;
}
else if ( reqUrl . protocol === 'https:' ) {
reqPort = 443 ;
}
// Format the request hostname and hostname with port
2022-07-11 13:48:02 -04:00
const upperReqHosts = [ reqUrl . hostname . toUpperCase ( ) ] ;
2022-06-27 14:17:15 -04:00
if ( typeof reqPort === 'number' ) {
upperReqHosts . push ( ` ${ upperReqHosts [ 0 ] } : ${ reqPort } ` ) ;
}
// Compare request host against noproxy
2022-07-11 13:48:02 -04:00
for ( const upperNoProxyItem of noProxy
2022-06-27 14:17:15 -04:00
. split ( ',' )
. map ( x => x . trim ( ) . toUpperCase ( ) )
. filter ( x => x ) ) {
if ( upperReqHosts . some ( x => x === upperNoProxyItem ) ) {
return true ;
}
}
return false ;
}
exports . checkBypass = checkBypass ;
2022-07-11 13:48:02 -04:00
//# sourceMappingURL=proxy.js.map
2022-06-27 14:17:15 -04:00
/***/ } ) ,
/***/ 6120 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
var _a ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . getCmdPath = exports . tryGetExecutablePath = exports . isRooted = exports . isDirectory = exports . exists = exports . IS _WINDOWS = exports . unlink = exports . symlink = exports . stat = exports . rmdir = exports . rename = exports . readlink = exports . readdir = exports . mkdir = exports . lstat = exports . copyFile = exports . chmod = void 0 ;
const fs = _ _importStar ( _ _nccwpck _require _ _ ( 7147 ) ) ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 1017 ) ) ;
_a = fs . promises , exports . chmod = _a . chmod , exports . copyFile = _a . copyFile , exports . lstat = _a . lstat , exports . mkdir = _a . mkdir , exports . readdir = _a . readdir , exports . readlink = _a . readlink , exports . rename = _a . rename , exports . rmdir = _a . rmdir , exports . stat = _a . stat , exports . symlink = _a . symlink , exports . unlink = _a . unlink ;
exports . IS _WINDOWS = process . platform === 'win32' ;
function exists ( fsPath ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
try {
yield exports . stat ( fsPath ) ;
}
catch ( err ) {
if ( err . code === 'ENOENT' ) {
return false ;
}
throw err ;
}
return true ;
} ) ;
}
exports . exists = exists ;
function isDirectory ( fsPath , useStat = false ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const stats = useStat ? yield exports . stat ( fsPath ) : yield exports . lstat ( fsPath ) ;
return stats . isDirectory ( ) ;
} ) ;
}
exports . isDirectory = isDirectory ;
/ * *
* On OSX / Linux , true if path starts with '/' . On Windows , true for paths like :
* \ , \ hello , \ \ hello \ share , C : , and C : \ hello ( and corresponding alternate separator cases ) .
* /
function isRooted ( p ) {
p = normalizeSeparators ( p ) ;
if ( ! p ) {
throw new Error ( 'isRooted() parameter "p" cannot be empty' ) ;
}
if ( exports . IS _WINDOWS ) {
return ( p . startsWith ( '\\' ) || /^[A-Z]:/i . test ( p ) // e.g. \ or \hello or \\hello
) ; // e.g. C: or C:\hello
}
return p . startsWith ( '/' ) ;
}
exports . isRooted = isRooted ;
/ * *
* Best effort attempt to determine whether a file exists and is executable .
* @ param filePath file path to check
* @ param extensions additional file extensions to try
* @ return if file exists and is executable , returns the file path . otherwise empty string .
* /
function tryGetExecutablePath ( filePath , extensions ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
let stats = undefined ;
try {
// test file exists
stats = yield exports . stat ( filePath ) ;
}
catch ( err ) {
if ( err . code !== 'ENOENT' ) {
// eslint-disable-next-line no-console
console . log ( ` Unexpected error attempting to determine if executable file exists ' ${ filePath } ': ${ err } ` ) ;
}
}
if ( stats && stats . isFile ( ) ) {
if ( exports . IS _WINDOWS ) {
// on Windows, test for valid extension
const upperExt = path . extname ( filePath ) . toUpperCase ( ) ;
if ( extensions . some ( validExt => validExt . toUpperCase ( ) === upperExt ) ) {
return filePath ;
}
}
else {
if ( isUnixExecutable ( stats ) ) {
return filePath ;
}
}
}
// try each extension
const originalFilePath = filePath ;
for ( const extension of extensions ) {
filePath = originalFilePath + extension ;
stats = undefined ;
try {
stats = yield exports . stat ( filePath ) ;
}
catch ( err ) {
if ( err . code !== 'ENOENT' ) {
// eslint-disable-next-line no-console
console . log ( ` Unexpected error attempting to determine if executable file exists ' ${ filePath } ': ${ err } ` ) ;
}
}
if ( stats && stats . isFile ( ) ) {
if ( exports . IS _WINDOWS ) {
// preserve the case of the actual file (since an extension was appended)
try {
const directory = path . dirname ( filePath ) ;
const upperName = path . basename ( filePath ) . toUpperCase ( ) ;
for ( const actualName of yield exports . readdir ( directory ) ) {
if ( upperName === actualName . toUpperCase ( ) ) {
filePath = path . join ( directory , actualName ) ;
break ;
}
}
}
catch ( err ) {
// eslint-disable-next-line no-console
console . log ( ` Unexpected error attempting to determine the actual case of the file ' ${ filePath } ': ${ err } ` ) ;
}
return filePath ;
}
else {
if ( isUnixExecutable ( stats ) ) {
return filePath ;
}
}
}
}
return '' ;
} ) ;
}
exports . tryGetExecutablePath = tryGetExecutablePath ;
function normalizeSeparators ( p ) {
p = p || '' ;
if ( exports . IS _WINDOWS ) {
// convert slashes on Windows
p = p . replace ( /\//g , '\\' ) ;
// remove redundant slashes
return p . replace ( /\\\\+/g , '\\' ) ;
}
// remove redundant slashes
return p . replace ( /\/\/+/g , '/' ) ;
}
// on Mac/Linux, test the execute bit
// R W X R W X R W X
// 256 128 64 32 16 8 4 2 1
function isUnixExecutable ( stats ) {
return ( ( stats . mode & 1 ) > 0 ||
( ( stats . mode & 8 ) > 0 && stats . gid === process . getgid ( ) ) ||
( ( stats . mode & 64 ) > 0 && stats . uid === process . getuid ( ) ) ) ;
}
// Get the path of cmd.exe in windows
function getCmdPath ( ) {
var _a ;
return ( _a = process . env [ 'COMSPEC' ] ) !== null && _a !== void 0 ? _a : ` cmd.exe ` ;
}
exports . getCmdPath = getCmdPath ;
//# sourceMappingURL=io-util.js.map
/***/ } ) ,
/***/ 6202 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . findInPath = exports . which = exports . mkdirP = exports . rmRF = exports . mv = exports . cp = void 0 ;
const assert _1 = _ _nccwpck _require _ _ ( 9491 ) ;
const childProcess = _ _importStar ( _ _nccwpck _require _ _ ( 2081 ) ) ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 1017 ) ) ;
const util _1 = _ _nccwpck _require _ _ ( 3837 ) ;
const ioUtil = _ _importStar ( _ _nccwpck _require _ _ ( 6120 ) ) ;
const exec = util _1 . promisify ( childProcess . exec ) ;
const execFile = util _1 . promisify ( childProcess . execFile ) ;
/ * *
* 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 , copySourceDirectory } = 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 ( ) && copySourceDirectory
? 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.
// Check for invalid characters
// https://docs.microsoft.com/en-us/windows/win32/fileio/naming-a-file
if ( /[*"<>|]/ . test ( inputPath ) ) {
throw new Error ( 'File path must not contain `*`, `"`, `<`, `>` or `|` on Windows' ) ;
}
try {
const cmdPath = ioUtil . getCmdPath ( ) ;
if ( yield ioUtil . isDirectory ( inputPath , true ) ) {
yield exec ( ` ${ cmdPath } /s /c "rd /s /q "%inputPath%"" ` , {
env : { inputPath }
} ) ;
}
else {
yield exec ( ` ${ cmdPath } /s /c "del /f /a "%inputPath%"" ` , {
env : { 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 execFile ( ` 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 * ( ) {
assert _1 . ok ( fsPath , 'a path argument must be provided' ) ;
yield ioUtil . mkdir ( fsPath , { recursive : true } ) ;
} ) ;
}
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. ` ) ;
}
}
return result ;
}
const matches = yield findInPath ( tool ) ;
if ( matches && matches . length > 0 ) {
return matches [ 0 ] ;
}
return '' ;
} ) ;
}
exports . which = which ;
/ * *
* Returns a list of all occurrences of the given tool on the system path .
*
* @ returns Promise < string [ ] > the paths of the tool
* /
function findInPath ( tool ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( ! tool ) {
throw new Error ( "parameter 'tool' is required" ) ;
}
// 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 ( path . sep ) ) {
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 ) ;
}
}
}
// find all matches
const matches = [ ] ;
for ( const directory of directories ) {
const filePath = yield ioUtil . tryGetExecutablePath ( path . join ( directory , tool ) , extensions ) ;
if ( filePath ) {
matches . push ( filePath ) ;
}
}
return matches ;
} ) ;
}
exports . findInPath = findInPath ;
function readCopyOptions ( options ) {
const force = options . force == null ? true : options . force ;
const recursive = Boolean ( options . recursive ) ;
const copySourceDirectory = options . copySourceDirectory == null
? true
: Boolean ( options . copySourceDirectory ) ;
return { force , recursive , copySourceDirectory } ;
}
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
/***/ } ) ,
/***/ 3594 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _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 core = _ _nccwpck _require _ _ ( 6024 ) ;
const io = _ _nccwpck _require _ _ ( 6202 ) ;
const fs = _ _nccwpck _require _ _ ( 7147 ) ;
const os = _ _nccwpck _require _ _ ( 2037 ) ;
const path = _ _nccwpck _require _ _ ( 1017 ) ;
const httpm = _ _nccwpck _require _ _ ( 6566 ) ;
const semver = _ _nccwpck _require _ _ ( 1554 ) ;
const uuidV4 = _ _nccwpck _require _ _ ( 3902 ) ;
const exec _1 = _ _nccwpck _require _ _ ( 2423 ) ;
const assert _1 = _ _nccwpck _require _ _ ( 9491 ) ;
class HTTPError extends Error {
constructor ( httpStatusCode ) {
super ( ` Unexpected HTTP response: ${ httpStatusCode } ` ) ;
this . httpStatusCode = httpStatusCode ;
Object . setPrototypeOf ( this , new . target . prototype ) ;
}
}
exports . HTTPError = HTTPError ;
const IS _WINDOWS = process . platform === 'win32' ;
const userAgent = 'actions/tool-cache' ;
// On load grab temp directory and cache directory and remove them from env (currently don't want to expose this)
let tempDirectory = process . env [ 'RUNNER_TEMP' ] || '' ;
let cacheRoot = process . env [ 'RUNNER_TOOL_CACHE' ] || '' ;
// If directories not found, place them in common temp locations
if ( ! tempDirectory || ! cacheRoot ) {
let baseLocation ;
if ( IS _WINDOWS ) {
// On windows use the USERPROFILE env variable
baseLocation = process . env [ 'USERPROFILE' ] || 'C:\\' ;
}
else {
if ( process . platform === 'darwin' ) {
baseLocation = '/Users' ;
}
else {
baseLocation = '/home' ;
}
}
if ( ! tempDirectory ) {
tempDirectory = path . join ( baseLocation , 'actions' , 'temp' ) ;
}
if ( ! cacheRoot ) {
cacheRoot = path . join ( baseLocation , 'actions' , 'cache' ) ;
}
}
/ * *
* Download a tool from an url and stream it into a file
*
* @ param url url of tool to download
* @ returns path to downloaded tool
* /
function downloadTool ( url ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
// Wrap in a promise so that we can resolve from within stream callbacks
return new Promise ( ( resolve , reject ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
try {
const http = new httpm . HttpClient ( userAgent , [ ] , {
allowRetries : true ,
maxRetries : 3
} ) ;
const destPath = path . join ( tempDirectory , uuidV4 ( ) ) ;
yield io . mkdirP ( tempDirectory ) ;
core . debug ( ` Downloading ${ url } ` ) ;
core . debug ( ` Downloading ${ destPath } ` ) ;
if ( fs . existsSync ( destPath ) ) {
throw new Error ( ` Destination file path ${ destPath } already exists ` ) ;
}
const response = yield http . get ( url ) ;
if ( response . message . statusCode !== 200 ) {
const err = new HTTPError ( response . message . statusCode ) ;
core . debug ( ` Failed to download from " ${ url } ". Code( ${ response . message . statusCode } ) Message( ${ response . message . statusMessage } ) ` ) ;
throw err ;
}
const file = fs . createWriteStream ( destPath ) ;
file . on ( 'open' , ( ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
try {
const stream = response . message . pipe ( file ) ;
stream . on ( 'close' , ( ) => {
core . debug ( 'download complete' ) ;
resolve ( destPath ) ;
} ) ;
}
catch ( err ) {
core . debug ( ` Failed to download from " ${ url } ". Code( ${ response . message . statusCode } ) Message( ${ response . message . statusMessage } ) ` ) ;
reject ( err ) ;
}
} ) ) ;
file . on ( 'error' , err => {
file . end ( ) ;
reject ( err ) ;
} ) ;
}
catch ( err ) {
reject ( err ) ;
}
} ) ) ;
} ) ;
}
exports . downloadTool = downloadTool ;
/ * *
* Extract a . 7 z file
*
* @ param file path to the . 7 z file
* @ param dest destination directory . Optional .
* @ param _7zPath path to 7 zr . exe . Optional , for long path support . Most . 7 z archives do not have this
* problem . If your . 7 z archive contains very long paths , you can pass the path to 7 zr . exe which will
* gracefully handle long paths . By default 7 zdec . exe is used because it is a very small program and is
* bundled with the tool lib . However it does not support long paths . 7 zr . exe is the reduced command line
* interface , it is smaller than the full command line interface , and it does support long paths . At the
* time of this writing , it is freely available from the LZMA SDK that is available on the 7 zip website .
* Be sure to check the current license agreement . If 7 zr . exe is bundled with your action , then the path
* to 7 zr . exe can be pass to this function .
* @ returns path to the destination directory
* /
function extract7z ( file , dest , _7zPath ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
assert _1 . ok ( IS _WINDOWS , 'extract7z() not supported on current OS' ) ;
assert _1 . ok ( file , 'parameter "file" is required' ) ;
dest = dest || ( yield _createExtractFolder ( dest ) ) ;
const originalCwd = process . cwd ( ) ;
process . chdir ( dest ) ;
if ( _7zPath ) {
try {
const args = [
'x' ,
'-bb1' ,
'-bd' ,
'-sccUTF-8' ,
file
] ;
const options = {
silent : true
} ;
yield exec _1 . exec ( ` " ${ _7zPath } " ` , args , options ) ;
}
finally {
process . chdir ( originalCwd ) ;
}
}
else {
const escapedScript = path
. join ( _ _dirname , '..' , 'scripts' , 'Invoke-7zdec.ps1' )
. replace ( /'/g , "''" )
. replace ( /"|\n|\r/g , '' ) ; // double-up single quotes, remove double quotes and newlines
const escapedFile = file . replace ( /'/g , "''" ) . replace ( /"|\n|\r/g , '' ) ;
const escapedTarget = dest . replace ( /'/g , "''" ) . replace ( /"|\n|\r/g , '' ) ;
const command = ` & ' ${ escapedScript } ' -Source ' ${ escapedFile } ' -Target ' ${ escapedTarget } ' ` ;
const args = [
'-NoLogo' ,
'-Sta' ,
'-NoProfile' ,
'-NonInteractive' ,
'-ExecutionPolicy' ,
'Unrestricted' ,
'-Command' ,
command
] ;
const options = {
silent : true
} ;
try {
const powershellPath = yield io . which ( 'powershell' , true ) ;
yield exec _1 . exec ( ` " ${ powershellPath } " ` , args , options ) ;
}
finally {
process . chdir ( originalCwd ) ;
}
}
return dest ;
} ) ;
}
exports . extract7z = extract7z ;
/ * *
* Extract a tar
*
* @ param file path to the tar
* @ param dest destination directory . Optional .
* @ param flags flags for the tar . Optional .
* @ returns path to the destination directory
* /
function extractTar ( file , dest , flags = 'xz' ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( ! file ) {
throw new Error ( "parameter 'file' is required" ) ;
}
dest = dest || ( yield _createExtractFolder ( dest ) ) ;
const tarPath = yield io . which ( 'tar' , true ) ;
yield exec _1 . exec ( ` " ${ tarPath } " ` , [ flags , '-C' , dest , '-f' , file ] ) ;
return dest ;
} ) ;
}
exports . extractTar = extractTar ;
/ * *
* Extract a zip
*
* @ param file path to the zip
* @ param dest destination directory . Optional .
* @ returns path to the destination directory
* /
function extractZip ( file , dest ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( ! file ) {
throw new Error ( "parameter 'file' is required" ) ;
}
dest = dest || ( yield _createExtractFolder ( dest ) ) ;
if ( IS _WINDOWS ) {
yield extractZipWin ( file , dest ) ;
}
else {
yield extractZipNix ( file , dest ) ;
}
return dest ;
} ) ;
}
exports . extractZip = extractZip ;
function extractZipWin ( file , dest ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
// build the powershell command
const escapedFile = file . replace ( /'/g , "''" ) . replace ( /"|\n|\r/g , '' ) ; // double-up single quotes, remove double quotes and newlines
const escapedDest = dest . replace ( /'/g , "''" ) . replace ( /"|\n|\r/g , '' ) ;
const command = ` $ ErrorActionPreference = 'Stop' ; try { Add-Type -AssemblyName System.IO.Compression.FileSystem } catch { } ; [System.IO.Compression.ZipFile]::ExtractToDirectory(' ${ escapedFile } ', ' ${ escapedDest } ') ` ;
// run powershell
const powershellPath = yield io . which ( 'powershell' ) ;
const args = [
'-NoLogo' ,
'-Sta' ,
'-NoProfile' ,
'-NonInteractive' ,
'-ExecutionPolicy' ,
'Unrestricted' ,
'-Command' ,
command
] ;
yield exec _1 . exec ( ` " ${ powershellPath } " ` , args ) ;
} ) ;
}
function extractZipNix ( file , dest ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const unzipPath = yield io . which ( 'unzip' ) ;
yield exec _1 . exec ( ` " ${ unzipPath } " ` , [ file ] , { cwd : dest } ) ;
} ) ;
}
/ * *
* Caches a directory and installs it into the tool cacheDir
*
* @ param sourceDir the directory to cache into tools
* @ param tool tool name
* @ param version version of the tool . semver format
* @ param arch architecture of the tool . Optional . Defaults to machine architecture
* /
function cacheDir ( sourceDir , tool , version , arch ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
version = semver . clean ( version ) || version ;
arch = arch || os . arch ( ) ;
core . debug ( ` Caching tool ${ tool } ${ version } ${ arch } ` ) ;
core . debug ( ` source dir: ${ sourceDir } ` ) ;
if ( ! fs . statSync ( sourceDir ) . isDirectory ( ) ) {
throw new Error ( 'sourceDir is not a directory' ) ;
}
// Create the tool dir
const destPath = yield _createToolPath ( tool , version , arch ) ;
// copy each child item. do not move. move can fail on Windows
// due to anti-virus software having an open handle on a file.
for ( const itemName of fs . readdirSync ( sourceDir ) ) {
const s = path . join ( sourceDir , itemName ) ;
yield io . cp ( s , destPath , { recursive : true } ) ;
}
// write .complete
_completeToolPath ( tool , version , arch ) ;
return destPath ;
} ) ;
}
exports . cacheDir = cacheDir ;
/ * *
* Caches a downloaded file ( GUID ) and installs it
* into the tool cache with a given targetName
*
* @ param sourceFile the file to cache into tools . Typically a result of downloadTool which is a guid .
* @ param targetFile the name of the file name in the tools directory
* @ param tool tool name
* @ param version version of the tool . semver format
* @ param arch architecture of the tool . Optional . Defaults to machine architecture
* /
function cacheFile ( sourceFile , targetFile , tool , version , arch ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
version = semver . clean ( version ) || version ;
arch = arch || os . arch ( ) ;
core . debug ( ` Caching tool ${ tool } ${ version } ${ arch } ` ) ;
core . debug ( ` source file: ${ sourceFile } ` ) ;
if ( ! fs . statSync ( sourceFile ) . isFile ( ) ) {
throw new Error ( 'sourceFile is not a file' ) ;
}
// create the tool dir
const destFolder = yield _createToolPath ( tool , version , arch ) ;
// copy instead of move. move can fail on Windows due to
// anti-virus software having an open handle on a file.
const destPath = path . join ( destFolder , targetFile ) ;
core . debug ( ` destination file ${ destPath } ` ) ;
yield io . cp ( sourceFile , destPath ) ;
// write .complete
_completeToolPath ( tool , version , arch ) ;
return destFolder ;
} ) ;
}
exports . cacheFile = cacheFile ;
/ * *
* Finds the path to a tool version in the local installed tool cache
*
* @ param toolName name of the tool
* @ param versionSpec version of the tool
* @ param arch optional arch . defaults to arch of computer
* /
function find ( toolName , versionSpec , arch ) {
if ( ! toolName ) {
throw new Error ( 'toolName parameter is required' ) ;
}
if ( ! versionSpec ) {
throw new Error ( 'versionSpec parameter is required' ) ;
}
arch = arch || os . arch ( ) ;
// attempt to resolve an explicit version
if ( ! _isExplicitVersion ( versionSpec ) ) {
const localVersions = findAllVersions ( toolName , arch ) ;
const match = _evaluateVersions ( localVersions , versionSpec ) ;
versionSpec = match ;
}
// check for the explicit version in the cache
let toolPath = '' ;
if ( versionSpec ) {
versionSpec = semver . clean ( versionSpec ) || '' ;
const cachePath = path . join ( cacheRoot , toolName , versionSpec , arch ) ;
core . debug ( ` checking cache: ${ cachePath } ` ) ;
if ( fs . existsSync ( cachePath ) && fs . existsSync ( ` ${ cachePath } .complete ` ) ) {
core . debug ( ` Found tool in cache ${ toolName } ${ versionSpec } ${ arch } ` ) ;
toolPath = cachePath ;
}
else {
core . debug ( 'not found' ) ;
}
}
return toolPath ;
}
exports . find = find ;
/ * *
* Finds the paths to all versions of a tool that are installed in the local tool cache
*
* @ param toolName name of the tool
* @ param arch optional arch . defaults to arch of computer
* /
function findAllVersions ( toolName , arch ) {
const versions = [ ] ;
arch = arch || os . arch ( ) ;
const toolPath = path . join ( cacheRoot , toolName ) ;
if ( fs . existsSync ( toolPath ) ) {
const children = fs . readdirSync ( toolPath ) ;
for ( const child of children ) {
if ( _isExplicitVersion ( child ) ) {
const fullPath = path . join ( toolPath , child , arch || '' ) ;
if ( fs . existsSync ( fullPath ) && fs . existsSync ( ` ${ fullPath } .complete ` ) ) {
versions . push ( child ) ;
}
}
}
}
return versions ;
}
exports . findAllVersions = findAllVersions ;
function _createExtractFolder ( dest ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( ! dest ) {
// create a temp dir
dest = path . join ( tempDirectory , uuidV4 ( ) ) ;
}
yield io . mkdirP ( dest ) ;
return dest ;
} ) ;
}
function _createToolPath ( tool , version , arch ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const folderPath = path . join ( cacheRoot , tool , semver . clean ( version ) || version , arch || '' ) ;
core . debug ( ` destination ${ folderPath } ` ) ;
const markerPath = ` ${ folderPath } .complete ` ;
yield io . rmRF ( folderPath ) ;
yield io . rmRF ( markerPath ) ;
yield io . mkdirP ( folderPath ) ;
return folderPath ;
} ) ;
}
function _completeToolPath ( tool , version , arch ) {
const folderPath = path . join ( cacheRoot , tool , semver . clean ( version ) || version , arch || '' ) ;
const markerPath = ` ${ folderPath } .complete ` ;
fs . writeFileSync ( markerPath , '' ) ;
core . debug ( 'finished caching tool' ) ;
}
function _isExplicitVersion ( versionSpec ) {
const c = semver . clean ( versionSpec ) || '' ;
core . debug ( ` isExplicit: ${ c } ` ) ;
const valid = semver . valid ( c ) != null ;
core . debug ( ` explicit? ${ valid } ` ) ;
return valid ;
}
function _evaluateVersions ( versions , versionSpec ) {
let version = '' ;
core . debug ( ` evaluating ${ versions . length } versions ` ) ;
versions = versions . sort ( ( a , b ) => {
if ( semver . gt ( a , b ) ) {
return 1 ;
}
return - 1 ;
} ) ;
for ( let i = versions . length - 1 ; i >= 0 ; i -- ) {
const potential = versions [ i ] ;
const satisfied = semver . satisfies ( potential , versionSpec ) ;
if ( satisfied ) {
version = potential ;
break ;
}
}
if ( version ) {
core . debug ( ` matched: ${ version } ` ) ;
}
else {
core . debug ( 'match not found' ) ;
}
return version ;
}
//# sourceMappingURL=tool-cache.js.map
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 7509 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2022-06-27 14:17:15 -04:00
"use strict" ;
2022-07-11 13:48:02 -04:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var isPlainObject = _ _nccwpck _require _ _ ( 987 ) ;
var universalUserAgent = _ _nccwpck _require _ _ ( 7163 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function lowercaseKeys ( object ) {
if ( ! object ) {
return { } ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return Object . keys ( object ) . reduce ( ( newObj , key ) => {
newObj [ key . toLowerCase ( ) ] = object [ key ] ;
return newObj ;
} , { } ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function mergeDeep ( defaults , options ) {
const result = Object . assign ( { } , defaults ) ;
Object . keys ( options ) . forEach ( key => {
if ( isPlainObject . 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 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function removeUndefinedProperties ( obj ) {
for ( const key in obj ) {
if ( obj [ key ] === undefined ) {
delete obj [ key ] ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return obj ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
options . headers = lowercaseKeys ( options . headers ) ; // remove properties with undefined values before merging
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
removeUndefinedProperties ( options ) ;
removeUndefinedProperties ( options . headers ) ;
const mergedOptions = mergeDeep ( defaults || { } , options ) ; // mediaType.previews arrays are merged, instead of overwritten
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( defaults && defaults . mediaType . previews . length ) {
mergedOptions . mediaType . previews = defaults . mediaType . previews . filter ( preview => ! mergedOptions . mediaType . previews . includes ( preview ) ) . concat ( mergedOptions . mediaType . previews ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
mergedOptions . mediaType . previews = mergedOptions . mediaType . previews . map ( preview => preview . replace ( /-preview/ , "" ) ) ;
return mergedOptions ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
function addQueryParameters ( url , parameters ) {
const separator = /\?/ . test ( url ) ? "&" : "?" ;
const names = Object . keys ( parameters ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( names . length === 0 ) {
return url ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return url + separator + names . map ( name => {
if ( name === "q" ) {
return "q=" + parameters . q . split ( "+" ) . map ( encodeURIComponent ) . join ( "+" ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return ` ${ name } = ${ encodeURIComponent ( parameters [ name ] ) } ` ;
} ) . join ( "&" ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const urlVariableRegex = /\{[^}]+\}/g ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function removeNonChars ( variableName ) {
return variableName . replace ( /^\W+|\W+$/g , "" ) . split ( /,/ ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function extractUrlVariableNames ( url ) {
const matches = url . match ( urlVariableRegex ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( ! matches ) {
return [ ] ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return matches . map ( removeNonChars ) . reduce ( ( a , b ) => a . concat ( b ) , [ ] ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
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.
/* 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 , "]" ) ;
}
return part ;
} ) . join ( "" ) ;
}
function encodeUnreserved ( str ) {
return encodeURIComponent ( str ) . replace ( /[!'()*]/g , function ( c ) {
return "%" + c . charCodeAt ( 0 ) . toString ( 16 ) . toUpperCase ( ) ;
} ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function encodeValue ( operator , value , key ) {
value = operator === "+" || operator === "#" ? encodeReserved ( value ) : encodeUnreserved ( value ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( key ) {
return encodeUnreserved ( key ) + "=" + value ;
} else {
return value ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function isDefined ( value ) {
return value !== undefined && value !== null ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function isKeyOperator ( operator ) {
return operator === ";" || operator === "&" || operator === "?" ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function getValues ( context , operator , key , modifier ) {
var value = context [ key ] ,
result = [ ] ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( isDefined ( value ) && value !== "" ) {
if ( typeof value === "string" || typeof value === "number" || typeof value === "boolean" ) {
value = value . toString ( ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( modifier && modifier !== "*" ) {
value = value . substring ( 0 , parseInt ( modifier , 10 ) ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 = [ ] ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ( ) ) ) ;
}
} ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ( "" ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return result ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function parseUrl ( template ) {
return {
expand : expand . bind ( null , template )
} ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function expand ( template , context ) {
var operators = [ "+" , "#" , "." , "/" , ";" , "?" , "&" ] ;
return template . replace ( /\{([^\{\}]+)\}|([^\{\}]+)/g , function ( _ , expression , literal ) {
if ( expression ) {
let operator = "" ;
const values = [ ] ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( operators . indexOf ( expression . charAt ( 0 ) ) !== - 1 ) {
operator = expression . charAt ( 0 ) ;
expression = expression . substr ( 1 ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
expression . split ( /,/g ) . forEach ( function ( variable ) {
var tmp = /([^:\*]*)(?::(\d+)|(\*))?/ . exec ( variable ) ;
values . push ( getValues ( context , operator , tmp [ 1 ] , tmp [ 2 ] || tmp [ 3 ] ) ) ;
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( operator && operator !== "+" ) {
var separator = "," ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( operator === "?" ) {
separator = "&" ;
} else if ( operator !== "#" ) {
separator = operator ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return ( values . length !== 0 ? operator : "" ) + values . join ( separator ) ;
} else {
return values . join ( "," ) ;
}
} else {
return encodeReserved ( literal ) ;
}
} ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const urlVariableNames = extractUrlVariableNames ( url ) ;
url = parseUrl ( url ) . expand ( parameters ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( ! /^http/ . test ( url ) ) {
url = options . baseUrl + url ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const omittedParameters = Object . keys ( options ) . filter ( option => urlVariableNames . includes ( option ) ) . concat ( "baseUrl" ) ;
const remainingParameters = omit ( parameters , omittedParameters ) ;
const isBinaryRequest = /application\/octet-stream/i . test ( headers . accept ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( ! isBinaryRequest ) {
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 ( "," ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ( "," ) ;
}
} // for GET/HEAD requests, set URL query parameters from remaining parameters
// for PATCH/POST/PUT/DELETE requests, set request body from remaining parameters
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
}
}
} // default content-type for JSON if body is set
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( [ "PATCH" , "PUT" ] . includes ( method ) && typeof body === "undefined" ) {
body = "" ;
} // Only return body/request keys if present
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return Object . assign ( {
method ,
url ,
headers
} , typeof body !== "undefined" ? {
body
} : null , options . request ? {
request : options . request
} : null ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function endpointWithDefaults ( defaults , route , options ) {
return parse ( merge ( defaults , route , options ) ) ;
}
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
} ) ;
}
const VERSION = "6.0.12" ;
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 : [ ]
}
2022-06-27 14:17:15 -04:00
} ;
2022-07-11 13:48:02 -04:00
const endpoint = withDefaults ( null , DEFAULTS ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
exports . endpoint = endpoint ;
//# sourceMappingURL=index.js.map
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 1660 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"use strict" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var request = _ _nccwpck _require _ _ ( 2364 ) ;
var universalUserAgent = _ _nccwpck _require _ _ ( 7163 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const VERSION = "4.8.0" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function _buildMessageForResponseErrors ( data ) {
return ` Request failed due to following response errors: \n ` + data . errors . map ( e => ` - ${ e . message } ` ) . join ( "\n" ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
class GraphqlResponseError extends Error {
constructor ( request , headers , response ) {
super ( _buildMessageForResponseErrors ( response ) ) ;
this . request = request ;
this . headers = headers ;
this . response = response ;
this . name = "GraphqlResponseError" ; // Expose the errors and response data in their shorthand properties.
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
this . errors = response . errors ;
this . data = response . data ; // Maintains proper stack trace (only available on V8)
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/* istanbul ignore next */
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( Error . captureStackTrace ) {
Error . captureStackTrace ( this , this . constructor ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const NON _VARIABLE _OPTIONS = [ "method" , "baseUrl" , "url" , "headers" , "request" , "query" , "mediaType" ] ;
const FORBIDDEN _VARIABLE _OPTIONS = [ "query" , "method" , "url" ] ;
const GHES _V3 _SUFFIX _REGEX = /\/api\/v3\/?$/ ;
function graphql ( request , query , options ) {
if ( options ) {
if ( typeof query === "string" && "query" in options ) {
return Promise . reject ( new Error ( ` [@octokit/graphql] "query" cannot be used as variable name ` ) ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
for ( const key in options ) {
if ( ! FORBIDDEN _VARIABLE _OPTIONS . includes ( key ) ) continue ;
return Promise . reject ( new Error ( ` [@octokit/graphql] " ${ key } " cannot be used as variable name ` ) ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const parsedOptions = typeof query === "string" ? Object . assign ( {
query
} , options ) : query ;
const requestOptions = Object . keys ( parsedOptions ) . reduce ( ( result , key ) => {
if ( NON _VARIABLE _OPTIONS . includes ( key ) ) {
result [ key ] = parsedOptions [ key ] ;
return result ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( ! result . variables ) {
result . variables = { } ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
result . variables [ key ] = parsedOptions [ key ] ;
return result ;
} , { } ) ; // workaround for GitHub Enterprise baseUrl set with /api/v3 suffix
// https://github.com/octokit/auth-app.js/issues/111#issuecomment-657610451
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const baseUrl = parsedOptions . baseUrl || request . endpoint . DEFAULTS . baseUrl ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( GHES _V3 _SUFFIX _REGEX . test ( baseUrl ) ) {
requestOptions . url = baseUrl . replace ( GHES _V3 _SUFFIX _REGEX , "/api/graphql" ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return request ( requestOptions ) . then ( response => {
if ( response . data . errors ) {
const headers = { } ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
for ( const key of Object . keys ( response . headers ) ) {
headers [ key ] = response . headers [ key ] ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
throw new GraphqlResponseError ( requestOptions , headers , response . data ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return response . data . data ;
} ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function withDefaults ( request$1 , newDefaults ) {
const newRequest = request$1 . defaults ( newDefaults ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const newApi = ( query , options ) => {
return graphql ( newRequest , query , options ) ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return Object . assign ( newApi , {
defaults : withDefaults . bind ( null , newRequest ) ,
endpoint : request . request . endpoint
} ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
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"
} ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
exports . GraphqlResponseError = GraphqlResponseError ;
exports . graphql = graphql$1 ;
exports . withCustomRequest = withCustomRequest ;
//# sourceMappingURL=index.js.map
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 1042 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"use strict" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function _interopDefault ( ex ) { return ( ex && ( typeof ex === 'object' ) && 'default' in ex ) ? ex [ 'default' ] : ex ; }
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var deprecation = _ _nccwpck _require _ _ ( 2280 ) ;
var once = _interopDefault ( _ _nccwpck _require _ _ ( 8953 ) ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const logOnceCode = once ( deprecation => console . warn ( deprecation ) ) ;
const logOnceHeaders = once ( deprecation => console . warn ( deprecation ) ) ;
/ * *
* Error with extra properties to help with debugging
* /
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
class RequestError extends Error {
constructor ( message , statusCode , options ) {
super ( message ) ; // Maintains proper stack trace (only available on V8)
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/* istanbul ignore next */
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( Error . captureStackTrace ) {
Error . captureStackTrace ( this , this . constructor ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
this . name = "HttpError" ;
this . status = statusCode ;
let headers ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( "headers" in options && typeof options . headers !== "undefined" ) {
headers = options . headers ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( "response" in options ) {
this . response = options . response ;
headers = options . response . headers ;
} // redact request credentials without mutating original request options
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const requestCopy = Object . assign ( { } , options . request ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( options . request . headers . authorization ) {
requestCopy . headers = Object . assign ( { } , options . request . headers , {
authorization : options . request . headers . authorization . replace ( / .*$/ , " [REDACTED]" )
} ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04: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 ; // deprecations
Object . defineProperty ( this , "code" , {
get ( ) {
logOnceCode ( new deprecation . Deprecation ( "[@octokit/request-error] `error.code` is deprecated, use `error.status`." ) ) ;
return statusCode ;
}
} ) ;
Object . defineProperty ( this , "headers" , {
get ( ) {
logOnceHeaders ( new deprecation . Deprecation ( "[@octokit/request-error] `error.headers` is deprecated, use `error.response.headers`." ) ) ;
return headers || { } ;
}
} ) ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
exports . RequestError = RequestError ;
//# sourceMappingURL=index.js.map
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 2364 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"use strict" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function _interopDefault ( ex ) { return ( ex && ( typeof ex === 'object' ) && 'default' in ex ) ? ex [ 'default' ] : ex ; }
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var endpoint = _ _nccwpck _require _ _ ( 7509 ) ;
var universalUserAgent = _ _nccwpck _require _ _ ( 7163 ) ;
var isPlainObject = _ _nccwpck _require _ _ ( 987 ) ;
var nodeFetch = _interopDefault ( _ _nccwpck _require _ _ ( 2460 ) ) ;
var requestError = _ _nccwpck _require _ _ ( 1042 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const VERSION = "5.6.3" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function getBufferResponse ( response ) {
return response . arrayBuffer ( ) ;
}
function fetchWrapper ( requestOptions ) {
const log = requestOptions . request && requestOptions . request . log ? requestOptions . request . log : console ;
if ( isPlainObject . 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.agent` type is incompatible
// see https://github.com/octokit/types.ts/pull/264
requestOptions . request ) ) . then ( async response => {
url = response . url ;
status = response . status ;
for ( const keyAndValue of response . headers ) {
headers [ keyAndValue [ 0 ] ] = keyAndValue [ 1 ] ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
if ( "deprecation" in headers ) {
const matches = headers . link && headers . link . match ( /<([^>]+)>; rel="deprecation"/ ) ;
const deprecationLink = matches && matches . pop ( ) ;
log . warn ( ` [@octokit/request] " ${ requestOptions . method } ${ requestOptions . url } " is deprecated. It is scheduled to be removed on ${ headers . sunset } ${ deprecationLink ? ` . See ${ deprecationLink } ` : "" } ` ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
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 , {
response : {
url ,
status ,
headers ,
data : undefined
} ,
request : requestOptions
} ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
if ( status === 304 ) {
throw new requestError . RequestError ( "Not modified" , status , {
response : {
url ,
status ,
headers ,
data : await getResponseData ( response )
} ,
request : requestOptions
} ) ;
}
if ( status >= 400 ) {
const data = await getResponseData ( response ) ;
const error = new requestError . RequestError ( toErrorMessage ( data ) , status , {
response : {
url ,
status ,
headers ,
data
} ,
request : requestOptions
} ) ;
throw error ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return getResponseData ( response ) ;
} ) . then ( data => {
return {
status ,
url ,
headers ,
data
} ;
} ) . catch ( error => {
if ( error instanceof requestError . RequestError ) throw error ;
throw new requestError . RequestError ( error . message , 500 , {
request : requestOptions
} ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
async function getResponseData ( response ) {
const contentType = response . headers . get ( "content-type" ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( /application\/json/ . test ( contentType ) ) {
return response . json ( ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( ! contentType || /^text\/|charset=utf-8$/ . test ( contentType ) ) {
return response . text ( ) ;
}
return getBufferResponse ( response ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
function toErrorMessage ( data ) {
if ( typeof data === "string" ) return data ; // istanbul ignore else - just in case
if ( "message" in data ) {
if ( Array . isArray ( data . errors ) ) {
return ` ${ data . message } : ${ data . errors . map ( JSON . stringify ) . join ( ", " ) } ` ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return data . message ;
} // istanbul ignore next - just in case
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return ` Unknown error: ${ JSON . stringify ( data ) } ` ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04: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 ) ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
const request = ( route , parameters ) => {
return fetchWrapper ( endpoint . parse ( endpoint . merge ( route , parameters ) ) ) ;
} ;
Object . assign ( request , {
endpoint ,
defaults : withDefaults . bind ( null , endpoint )
} ) ;
return endpointOptions . request . hook ( request , endpointOptions ) ;
} ;
return Object . assign ( newApi , {
endpoint ,
defaults : withDefaults . bind ( null , endpoint )
} ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
const request = withDefaults ( endpoint . endpoint , {
headers : {
"user-agent" : ` octokit-request.js/ ${ VERSION } ${ universalUserAgent . getUserAgent ( ) } `
}
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
exports . request = request ;
//# sourceMappingURL=index.js.map
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 4353 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"use strict" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var GetIntrinsic = _ _nccwpck _require _ _ ( 4880 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var callBind = _ _nccwpck _require _ _ ( 8724 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var $indexOf = callBind ( GetIntrinsic ( 'String.prototype.indexOf' ) ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports = function callBoundIntrinsic ( name , allowMissing ) {
var intrinsic = GetIntrinsic ( name , ! ! allowMissing ) ;
if ( typeof intrinsic === 'function' && $indexOf ( name , '.prototype.' ) > - 1 ) {
return callBind ( intrinsic ) ;
}
return intrinsic ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 8724 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
var bind = _ _nccwpck _require _ _ ( 795 ) ;
var GetIntrinsic = _ _nccwpck _require _ _ ( 4880 ) ;
var $apply = GetIntrinsic ( '%Function.prototype.apply%' ) ;
var $call = GetIntrinsic ( '%Function.prototype.call%' ) ;
var $reflectApply = GetIntrinsic ( '%Reflect.apply%' , true ) || bind . call ( $call , $apply ) ;
var $gOPD = GetIntrinsic ( '%Object.getOwnPropertyDescriptor%' , true ) ;
var $defineProperty = GetIntrinsic ( '%Object.defineProperty%' , true ) ;
var $max = GetIntrinsic ( '%Math.max%' ) ;
if ( $defineProperty ) {
try {
$defineProperty ( { } , 'a' , { value : 1 } ) ;
} catch ( e ) {
// IE 8 has a broken defineProperty
$defineProperty = null ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
module . exports = function callBind ( originalFunction ) {
var func = $reflectApply ( bind , $call , arguments ) ;
if ( $gOPD && $defineProperty ) {
var desc = $gOPD ( func , 'length' ) ;
if ( desc . configurable ) {
// original length, plus the receiver, minus any additional arguments (after the receiver)
$defineProperty (
func ,
'length' ,
{ value : 1 + $max ( 0 , originalFunction . length - ( arguments . length - 1 ) ) }
) ;
}
}
return func ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var applyBind = function applyBind ( ) {
return $reflectApply ( bind , $apply , arguments ) ;
} ;
if ( $defineProperty ) {
$defineProperty ( module . exports , 'apply' , { value : applyBind } ) ;
} else {
module . exports . apply = applyBind ;
2022-06-27 14:17:15 -04:00
}
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 2280 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"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' ;
}
}
exports . Deprecation = Deprecation ;
2022-06-27 14:17:15 -04:00
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 3967 :
2022-06-27 14:17:15 -04:00
/***/ ( ( module ) => {
"use strict" ;
2022-07-11 13:48:02 -04:00
/* eslint no-invalid-this: 1 */
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var ERROR _MESSAGE = 'Function.prototype.bind called on incompatible ' ;
var slice = Array . prototype . slice ;
var toStr = Object . prototype . toString ;
var funcType = '[object Function]' ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports = function bind ( that ) {
var target = this ;
if ( typeof target !== 'function' || toStr . call ( target ) !== funcType ) {
throw new TypeError ( ERROR _MESSAGE + target ) ;
}
var args = slice . call ( arguments , 1 ) ;
var bound ;
var binder = function ( ) {
if ( this instanceof bound ) {
var result = target . apply (
this ,
args . concat ( slice . call ( arguments ) )
) ;
if ( Object ( result ) === result ) {
return result ;
}
return this ;
} else {
return target . apply (
that ,
args . concat ( slice . call ( arguments ) )
) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
} ;
var boundLength = Math . max ( 0 , target . length - args . length ) ;
var boundArgs = [ ] ;
for ( var i = 0 ; i < boundLength ; i ++ ) {
boundArgs . push ( '$' + i ) ;
}
bound = Function ( 'binder' , 'return function (' + boundArgs . join ( ',' ) + '){ return binder.apply(this,arguments); }' ) ( binder ) ;
if ( target . prototype ) {
var Empty = function Empty ( ) { } ;
Empty . prototype = target . prototype ;
bound . prototype = new Empty ( ) ;
Empty . prototype = null ;
}
return bound ;
2022-06-27 14:17:15 -04:00
} ;
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 795 :
2022-06-27 14:17:15 -04:00
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
2022-07-11 13:48:02 -04:00
var implementation = _ _nccwpck _require _ _ ( 3967 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports = Function . prototype . bind || implementation ;
2022-06-27 14:17:15 -04:00
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 4880 :
2022-06-27 14:17:15 -04:00
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
2022-07-11 13:48:02 -04:00
var undefined ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var $SyntaxError = SyntaxError ;
var $Function = Function ;
var $TypeError = TypeError ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// eslint-disable-next-line consistent-return
var getEvalledConstructor = function ( expressionSyntax ) {
try {
return $Function ( '"use strict"; return (' + expressionSyntax + ').constructor;' ) ( ) ;
} catch ( e ) { }
2022-06-27 14:17:15 -04:00
} ;
2022-07-11 13:48:02 -04:00
var $gOPD = Object . getOwnPropertyDescriptor ;
if ( $gOPD ) {
try {
$gOPD ( { } , '' ) ;
} catch ( e ) {
$gOPD = null ; // this is IE 8, which has a broken gOPD
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var throwTypeError = function ( ) {
throw new $TypeError ( ) ;
2022-06-27 14:17:15 -04:00
} ;
2022-07-11 13:48:02 -04:00
var ThrowTypeError = $gOPD
? ( function ( ) {
try {
// eslint-disable-next-line no-unused-expressions, no-caller, no-restricted-properties
arguments . callee ; // IE 8 does not throw here
return throwTypeError ;
} catch ( calleeThrows ) {
try {
// IE 8 throws on Object.getOwnPropertyDescriptor(arguments, '')
return $gOPD ( arguments , 'callee' ) . get ;
} catch ( gOPDthrows ) {
return throwTypeError ;
}
}
} ( ) )
: throwTypeError ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var hasSymbols = _ _nccwpck _require _ _ ( 407 ) ( ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var getProto = Object . getPrototypeOf || function ( x ) { return x . _ _proto _ _ ; } ; // eslint-disable-line no-proto
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var needsEval = { } ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var TypedArray = typeof Uint8Array === 'undefined' ? undefined : getProto ( Uint8Array ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var INTRINSICS = {
'%AggregateError%' : typeof AggregateError === 'undefined' ? undefined : AggregateError ,
'%Array%' : Array ,
'%ArrayBuffer%' : typeof ArrayBuffer === 'undefined' ? undefined : ArrayBuffer ,
'%ArrayIteratorPrototype%' : hasSymbols ? getProto ( [ ] [ Symbol . iterator ] ( ) ) : undefined ,
'%AsyncFromSyncIteratorPrototype%' : undefined ,
'%AsyncFunction%' : needsEval ,
'%AsyncGenerator%' : needsEval ,
'%AsyncGeneratorFunction%' : needsEval ,
'%AsyncIteratorPrototype%' : needsEval ,
'%Atomics%' : typeof Atomics === 'undefined' ? undefined : Atomics ,
'%BigInt%' : typeof BigInt === 'undefined' ? undefined : BigInt ,
'%Boolean%' : Boolean ,
'%DataView%' : typeof DataView === 'undefined' ? undefined : DataView ,
'%Date%' : Date ,
'%decodeURI%' : decodeURI ,
'%decodeURIComponent%' : decodeURIComponent ,
'%encodeURI%' : encodeURI ,
'%encodeURIComponent%' : encodeURIComponent ,
'%Error%' : Error ,
'%eval%' : eval , // eslint-disable-line no-eval
'%EvalError%' : EvalError ,
'%Float32Array%' : typeof Float32Array === 'undefined' ? undefined : Float32Array ,
'%Float64Array%' : typeof Float64Array === 'undefined' ? undefined : Float64Array ,
'%FinalizationRegistry%' : typeof FinalizationRegistry === 'undefined' ? undefined : FinalizationRegistry ,
'%Function%' : $Function ,
'%GeneratorFunction%' : needsEval ,
'%Int8Array%' : typeof Int8Array === 'undefined' ? undefined : Int8Array ,
'%Int16Array%' : typeof Int16Array === 'undefined' ? undefined : Int16Array ,
'%Int32Array%' : typeof Int32Array === 'undefined' ? undefined : Int32Array ,
'%isFinite%' : isFinite ,
'%isNaN%' : isNaN ,
'%IteratorPrototype%' : hasSymbols ? getProto ( getProto ( [ ] [ Symbol . iterator ] ( ) ) ) : undefined ,
'%JSON%' : typeof JSON === 'object' ? JSON : undefined ,
'%Map%' : typeof Map === 'undefined' ? undefined : Map ,
'%MapIteratorPrototype%' : typeof Map === 'undefined' || ! hasSymbols ? undefined : getProto ( new Map ( ) [ Symbol . iterator ] ( ) ) ,
'%Math%' : Math ,
'%Number%' : Number ,
'%Object%' : Object ,
'%parseFloat%' : parseFloat ,
'%parseInt%' : parseInt ,
'%Promise%' : typeof Promise === 'undefined' ? undefined : Promise ,
'%Proxy%' : typeof Proxy === 'undefined' ? undefined : Proxy ,
'%RangeError%' : RangeError ,
'%ReferenceError%' : ReferenceError ,
'%Reflect%' : typeof Reflect === 'undefined' ? undefined : Reflect ,
'%RegExp%' : RegExp ,
'%Set%' : typeof Set === 'undefined' ? undefined : Set ,
'%SetIteratorPrototype%' : typeof Set === 'undefined' || ! hasSymbols ? undefined : getProto ( new Set ( ) [ Symbol . iterator ] ( ) ) ,
'%SharedArrayBuffer%' : typeof SharedArrayBuffer === 'undefined' ? undefined : SharedArrayBuffer ,
'%String%' : String ,
'%StringIteratorPrototype%' : hasSymbols ? getProto ( '' [ Symbol . iterator ] ( ) ) : undefined ,
'%Symbol%' : hasSymbols ? Symbol : undefined ,
'%SyntaxError%' : $SyntaxError ,
'%ThrowTypeError%' : ThrowTypeError ,
'%TypedArray%' : TypedArray ,
'%TypeError%' : $TypeError ,
'%Uint8Array%' : typeof Uint8Array === 'undefined' ? undefined : Uint8Array ,
'%Uint8ClampedArray%' : typeof Uint8ClampedArray === 'undefined' ? undefined : Uint8ClampedArray ,
'%Uint16Array%' : typeof Uint16Array === 'undefined' ? undefined : Uint16Array ,
'%Uint32Array%' : typeof Uint32Array === 'undefined' ? undefined : Uint32Array ,
'%URIError%' : URIError ,
'%WeakMap%' : typeof WeakMap === 'undefined' ? undefined : WeakMap ,
'%WeakRef%' : typeof WeakRef === 'undefined' ? undefined : WeakRef ,
'%WeakSet%' : typeof WeakSet === 'undefined' ? undefined : WeakSet
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var doEval = function doEval ( name ) {
var value ;
if ( name === '%AsyncFunction%' ) {
value = getEvalledConstructor ( 'async function () {}' ) ;
} else if ( name === '%GeneratorFunction%' ) {
value = getEvalledConstructor ( 'function* () {}' ) ;
} else if ( name === '%AsyncGeneratorFunction%' ) {
value = getEvalledConstructor ( 'async function* () {}' ) ;
} else if ( name === '%AsyncGenerator%' ) {
var fn = doEval ( '%AsyncGeneratorFunction%' ) ;
if ( fn ) {
value = fn . prototype ;
}
} else if ( name === '%AsyncIteratorPrototype%' ) {
var gen = doEval ( '%AsyncGenerator%' ) ;
if ( gen ) {
value = getProto ( gen . prototype ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
INTRINSICS [ name ] = value ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return value ;
2022-06-27 14:17:15 -04:00
} ;
2022-07-11 13:48:02 -04:00
var LEGACY _ALIASES = {
'%ArrayBufferPrototype%' : [ 'ArrayBuffer' , 'prototype' ] ,
'%ArrayPrototype%' : [ 'Array' , 'prototype' ] ,
'%ArrayProto_entries%' : [ 'Array' , 'prototype' , 'entries' ] ,
'%ArrayProto_forEach%' : [ 'Array' , 'prototype' , 'forEach' ] ,
'%ArrayProto_keys%' : [ 'Array' , 'prototype' , 'keys' ] ,
'%ArrayProto_values%' : [ 'Array' , 'prototype' , 'values' ] ,
'%AsyncFunctionPrototype%' : [ 'AsyncFunction' , 'prototype' ] ,
'%AsyncGenerator%' : [ 'AsyncGeneratorFunction' , 'prototype' ] ,
'%AsyncGeneratorPrototype%' : [ 'AsyncGeneratorFunction' , 'prototype' , 'prototype' ] ,
'%BooleanPrototype%' : [ 'Boolean' , 'prototype' ] ,
'%DataViewPrototype%' : [ 'DataView' , 'prototype' ] ,
'%DatePrototype%' : [ 'Date' , 'prototype' ] ,
'%ErrorPrototype%' : [ 'Error' , 'prototype' ] ,
'%EvalErrorPrototype%' : [ 'EvalError' , 'prototype' ] ,
'%Float32ArrayPrototype%' : [ 'Float32Array' , 'prototype' ] ,
'%Float64ArrayPrototype%' : [ 'Float64Array' , 'prototype' ] ,
'%FunctionPrototype%' : [ 'Function' , 'prototype' ] ,
'%Generator%' : [ 'GeneratorFunction' , 'prototype' ] ,
'%GeneratorPrototype%' : [ 'GeneratorFunction' , 'prototype' , 'prototype' ] ,
'%Int8ArrayPrototype%' : [ 'Int8Array' , 'prototype' ] ,
'%Int16ArrayPrototype%' : [ 'Int16Array' , 'prototype' ] ,
'%Int32ArrayPrototype%' : [ 'Int32Array' , 'prototype' ] ,
'%JSONParse%' : [ 'JSON' , 'parse' ] ,
'%JSONStringify%' : [ 'JSON' , 'stringify' ] ,
'%MapPrototype%' : [ 'Map' , 'prototype' ] ,
'%NumberPrototype%' : [ 'Number' , 'prototype' ] ,
'%ObjectPrototype%' : [ 'Object' , 'prototype' ] ,
'%ObjProto_toString%' : [ 'Object' , 'prototype' , 'toString' ] ,
'%ObjProto_valueOf%' : [ 'Object' , 'prototype' , 'valueOf' ] ,
'%PromisePrototype%' : [ 'Promise' , 'prototype' ] ,
'%PromiseProto_then%' : [ 'Promise' , 'prototype' , 'then' ] ,
'%Promise_all%' : [ 'Promise' , 'all' ] ,
'%Promise_reject%' : [ 'Promise' , 'reject' ] ,
'%Promise_resolve%' : [ 'Promise' , 'resolve' ] ,
'%RangeErrorPrototype%' : [ 'RangeError' , 'prototype' ] ,
'%ReferenceErrorPrototype%' : [ 'ReferenceError' , 'prototype' ] ,
'%RegExpPrototype%' : [ 'RegExp' , 'prototype' ] ,
'%SetPrototype%' : [ 'Set' , 'prototype' ] ,
'%SharedArrayBufferPrototype%' : [ 'SharedArrayBuffer' , 'prototype' ] ,
'%StringPrototype%' : [ 'String' , 'prototype' ] ,
'%SymbolPrototype%' : [ 'Symbol' , 'prototype' ] ,
'%SyntaxErrorPrototype%' : [ 'SyntaxError' , 'prototype' ] ,
'%TypedArrayPrototype%' : [ 'TypedArray' , 'prototype' ] ,
'%TypeErrorPrototype%' : [ 'TypeError' , 'prototype' ] ,
'%Uint8ArrayPrototype%' : [ 'Uint8Array' , 'prototype' ] ,
'%Uint8ClampedArrayPrototype%' : [ 'Uint8ClampedArray' , 'prototype' ] ,
'%Uint16ArrayPrototype%' : [ 'Uint16Array' , 'prototype' ] ,
'%Uint32ArrayPrototype%' : [ 'Uint32Array' , 'prototype' ] ,
'%URIErrorPrototype%' : [ 'URIError' , 'prototype' ] ,
'%WeakMapPrototype%' : [ 'WeakMap' , 'prototype' ] ,
'%WeakSetPrototype%' : [ 'WeakSet' , 'prototype' ]
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var bind = _ _nccwpck _require _ _ ( 795 ) ;
var hasOwn = _ _nccwpck _require _ _ ( 1122 ) ;
var $concat = bind . call ( Function . call , Array . prototype . concat ) ;
var $spliceApply = bind . call ( Function . apply , Array . prototype . splice ) ;
var $replace = bind . call ( Function . call , String . prototype . replace ) ;
var $strSlice = bind . call ( Function . call , String . prototype . slice ) ;
var $exec = bind . call ( Function . call , RegExp . prototype . exec ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/* adapted from https://github.com/lodash/lodash/blob/4.17.15/dist/lodash.js#L6735-L6744 */
var rePropName = /[^%.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|%$))/g ;
var reEscapeChar = /\\(\\)?/g ; /** Used to match backslashes in property paths. */
var stringToPath = function stringToPath ( string ) {
var first = $strSlice ( string , 0 , 1 ) ;
var last = $strSlice ( string , - 1 ) ;
if ( first === '%' && last !== '%' ) {
throw new $SyntaxError ( 'invalid intrinsic syntax, expected closing `%`' ) ;
} else if ( last === '%' && first !== '%' ) {
throw new $SyntaxError ( 'invalid intrinsic syntax, expected opening `%`' ) ;
}
var result = [ ] ;
$replace ( string , rePropName , function ( match , number , quote , subString ) {
result [ result . length ] = quote ? $replace ( subString , reEscapeChar , '$1' ) : number || match ;
} ) ;
return result ;
2022-06-27 14:17:15 -04:00
} ;
2022-07-11 13:48:02 -04:00
/* end adaptation */
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var getBaseIntrinsic = function getBaseIntrinsic ( name , allowMissing ) {
var intrinsicName = name ;
var alias ;
if ( hasOwn ( LEGACY _ALIASES , intrinsicName ) ) {
alias = LEGACY _ALIASES [ intrinsicName ] ;
intrinsicName = '%' + alias [ 0 ] + '%' ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( hasOwn ( INTRINSICS , intrinsicName ) ) {
var value = INTRINSICS [ intrinsicName ] ;
if ( value === needsEval ) {
value = doEval ( intrinsicName ) ;
}
if ( typeof value === 'undefined' && ! allowMissing ) {
throw new $TypeError ( 'intrinsic ' + name + ' exists, but is not available. Please file an issue!' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return {
alias : alias ,
name : intrinsicName ,
value : value
} ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
throw new $SyntaxError ( 'intrinsic ' + name + ' does not exist!' ) ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports = function GetIntrinsic ( name , allowMissing ) {
if ( typeof name !== 'string' || name . length === 0 ) {
throw new $TypeError ( 'intrinsic name must be a non-empty string' ) ;
}
if ( arguments . length > 1 && typeof allowMissing !== 'boolean' ) {
throw new $TypeError ( '"allowMissing" argument must be a boolean' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( $exec ( /^%?[^%]*%?$/g , name ) === null ) {
throw new $SyntaxError ( '`%` may not be present anywhere but at the beginning and end of the intrinsic name' ) ;
}
var parts = stringToPath ( name ) ;
var intrinsicBaseName = parts . length > 0 ? parts [ 0 ] : '' ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var intrinsic = getBaseIntrinsic ( '%' + intrinsicBaseName + '%' , allowMissing ) ;
var intrinsicRealName = intrinsic . name ;
var value = intrinsic . value ;
var skipFurtherCaching = false ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var alias = intrinsic . alias ;
if ( alias ) {
intrinsicBaseName = alias [ 0 ] ;
$spliceApply ( parts , $concat ( [ 0 , 1 ] , alias ) ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
for ( var i = 1 , isOwn = true ; i < parts . length ; i += 1 ) {
var part = parts [ i ] ;
var first = $strSlice ( part , 0 , 1 ) ;
var last = $strSlice ( part , - 1 ) ;
if (
(
( first === '"' || first === "'" || first === '`' )
|| ( last === '"' || last === "'" || last === '`' )
)
&& first !== last
) {
throw new $SyntaxError ( 'property names with quotes must have matching quotes' ) ;
}
if ( part === 'constructor' || ! isOwn ) {
skipFurtherCaching = true ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
intrinsicBaseName += '.' + part ;
intrinsicRealName = '%' + intrinsicBaseName + '%' ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( hasOwn ( INTRINSICS , intrinsicRealName ) ) {
value = INTRINSICS [ intrinsicRealName ] ;
} else if ( value != null ) {
if ( ! ( part in value ) ) {
if ( ! allowMissing ) {
throw new $TypeError ( 'base intrinsic for ' + name + ' exists, but the property is not available.' ) ;
}
return void undefined ;
}
if ( $gOPD && ( i + 1 ) >= parts . length ) {
var desc = $gOPD ( value , part ) ;
isOwn = ! ! desc ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// By convention, when a data property is converted to an accessor
// property to emulate a data property that does not suffer from
// the override mistake, that accessor's getter is marked with
// an `originalValue` property. Here, when we detect this, we
// uphold the illusion by pretending to see that original data
// property, i.e., returning the value rather than the getter
// itself.
if ( isOwn && 'get' in desc && ! ( 'originalValue' in desc . get ) ) {
value = desc . get ;
} else {
value = value [ part ] ;
}
} else {
isOwn = hasOwn ( value , part ) ;
value = value [ part ] ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( isOwn && ! skipFurtherCaching ) {
INTRINSICS [ intrinsicRealName ] = value ;
}
}
}
return value ;
2022-06-27 14:17:15 -04:00
} ;
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 407 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"use strict" ;
var origSymbol = typeof Symbol !== 'undefined' && Symbol ;
var hasSymbolSham = _ _nccwpck _require _ _ ( 853 ) ;
module . exports = function hasNativeSymbols ( ) {
if ( typeof origSymbol !== 'function' ) { return false ; }
if ( typeof Symbol !== 'function' ) { return false ; }
if ( typeof origSymbol ( 'foo' ) !== 'symbol' ) { return false ; }
if ( typeof Symbol ( 'bar' ) !== 'symbol' ) { return false ; }
return hasSymbolSham ( ) ;
2022-06-27 14:17:15 -04:00
} ;
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 853 :
/***/ ( ( module ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"use strict" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/* eslint complexity: [2, 18], max-statements: [2, 33] */
module . exports = function hasSymbols ( ) {
if ( typeof Symbol !== 'function' || typeof Object . getOwnPropertySymbols !== 'function' ) { return false ; }
if ( typeof Symbol . iterator === 'symbol' ) { return true ; }
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var obj = { } ;
var sym = Symbol ( 'test' ) ;
var symObj = Object ( sym ) ;
if ( typeof sym === 'string' ) { return false ; }
if ( Object . prototype . toString . call ( sym ) !== '[object Symbol]' ) { return false ; }
if ( Object . prototype . toString . call ( symObj ) !== '[object Symbol]' ) { return false ; }
// temp disabled per https://github.com/ljharb/object.assign/issues/17
// if (sym instanceof Symbol) { return false; }
// temp disabled per https://github.com/WebReflection/get-own-property-symbols/issues/4
// if (!(symObj instanceof Symbol)) { return false; }
// if (typeof Symbol.prototype.toString !== 'function') { return false; }
// if (String(sym) !== Symbol.prototype.toString.call(sym)) { return false; }
var symVal = 42 ;
obj [ sym ] = symVal ;
for ( sym in obj ) { return false ; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop
if ( typeof Object . keys === 'function' && Object . keys ( obj ) . length !== 0 ) { return false ; }
if ( typeof Object . getOwnPropertyNames === 'function' && Object . getOwnPropertyNames ( obj ) . length !== 0 ) { return false ; }
var syms = Object . getOwnPropertySymbols ( obj ) ;
if ( syms . length !== 1 || syms [ 0 ] !== sym ) { return false ; }
if ( ! Object . prototype . propertyIsEnumerable . call ( obj , sym ) ) { return false ; }
if ( typeof Object . getOwnPropertyDescriptor === 'function' ) {
var descriptor = Object . getOwnPropertyDescriptor ( obj , sym ) ;
if ( descriptor . value !== symVal || descriptor . enumerable !== true ) { return false ; }
}
return true ;
2022-06-27 14:17:15 -04:00
} ;
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 1122 :
2022-06-27 14:17:15 -04:00
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
2022-07-11 13:48:02 -04:00
var bind = _ _nccwpck _require _ _ ( 795 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports = bind . call ( Function . call , Object . prototype . hasOwnProperty ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 987 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"use strict" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/ * !
* is - plain - object < https : //github.com/jonschlinkert/is-plain-object>
*
* Copyright ( c ) 2014 - 2017 , Jon Schlinkert .
* Released under the MIT License .
* /
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function isObject ( o ) {
return Object . prototype . toString . call ( o ) === '[object Object]' ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function isPlainObject ( o ) {
var ctor , prot ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( isObject ( o ) === false ) return false ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// If has modified constructor
ctor = o . constructor ;
if ( ctor === undefined ) return true ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// If has modified prototype
prot = ctor . prototype ;
if ( isObject ( prot ) === false ) return false ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// If constructor does not have an Object-specific method
if ( prot . hasOwnProperty ( 'isPrototypeOf' ) === false ) {
return false ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// Most likely a plain Object
return true ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
exports . isPlainObject = isPlainObject ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 2460 :
/***/ ( ( module , exports , _ _nccwpck _require _ _ ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"use strict" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function _interopDefault ( ex ) { return ( ex && ( typeof ex === 'object' ) && 'default' in ex ) ? ex [ 'default' ] : ex ; }
var Stream = _interopDefault ( _ _nccwpck _require _ _ ( 2781 ) ) ;
var http = _interopDefault ( _ _nccwpck _require _ _ ( 3685 ) ) ;
var Url = _interopDefault ( _ _nccwpck _require _ _ ( 7310 ) ) ;
var whatwgUrl = _interopDefault ( _ _nccwpck _require _ _ ( 2752 ) ) ;
var https = _interopDefault ( _ _nccwpck _require _ _ ( 5687 ) ) ;
var zlib = _interopDefault ( _ _nccwpck _require _ _ ( 9796 ) ) ;
// Based on https://github.com/tmpvar/jsdom/blob/aa85b2abf07766ff7bf5c1f6daafb3726f2f2db5/lib/jsdom/living/blob.js
// fix for "Readable" isn't a named export issue
const Readable = Stream . Readable ;
const BUFFER = Symbol ( 'buffer' ) ;
const TYPE = Symbol ( 'type' ) ;
class Blob {
constructor ( ) {
this [ TYPE ] = '' ;
const blobParts = arguments [ 0 ] ;
const options = arguments [ 1 ] ;
const buffers = [ ] ;
let size = 0 ;
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 ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
this [ BUFFER ] = Buffer . concat ( buffers ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
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 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const buffer = this [ BUFFER ] ;
const slicedBuffer = buffer . slice ( relativeStart , relativeStart + span ) ;
const blob = new Blob ( [ ] , { type : arguments [ 2 ] } ) ;
blob [ BUFFER ] = slicedBuffer ;
return blob ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperties ( Blob . prototype , {
size : { enumerable : true } ,
type : { enumerable : true } ,
slice : { enumerable : true }
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( Blob . prototype , Symbol . toStringTag , {
value : 'Blob' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/ * *
* fetch - error . js
*
* FetchError interface for operational errors
* /
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
this . message = message ;
this . type = type ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// when err.type is `system`, err.code contains system error code
if ( systemError ) {
this . code = this . errno = systemError . code ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// hide custom error implementation details from end-users
Error . captureStackTrace ( this , this . constructor ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
FetchError . prototype = Object . create ( Error . prototype ) ;
FetchError . prototype . constructor = FetchError ;
FetchError . prototype . name = 'FetchError' ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
let convert ;
try {
convert = ( _ _nccwpck _require _ _ ( 5347 ) . convert ) ;
} catch ( e ) { }
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const INTERNALS = Symbol ( 'Body internals' ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// fix an issue where "PassThrough" isn't a named export for node <10
const PassThrough = Stream . PassThrough ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/ * *
* Body mixin
*
* Ref : https : //fetch.spec.whatwg.org/#body
*
* @ param Stream body Readable stream
* @ param Object opts Response options
* @ return Void
* /
function Body ( body ) {
var _this = this ;
var _ref = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : { } ,
_ref$size = _ref . size ;
let size = _ref$size === undefined ? 0 : _ref$size ;
var _ref$timeout = _ref . timeout ;
let timeout = _ref$timeout === undefined ? 0 : _ref$timeout ;
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 ;
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 ;
} ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Body . prototype = {
get body ( ) {
return this [ INTERNALS ] . body ;
} ,
get bodyUsed ( ) {
return this [ INTERNALS ] . disturbed ;
} ,
/ * *
* Decode response as ArrayBuffer
*
* @ return Promise
* /
arrayBuffer ( ) {
return consumeBody . call ( this ) . then ( function ( buf ) {
return buf . buffer . slice ( buf . byteOffset , buf . byteOffset + buf . byteLength ) ;
} ) ;
} ,
/ * *
* 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
} ) ;
} ) ;
} ,
/ * *
* Decode response as json
*
* @ return Promise
* /
json ( ) {
var _this2 = this ;
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' ) ) ;
}
} ) ;
} ,
/ * *
* Decode response as text
*
* @ return Promise
* /
text ( ) {
return consumeBody . call ( this ) . then ( function ( buffer ) {
return buffer . toString ( ) ;
} ) ;
} ,
/ * *
* Decode response as buffer ( non - spec api )
*
* @ return Promise
* /
buffer ( ) {
return consumeBody . call ( this ) ;
} ,
/ * *
* 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 ;
return consumeBody . call ( this ) . then ( function ( buffer ) {
return convertBody ( buffer , _this3 . headers ) ;
} ) ;
}
2022-06-27 14:17:15 -04:00
} ;
2022-07-11 13:48:02 -04: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 }
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ) ;
}
}
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( this [ INTERNALS ] . disturbed ) {
return Body . Promise . reject ( new TypeError ( ` body used already for: ${ this . url } ` ) ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
this [ INTERNALS ] . disturbed = true ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( this [ INTERNALS ] . error ) {
return Body . Promise . reject ( this [ INTERNALS ] . error ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
let body = this . body ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// body is null
if ( body === null ) {
return Body . Promise . resolve ( Buffer . alloc ( 0 ) ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// body is blob
if ( isBlob ( body ) ) {
body = body . stream ( ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// body is buffer
if ( Buffer . isBuffer ( body ) ) {
return Body . Promise . resolve ( body ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// istanbul ignore if: should never happen
if ( ! ( body instanceof Stream ) ) {
return Body . Promise . resolve ( Buffer . alloc ( 0 ) ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// body is stream
// get ready to actually consume the body
let accum = [ ] ;
let accumBytes = 0 ;
let abort = false ;
return new Body . Promise ( function ( resolve , reject ) {
let resTimeout ;
// 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 ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ) ) ;
}
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
body . on ( 'data' , function ( chunk ) {
if ( abort || chunk === null ) {
return ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
accumBytes += chunk . length ;
accum . push ( chunk ) ;
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
body . on ( 'end' , function ( ) {
if ( abort ) {
return ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
clearTimeout ( resTimeout ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ) ) ;
}
} ) ;
} ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const ct = headers . get ( 'content-type' ) ;
let charset = 'utf-8' ;
let res , str ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// header
if ( ct ) {
res = /charset=([^;]*)/i . exec ( ct ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// no charset in content type, peek at response body for at most 1024 bytes
str = buffer . slice ( 0 , 1024 ) . toString ( ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// html5
if ( ! res && str ) {
res = /<meta.+?charset=(['"])(.+?)\1/i . exec ( str ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// html4
if ( ! res && str ) {
res = /<meta[\s]+?http-equiv=(['"])content-type\1[\s]+?content=(['"])(.+?)\2/i . exec ( str ) ;
if ( ! res ) {
res = /<meta[\s]+?content=(['"])(.+?)\1[\s]+?http-equiv=(['"])content-type\3/i . exec ( str ) ;
if ( res ) {
res . pop ( ) ; // drop last quote
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( res ) {
res = /charset=(.*)/i . exec ( res . pop ( ) ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// xml
if ( ! res && str ) {
res = /<\?xml.+?encoding=(['"])(.+?)\1/i . exec ( str ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// found charset
if ( res ) {
charset = res . pop ( ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// prevent decode issues when sites use incorrect encoding
// ref: https://hsivonen.fi/encoding-menu/
if ( charset === 'gb2312' || charset === 'gbk' ) {
charset = 'gb18030' ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// turn raw buffers into a single utf-8 buffer
return convert ( buffer , 'UTF-8' , charset ) . toString ( ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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' ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ] ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// don't allow cloning a used body
if ( instance . bodyUsed ) {
throw new Error ( 'cannot clone body after it is used' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return body ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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' ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
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 ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
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 ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// expose Promise
Body . Promise = global . Promise ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/ * *
* headers . js
*
* Headers class offers convenient helpers
* /
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const invalidTokenRegex = /[^\^_`a-zA-Z\-0-9!#$%&'*+.|~]/ ;
const invalidHeaderCharRegex = /[^\t\x20-\x7e\x80-\xff]/ ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function validateName ( name ) {
name = ` ${ name } ` ;
if ( invalidTokenRegex . test ( name ) || name === '' ) {
throw new TypeError ( ` ${ name } is not a legal HTTP header name ` ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function validateValue ( value ) {
value = ` ${ value } ` ;
if ( invalidHeaderCharRegex . test ( value ) ) {
throw new TypeError ( ` ${ value } is not a legal HTTP header value ` ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
this [ MAP ] = Object . create ( null ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( init instanceof Headers ) {
const rawHeaders = init . raw ( ) ;
const headerNames = Object . keys ( rawHeaders ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
for ( const headerName of headerNames ) {
for ( const value of rawHeaders [ headerName ] ) {
this . append ( headerName , value ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ) ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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' ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return this [ MAP ] [ key ] . join ( ', ' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
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 ] ;
callback . call ( thisArg , value , name , this ) ;
pairs = getHeaders ( this ) ;
i ++ ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ] ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ] ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ] ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/ * *
* Return raw headers ( non - spec api )
*
* @ return Object
* /
raw ( ) {
return this [ MAP ] ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/ * *
* Get an iterator on keys .
*
* @ return Iterator
* /
keys ( ) {
return createHeadersIterator ( this , 'key' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/ * *
* Get an iterator on values .
*
* @ return Iterator
* /
values ( ) {
return createHeadersIterator ( this , 'value' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/ * *
* Get an iterator on entries .
*
* This is the default iterator of the Headers object .
*
* @ return Iterator
* /
[ Symbol . iterator ] ( ) {
return createHeadersIterator ( this , 'key+value' ) ;
}
}
Headers . prototype . entries = Headers . prototype [ Symbol . iterator ] ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( Headers . prototype , Symbol . toStringTag , {
value : 'Headers' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 }
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function getHeaders ( headers ) {
let kind = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : 'key+value' ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ( ', ' ) ] ;
} ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const INTERNAL = Symbol ( 'internal' ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function createHeadersIterator ( target , kind ) {
const iterator = Object . create ( HeadersIteratorPrototype ) ;
iterator [ INTERNAL ] = {
target ,
kind ,
index : 0
} ;
return iterator ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var _INTERNAL = this [ INTERNAL ] ;
const target = _INTERNAL . target ,
kind = _INTERNAL . kind ,
index = _INTERNAL . index ;
const values = getHeaders ( target , kind ) ;
const len = values . length ;
if ( index >= len ) {
return {
value : undefined ,
done : true
} ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
this [ INTERNAL ] . index = index + 1 ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return {
value : values [ index ] ,
done : false
} ;
}
} , Object . getPrototypeOf ( Object . getPrototypeOf ( [ ] [ Symbol . iterator ] ( ) ) ) ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( HeadersIteratorPrototype , Symbol . toStringTag , {
value : 'HeadersIterator' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ] ) ;
// 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 ] ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return obj ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const INTERNALS$1 = Symbol ( 'Response internals' ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// fix an issue where "STATUS_CODES" aren't a named export for node <10
const STATUS _CODES = http . STATUS _CODES ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ] : { } ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Body . call ( this , body , opts ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const status = opts . status || 200 ;
const headers = new Headers ( opts . headers ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( body != null && ! headers . has ( 'Content-Type' ) ) {
const contentType = extractContentType ( body ) ;
if ( contentType ) {
headers . append ( 'Content-Type' , contentType ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
this [ INTERNALS$1 ] = {
url : opts . url ,
status ,
statusText : opts . statusText || STATUS _CODES [ status ] ,
headers ,
counter : opts . counter
} ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
get url ( ) {
return this [ INTERNALS$1 ] . url || '' ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
get status ( ) {
return this [ INTERNALS$1 ] . status ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/ * *
* Convenience property representing if the request ended normally
* /
get ok ( ) {
return this [ INTERNALS$1 ] . status >= 200 && this [ INTERNALS$1 ] . status < 300 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
get redirected ( ) {
return this [ INTERNALS$1 ] . counter > 0 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
get statusText ( ) {
return this [ INTERNALS$1 ] . statusText ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
get headers ( ) {
return this [ INTERNALS$1 ] . headers ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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
} ) ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Body . mixIn ( Response . prototype ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 }
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( Response . prototype , Symbol . toStringTag , {
value : 'Response' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const INTERNALS$2 = Symbol ( 'Request internals' ) ;
const URL = Url . URL || whatwgUrl . URL ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/ * *
* Wrapper around ` new URL ` to handle arbitrary URLs
*
* @ param { string } urlStr
* @ return { void }
* /
function parseURL ( urlStr ) {
/ *
Check whether the URL is absolute or not
Scheme : https : //tools.ietf.org/html/rfc3986#section-3.1
Absolute URL : https : //tools.ietf.org/html/rfc3986#section-4.3
* /
if ( /^[a-zA-Z][a-zA-Z\d+\-.]*:/ . exec ( urlStr ) ) {
urlStr = new URL ( urlStr ) . toString ( ) ;
}
// Fallback to old implementation for arbitrary URLs
return parse _url ( urlStr ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
const streamDestructionSupported = 'destroy' in Stream . Readable . prototype ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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' ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function isAbortSignal ( signal ) {
const proto = signal && typeof signal === 'object' && Object . getPrototypeOf ( signal ) ;
return ! ! ( proto && proto . constructor . name === 'AbortSignal' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ] : { } ;
let parsedURL ;
// 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 = parseURL ( input . href ) ;
} else {
// coerce input to a string before attempting to parse
parsedURL = parseURL ( ` ${ input } ` ) ;
}
input = { } ;
} else {
parsedURL = parseURL ( input . url ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
let method = init . method || input . method || 'GET' ;
method = method . toUpperCase ( ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
let inputBody = init . body != null ? init . body : isRequest ( input ) && input . body !== null ? clone ( input ) : null ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Body . call ( this , inputBody , {
timeout : init . timeout || input . timeout || 0 ,
size : init . size || input . size || 0
} ) ;
const headers = new Headers ( init . headers || input . headers || { } ) ;
if ( inputBody != null && ! headers . has ( 'Content-Type' ) ) {
const contentType = extractContentType ( inputBody ) ;
if ( contentType ) {
headers . append ( 'Content-Type' , contentType ) ;
}
}
let signal = isRequest ( input ) ? input . signal : null ;
if ( 'signal' in init ) signal = init . signal ;
if ( signal != null && ! isAbortSignal ( signal ) ) {
throw new TypeError ( 'Expected signal to be an instanceof AbortSignal' ) ;
}
this [ INTERNALS$2 ] = {
method ,
redirect : init . redirect || input . redirect || 'follow' ,
headers ,
parsedURL ,
signal
} ;
// 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 ;
}
get method ( ) {
return this [ INTERNALS$2 ] . method ;
}
get url ( ) {
return format _url ( this [ INTERNALS$2 ] . parsedURL ) ;
}
get headers ( ) {
return this [ INTERNALS$2 ] . headers ;
}
get redirect ( ) {
return this [ INTERNALS$2 ] . redirect ;
}
get signal ( ) {
return this [ INTERNALS$2 ] . signal ;
}
/ * *
* Clone this request
*
* @ return Request
* /
clone ( ) {
return new Request ( this ) ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
Body . mixIn ( Request . prototype ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( Request . prototype , Symbol . toStringTag , {
value : 'Request' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperties ( Request . prototype , {
method : { enumerable : true } ,
url : { enumerable : true } ,
headers : { enumerable : true } ,
redirect : { enumerable : true } ,
clone : { enumerable : true } ,
signal : { enumerable : true }
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// fetch step 1.3
if ( ! headers . has ( 'Accept' ) ) {
headers . set ( 'Accept' , '*/*' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// Basic fetch
if ( ! parsedURL . protocol || ! parsedURL . hostname ) {
throw new TypeError ( 'Only absolute URLs are supported' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( ! /^https?:$/ . test ( parsedURL . protocol ) ) {
throw new TypeError ( 'Only HTTP(S) protocols are supported' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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)' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// HTTP-network-or-cache fetch step 2.15
if ( request . compress && ! headers . has ( 'Accept-Encoding' ) ) {
headers . set ( 'Accept-Encoding' , 'gzip,deflate' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
let agent = request . agent ;
if ( typeof agent === 'function' ) {
agent = agent ( parsedURL ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( ! headers . has ( 'Connection' ) && ! agent ) {
headers . set ( 'Connection' , 'close' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// HTTP-network fetch step 4.2
// chunked encoding is handled by Node.js
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return Object . assign ( { } , parsedURL , {
method : request . method ,
headers : exportNodeCompatibleHeaders ( headers ) ,
agent
} ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
/ * *
* abort - error . js
*
* AbortError interface for cancelled requests
* /
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/ * *
* Create AbortError instance
*
* @ param String message Error message for human
* @ return AbortError
* /
function AbortError ( message ) {
Error . call ( this , message ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
this . type = 'aborted' ;
this . message = message ;
// hide custom error implementation details from end-users
Error . captureStackTrace ( this , this . constructor ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
AbortError . prototype = Object . create ( Error . prototype ) ;
AbortError . prototype . constructor = AbortError ;
AbortError . prototype . name = 'AbortError' ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const URL$1 = Url . URL || whatwgUrl . URL ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// fix an issue where "PassThrough", "resolve" aren't a named export for node <10
const PassThrough$1 = Stream . PassThrough ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const isDomainOrSubdomain = function isDomainOrSubdomain ( destination , original ) {
const orig = new URL$1 ( original ) . hostname ;
const dest = new URL$1 ( destination ) . hostname ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return orig === dest || orig [ orig . length - dest . length - 1 ] === '.' && orig . endsWith ( dest ) ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/ * *
* Fetch function
*
* @ param Mixed url Absolute url or Request instance
* @ param Object opts Fetch options
* @ return Promise
* /
function fetch ( url , opts ) {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// allow custom promise
if ( ! fetch . Promise ) {
throw new Error ( 'native promise missing, set fetch.Promise to your favorite alternative' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Body . Promise = fetch . Promise ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const send = ( options . protocol === 'https:' ? https : http ) . request ;
const signal = request . signal ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
let response = null ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ) ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( signal && signal . aborted ) {
abort ( ) ;
return ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const abortAndFinalize = function abortAndFinalize ( ) {
abort ( ) ;
finalize ( ) ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// send request
const req = send ( options ) ;
let reqTimeout ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( signal ) {
signal . addEventListener ( 'abort' , abortAndFinalize ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function finalize ( ) {
req . abort ( ) ;
if ( signal ) signal . removeEventListener ( 'abort' , abortAndFinalize ) ;
clearTimeout ( reqTimeout ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ) ;
} ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
req . on ( 'error' , function ( err ) {
reject ( new FetchError ( ` request to ${ request . url } failed, reason: ${ err . message } ` , 'system' , err ) ) ;
finalize ( ) ;
} ) ;
req . on ( 'response' , function ( res ) {
clearTimeout ( reqTimeout ) ;
const headers = createHeadersLenient ( res . headers ) ;
// HTTP fetch step 5
if ( fetch . isRedirect ( res . statusCode ) ) {
// HTTP fetch step 5.2
const location = headers . get ( 'Location' ) ;
// HTTP fetch step 5.3
let locationURL = null ;
try {
locationURL = location === null ? null : new URL$1 ( location , request . url ) . toString ( ) ;
} catch ( err ) {
// error here can only be invalid URL in Location: header
// do not throw when options.redirect == manual
// let the user extract the errorneous redirect URL
if ( request . redirect !== 'manual' ) {
reject ( new FetchError ( ` uri requested responds with an invalid redirect URL: ${ location } ` , 'invalid-redirect' ) ) ;
finalize ( ) ;
return ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// HTTP fetch step 5.5
switch ( request . redirect ) {
case 'error' :
reject ( new FetchError ( ` uri requested responds with a redirect, 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 ;
}
// HTTP-redirect fetch step 5
if ( request . counter >= request . follow ) {
reject ( new FetchError ( ` maximum redirect reached at: ${ request . url } ` , 'max-redirect' ) ) ;
finalize ( ) ;
return ;
}
// 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 ,
size : request . size
} ;
if ( ! isDomainOrSubdomain ( request . url , locationURL ) ) {
for ( const name of [ 'authorization' , 'www-authenticate' , 'cookie' , 'cookie2' ] ) {
requestOpts . headers . delete ( name ) ;
}
}
// 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 ;
}
// 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' ) ;
}
// HTTP-redirect fetch step 15
resolve ( fetch ( new Request ( locationURL , requestOpts ) ) ) ;
finalize ( ) ;
return ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// prepare response
res . once ( 'end' , function ( ) {
if ( signal ) signal . removeEventListener ( 'abort' , abortAndFinalize ) ;
} ) ;
let body = res . pipe ( new PassThrough$1 ( ) ) ;
const response _options = {
url : request . url ,
status : res . statusCode ,
statusText : res . statusMessage ,
headers : headers ,
size : request . size ,
timeout : request . timeout ,
counter : request . counter
} ;
// HTTP-network fetch step 12.1.1.3
const codings = headers . get ( 'Content-Encoding' ) ;
// 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 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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
} ;
// for gzip
if ( codings == 'gzip' || codings == 'x-gzip' ) {
body = body . pipe ( zlib . createGunzip ( zlibOptions ) ) ;
response = new Response ( body , response _options ) ;
resolve ( response ) ;
return ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// for br
if ( codings == 'br' && typeof zlib . createBrotliDecompress === 'function' ) {
body = body . pipe ( zlib . createBrotliDecompress ( ) ) ;
response = new Response ( body , response _options ) ;
resolve ( response ) ;
return ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// otherwise, use response as-is
response = new Response ( body , response _options ) ;
resolve ( response ) ;
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
writeToStream ( req , request ) ;
} ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
/ * *
* 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 ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// expose Promise
fetch . Promise = global . Promise ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04: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 ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 8992 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"use strict" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var punycode = _ _nccwpck _require _ _ ( 5477 ) ;
var mappingTable = _ _nccwpck _require _ _ ( 1907 ) ;
var PROCESSING _OPTIONS = {
TRANSITIONAL : 0 ,
NONTRANSITIONAL : 1
} ;
function normalize ( str ) { // fix bug in v8
return str . split ( '\u0000' ) . map ( function ( s ) { return s . normalize ( 'NFC' ) ; } ) . join ( '\u0000' ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
function findStatus ( val ) {
var start = 0 ;
var end = mappingTable . length - 1 ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
while ( start <= end ) {
var mid = Math . floor ( ( start + end ) / 2 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var target = mappingTable [ mid ] ;
if ( target [ 0 ] [ 0 ] <= val && target [ 0 ] [ 1 ] >= val ) {
return target ;
} else if ( target [ 0 ] [ 0 ] > val ) {
end = mid - 1 ;
2022-06-27 14:17:15 -04:00
} else {
2022-07-11 13:48:02 -04:00
start = mid + 1 ;
2022-06-27 14:17:15 -04:00
}
}
2022-07-11 13:48:02 -04:00
return null ;
}
var regexAstralSymbols = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g ;
function countSymbols ( string ) {
return string
// replace every surrogate pair with a BMP symbol
. replace ( regexAstralSymbols , '_' )
// then get the length
. length ;
}
function mapChars ( domain _name , useSTD3 , processing _option ) {
var hasError = false ;
var processed = "" ;
var len = countSymbols ( domain _name ) ;
for ( var i = 0 ; i < len ; ++ i ) {
var codePoint = domain _name . codePointAt ( i ) ;
var status = findStatus ( codePoint ) ;
switch ( status [ 1 ] ) {
case "disallowed" :
hasError = true ;
processed += String . fromCodePoint ( codePoint ) ;
break ;
case "ignored" :
break ;
case "mapped" :
processed += String . fromCodePoint . apply ( String , status [ 2 ] ) ;
break ;
case "deviation" :
if ( processing _option === PROCESSING _OPTIONS . TRANSITIONAL ) {
processed += String . fromCodePoint . apply ( String , status [ 2 ] ) ;
} else {
processed += String . fromCodePoint ( codePoint ) ;
}
break ;
case "valid" :
processed += String . fromCodePoint ( codePoint ) ;
break ;
case "disallowed_STD3_mapped" :
if ( useSTD3 ) {
hasError = true ;
processed += String . fromCodePoint ( codePoint ) ;
} else {
processed += String . fromCodePoint . apply ( String , status [ 2 ] ) ;
}
break ;
case "disallowed_STD3_valid" :
if ( useSTD3 ) {
hasError = true ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
processed += String . fromCodePoint ( codePoint ) ;
break ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return {
string : processed ,
error : hasError
} ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
var combiningMarksRegex = /[\u0300-\u036F\u0483-\u0489\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u0610-\u061A\u064B-\u065F\u0670\u06D6-\u06DC\u06DF-\u06E4\u06E7\u06E8\u06EA-\u06ED\u0711\u0730-\u074A\u07A6-\u07B0\u07EB-\u07F3\u0816-\u0819\u081B-\u0823\u0825-\u0827\u0829-\u082D\u0859-\u085B\u08E4-\u0903\u093A-\u093C\u093E-\u094F\u0951-\u0957\u0962\u0963\u0981-\u0983\u09BC\u09BE-\u09C4\u09C7\u09C8\u09CB-\u09CD\u09D7\u09E2\u09E3\u0A01-\u0A03\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A70\u0A71\u0A75\u0A81-\u0A83\u0ABC\u0ABE-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AE2\u0AE3\u0B01-\u0B03\u0B3C\u0B3E-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B62\u0B63\u0B82\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD7\u0C00-\u0C03\u0C3E-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C62\u0C63\u0C81-\u0C83\u0CBC\u0CBE-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CE2\u0CE3\u0D01-\u0D03\u0D3E-\u0D44\u0D46-\u0D48\u0D4A-\u0D4D\u0D57\u0D62\u0D63\u0D82\u0D83\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DF2\u0DF3\u0E31\u0E34-\u0E3A\u0E47-\u0E4E\u0EB1\u0EB4-\u0EB9\u0EBB\u0EBC\u0EC8-\u0ECD\u0F18\u0F19\u0F35\u0F37\u0F39\u0F3E\u0F3F\u0F71-\u0F84\u0F86\u0F87\u0F8D-\u0F97\u0F99-\u0FBC\u0FC6\u102B-\u103E\u1056-\u1059\u105E-\u1060\u1062-\u1064\u1067-\u106D\u1071-\u1074\u1082-\u108D\u108F\u109A-\u109D\u135D-\u135F\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17B4-\u17D3\u17DD\u180B-\u180D\u18A9\u1920-\u192B\u1930-\u193B\u19B0-\u19C0\u19C8\u19C9\u1A17-\u1A1B\u1A55-\u1A5E\u1A60-\u1A7C\u1A7F\u1AB0-\u1ABE\u1B00-\u1B04\u1B34-\u1B44\u1B6B-\u1B73\u1B80-\u1B82\u1BA1-\u1BAD\u1BE6-\u1BF3\u1C24-\u1C37\u1CD0-\u1CD2\u1CD4-\u1CE8\u1CED\u1CF2-\u1CF4\u1CF8\u1CF9\u1DC0-\u1DF5\u1DFC-\u1DFF\u20D0-\u20F0\u2CEF-\u2CF1\u2D7F\u2DE0-\u2DFF\u302A-\u302F\u3099\u309A\uA66F-\uA672\uA674-\uA67D\uA69F\uA6F0\uA6F1\uA802\uA806\uA80B\uA823-\uA827\uA880\uA881\uA8B4-\uA8C4\uA8E0-\uA8F1\uA926-\uA92D\uA947-\uA953\uA980-\uA983\uA9B3-\uA9C0\uA9E5\uAA29-\uAA36\uAA43\uAA4C\uAA4D\uAA7B-\uAA7D\uAAB0\uAAB2-\uAAB4\uAAB7\uAAB8\uAABE\uAABF\uAAC1\uAAEB-\uAAEF\uAAF5\uAAF6\uABE3-\uABEA\uABEC\uABED\uFB1E\uFE00-\uFE0F\uFE20-\uFE2D]|\uD800[\uDDFD\uDEE0\uDF76-\uDF7A]|\uD802[\uDE01-\uDE03\uDE05\uDE06\uDE0C-\uDE0F\uDE38-\uDE3A\uDE3F\uDEE5\uDEE6]|\uD804[\uDC00-\uDC02\uDC38-\uDC46\uDC7F-\uDC82\uDCB0-\uDCBA\uDD00-\uDD02\uDD27-\uDD34\uDD73\uDD80-\uDD82\uDDB3-\uDDC0\uDE2C-\uDE37\uDEDF-\uDEEA\uDF01-\uDF03\uDF3C\uDF3E-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF57\uDF62\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDCB0-\uDCC3\uDDAF-\uDDB5\uDDB8-\uDDC0\uDE30-\uDE40\uDEAB-\uDEB7]|\uD81A[\uDEF0-\uDEF4\uDF30-\uDF36]|\uD81B[\uDF51-\uDF7E\uDF8F-\uDF92]|\uD82F[\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD83A[\uDCD0-\uDCD6]|\uDB40[\uDD00-\uDDEF]/ ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function validateLabel ( label , processing _option ) {
if ( label . substr ( 0 , 4 ) === "xn--" ) {
label = punycode . toUnicode ( label ) ;
processing _option = PROCESSING _OPTIONS . NONTRANSITIONAL ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
var error = false ;
if ( normalize ( label ) !== label ||
( label [ 3 ] === "-" && label [ 4 ] === "-" ) ||
label [ 0 ] === "-" || label [ label . length - 1 ] === "-" ||
label . indexOf ( "." ) !== - 1 ||
label . search ( combiningMarksRegex ) === 0 ) {
error = true ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
var len = countSymbols ( label ) ;
for ( var i = 0 ; i < len ; ++ i ) {
var status = findStatus ( label . codePointAt ( i ) ) ;
if ( ( processing === PROCESSING _OPTIONS . TRANSITIONAL && status [ 1 ] !== "valid" ) ||
( processing === PROCESSING _OPTIONS . NONTRANSITIONAL &&
status [ 1 ] !== "valid" && status [ 1 ] !== "deviation" ) ) {
error = true ;
break ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return {
label : label ,
error : error
} ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
function processing ( domain _name , useSTD3 , processing _option ) {
var result = mapChars ( domain _name , useSTD3 , processing _option ) ;
result . string = normalize ( result . string ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var labels = result . string . split ( "." ) ;
for ( var i = 0 ; i < labels . length ; ++ i ) {
2022-06-27 14:17:15 -04:00
try {
2022-07-11 13:48:02 -04:00
var validation = validateLabel ( labels [ i ] ) ;
labels [ i ] = validation . label ;
result . error = result . error || validation . error ;
} catch ( e ) {
result . error = true ;
2022-06-27 14:17:15 -04:00
}
}
2022-07-11 13:48:02 -04:00
return {
string : labels . join ( "." ) ,
error : result . error
} ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
module . exports . toASCII = function ( domain _name , useSTD3 , processing _option , verifyDnsLength ) {
var result = processing ( domain _name , useSTD3 , processing _option ) ;
var labels = result . string . split ( "." ) ;
labels = labels . map ( function ( l ) {
try {
return punycode . toASCII ( l ) ;
} catch ( e ) {
result . error = true ;
return l ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( verifyDnsLength ) {
var total = labels . slice ( 0 , labels . length - 1 ) . join ( "." ) . length ;
if ( total . length > 253 || total . length === 0 ) {
result . error = true ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
for ( var i = 0 ; i < labels . length ; ++ i ) {
if ( labels . length > 63 || labels . length === 0 ) {
result . error = true ;
break ;
}
2022-06-27 14:17:15 -04:00
}
}
2022-07-11 13:48:02 -04:00
if ( result . error ) return null ;
return labels . join ( "." ) ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports . toUnicode = function ( domain _name , useSTD3 ) {
var result = processing ( domain _name , useSTD3 , PROCESSING _OPTIONS . NONTRANSITIONAL ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return {
domain : result . string ,
error : result . error
} ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports . PROCESSING _OPTIONS = PROCESSING _OPTIONS ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 7295 :
/***/ ( ( module ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"use strict" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var conversions = { } ;
module . exports = conversions ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function sign ( x ) {
return x < 0 ? - 1 : 1 ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
function evenRound ( x ) {
// Round x to the nearest integer, choosing the even integer if it lies halfway between two.
if ( ( x % 1 ) === 0.5 && ( x & 1 ) === 0 ) { // [even number].5; round down (i.e. floor)
return Math . floor ( x ) ;
} else {
return Math . round ( x ) ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
function createNumberConversion ( bitLength , typeOpts ) {
if ( ! typeOpts . unsigned ) {
-- bitLength ;
}
const lowerBound = typeOpts . unsigned ? 0 : - Math . pow ( 2 , bitLength ) ;
const upperBound = Math . pow ( 2 , bitLength ) - 1 ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const moduloVal = typeOpts . moduloBitLength ? Math . pow ( 2 , typeOpts . moduloBitLength ) : Math . pow ( 2 , bitLength ) ;
const moduloBound = typeOpts . moduloBitLength ? Math . pow ( 2 , typeOpts . moduloBitLength - 1 ) : Math . pow ( 2 , bitLength - 1 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return function ( V , opts ) {
if ( ! opts ) opts = { } ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
let x = + V ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( opts . enforceRange ) {
if ( ! Number . isFinite ( x ) ) {
throw new TypeError ( "Argument is not a finite number" ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
x = sign ( x ) * Math . floor ( Math . abs ( x ) ) ;
if ( x < lowerBound || x > upperBound ) {
throw new TypeError ( "Argument is not in byte range" ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return x ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( ! isNaN ( x ) && opts . clamp ) {
x = evenRound ( x ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( x < lowerBound ) x = lowerBound ;
if ( x > upperBound ) x = upperBound ;
return x ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( ! Number . isFinite ( x ) || x === 0 ) {
return 0 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
x = sign ( x ) * Math . floor ( Math . abs ( x ) ) ;
x = x % moduloVal ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( ! typeOpts . unsigned && x >= moduloBound ) {
return x - moduloVal ;
} else if ( typeOpts . unsigned ) {
if ( x < 0 ) {
x += moduloVal ;
} else if ( x === - 0 ) { // don't return negative zero
return 0 ;
}
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return x ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
conversions [ "void" ] = function ( ) {
return undefined ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
conversions [ "boolean" ] = function ( val ) {
return ! ! val ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
conversions [ "byte" ] = createNumberConversion ( 8 , { unsigned : false } ) ;
conversions [ "octet" ] = createNumberConversion ( 8 , { unsigned : true } ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
conversions [ "short" ] = createNumberConversion ( 16 , { unsigned : false } ) ;
conversions [ "unsigned short" ] = createNumberConversion ( 16 , { unsigned : true } ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
conversions [ "long" ] = createNumberConversion ( 32 , { unsigned : false } ) ;
conversions [ "unsigned long" ] = createNumberConversion ( 32 , { unsigned : true } ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
conversions [ "long long" ] = createNumberConversion ( 32 , { unsigned : false , moduloBitLength : 64 } ) ;
conversions [ "unsigned long long" ] = createNumberConversion ( 32 , { unsigned : true , moduloBitLength : 64 } ) ;
conversions [ "double" ] = function ( V ) {
const x = + V ;
if ( ! Number . isFinite ( x ) ) {
throw new TypeError ( "Argument is not a finite floating-point value" ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return x ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
conversions [ "unrestricted double" ] = function ( V ) {
const x = + V ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( isNaN ( x ) ) {
throw new TypeError ( "Argument is NaN" ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return x ;
} ;
// not quite valid, but good enough for JS
conversions [ "float" ] = conversions [ "double" ] ;
conversions [ "unrestricted float" ] = conversions [ "unrestricted double" ] ;
conversions [ "DOMString" ] = function ( V , opts ) {
if ( ! opts ) opts = { } ;
if ( opts . treatNullAsEmptyString && V === null ) {
return "" ;
}
return String ( V ) ;
} ;
conversions [ "ByteString" ] = function ( V , opts ) {
const x = String ( V ) ;
let c = undefined ;
for ( let i = 0 ; ( c = x . codePointAt ( i ) ) !== undefined ; ++ i ) {
if ( c > 255 ) {
throw new TypeError ( "Argument is not a valid bytestring" ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
}
return x ;
} ;
conversions [ "USVString" ] = function ( V ) {
const S = String ( V ) ;
const n = S . length ;
const U = [ ] ;
for ( let i = 0 ; i < n ; ++ i ) {
const c = S . charCodeAt ( i ) ;
if ( c < 0xD800 || c > 0xDFFF ) {
U . push ( String . fromCodePoint ( c ) ) ;
} else if ( 0xDC00 <= c && c <= 0xDFFF ) {
U . push ( String . fromCodePoint ( 0xFFFD ) ) ;
2022-06-27 14:17:15 -04:00
} else {
2022-07-11 13:48:02 -04:00
if ( i === n - 1 ) {
U . push ( String . fromCodePoint ( 0xFFFD ) ) ;
} else {
const d = S . charCodeAt ( i + 1 ) ;
if ( 0xDC00 <= d && d <= 0xDFFF ) {
const a = c & 0x3FF ;
const b = d & 0x3FF ;
U . push ( String . fromCodePoint ( ( 2 << 15 ) + ( 2 << 9 ) * a + b ) ) ;
++ i ;
} else {
U . push ( String . fromCodePoint ( 0xFFFD ) ) ;
}
}
2022-06-27 14:17:15 -04:00
}
}
2022-07-11 13:48:02 -04:00
return U . join ( '' ) ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
conversions [ "Date" ] = function ( V , opts ) {
if ( ! ( V instanceof Date ) ) {
throw new TypeError ( "Argument is not a Date object" ) ;
}
if ( isNaN ( V ) ) {
return undefined ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return V ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
conversions [ "RegExp" ] = function ( V , opts ) {
if ( ! ( V instanceof RegExp ) ) {
V = new RegExp ( V ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return V ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 6125 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
const usm = _ _nccwpck _require _ _ ( 7783 ) ;
exports . implementation = class URLImpl {
constructor ( constructorArgs ) {
const url = constructorArgs [ 0 ] ;
const base = constructorArgs [ 1 ] ;
let parsedBase = null ;
if ( base !== undefined ) {
parsedBase = usm . basicURLParse ( base ) ;
if ( parsedBase === "failure" ) {
throw new TypeError ( "Invalid base URL" ) ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
const parsedURL = usm . basicURLParse ( url , { baseURL : parsedBase } ) ;
if ( parsedURL === "failure" ) {
throw new TypeError ( "Invalid URL" ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
this . _url = parsedURL ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// TODO: query stuff
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
get href ( ) {
return usm . serializeURL ( this . _url ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
set href ( v ) {
const parsedURL = usm . basicURLParse ( v ) ;
if ( parsedURL === "failure" ) {
throw new TypeError ( "Invalid URL" ) ;
}
this . _url = parsedURL ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
get origin ( ) {
return usm . serializeURLOrigin ( this . _url ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
get protocol ( ) {
return this . _url . scheme + ":" ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
set protocol ( v ) {
usm . basicURLParse ( v + ":" , { url : this . _url , stateOverride : "scheme start" } ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
get username ( ) {
return this . _url . username ;
}
set username ( v ) {
if ( usm . cannotHaveAUsernamePasswordPort ( this . _url ) ) {
return ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
usm . setTheUsername ( this . _url , v ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
get password ( ) {
return this . _url . password ;
}
set password ( v ) {
if ( usm . cannotHaveAUsernamePasswordPort ( this . _url ) ) {
return ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
usm . setThePassword ( this . _url , v ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
get host ( ) {
const url = this . _url ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( url . host === null ) {
return "" ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
if ( url . port === null ) {
return usm . serializeHost ( url . host ) ;
}
return usm . serializeHost ( url . host ) + ":" + usm . serializeInteger ( url . port ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
set host ( v ) {
if ( this . _url . cannotBeABaseURL ) {
return ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
usm . basicURLParse ( v , { url : this . _url , stateOverride : "host" } ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
get hostname ( ) {
if ( this . _url . host === null ) {
return "" ;
}
return usm . serializeHost ( this . _url . host ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
set hostname ( v ) {
if ( this . _url . cannotBeABaseURL ) {
return ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
usm . basicURLParse ( v , { url : this . _url , stateOverride : "hostname" } ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
get port ( ) {
if ( this . _url . port === null ) {
return "" ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return usm . serializeInteger ( this . _url . port ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
set port ( v ) {
if ( usm . cannotHaveAUsernamePasswordPort ( this . _url ) ) {
return ;
}
if ( v === "" ) {
this . _url . port = null ;
} else {
usm . basicURLParse ( v , { url : this . _url , stateOverride : "port" } ) ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
get pathname ( ) {
if ( this . _url . cannotBeABaseURL ) {
return this . _url . path [ 0 ] ;
}
if ( this . _url . path . length === 0 ) {
return "" ;
}
return "/" + this . _url . path . join ( "/" ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
set pathname ( v ) {
if ( this . _url . cannotBeABaseURL ) {
return ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
this . _url . path = [ ] ;
usm . basicURLParse ( v , { url : this . _url , stateOverride : "path start" } ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
get search ( ) {
if ( this . _url . query === null || this . _url . query === "" ) {
return "" ;
}
return "?" + this . _url . query ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
set search ( v ) {
// TODO: query stuff
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const url = this . _url ;
if ( v === "" ) {
url . query = null ;
return ;
}
const input = v [ 0 ] === "?" ? v . substring ( 1 ) : v ;
url . query = "" ;
usm . basicURLParse ( input , { url , stateOverride : "query" } ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
get hash ( ) {
if ( this . _url . fragment === null || this . _url . fragment === "" ) {
return "" ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
return "#" + this . _url . fragment ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
set hash ( v ) {
if ( v === "" ) {
this . _url . fragment = null ;
return ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const input = v [ 0 ] === "#" ? v . substring ( 1 ) : v ;
this . _url . fragment = "" ;
usm . basicURLParse ( input , { url : this . _url , stateOverride : "fragment" } ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
toJSON ( ) {
return this . href ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 8570 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"use strict" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const conversions = _ _nccwpck _require _ _ ( 7295 ) ;
const utils = _ _nccwpck _require _ _ ( 6048 ) ;
const Impl = _ _nccwpck _require _ _ ( 6125 ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
const impl = utils . implSymbol ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function URL ( url ) {
if ( ! this || this [ impl ] || ! ( this instanceof URL ) ) {
throw new TypeError ( "Failed to construct 'URL': Please use the 'new' operator, this DOM object constructor cannot be called as a function." ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
if ( arguments . length < 1 ) {
throw new TypeError ( "Failed to construct 'URL': 1 argument required, but only " + arguments . length + " present." ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
const args = [ ] ;
for ( let i = 0 ; i < arguments . length && i < 2 ; ++ i ) {
args [ i ] = arguments [ i ] ;
}
args [ 0 ] = conversions [ "USVString" ] ( args [ 0 ] ) ;
if ( args [ 1 ] !== undefined ) {
args [ 1 ] = conversions [ "USVString" ] ( args [ 1 ] ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
module . exports . setup ( this , args ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
URL . prototype . toJSON = function toJSON ( ) {
if ( ! this || ! module . exports . is ( this ) ) {
throw new TypeError ( "Illegal invocation" ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
const args = [ ] ;
for ( let i = 0 ; i < arguments . length && i < 0 ; ++ i ) {
args [ i ] = arguments [ i ] ;
}
return this [ impl ] . toJSON . apply ( this [ impl ] , args ) ;
} ;
Object . defineProperty ( URL . prototype , "href" , {
get ( ) {
return this [ impl ] . href ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . href = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
URL . prototype . toString = function ( ) {
if ( ! this || ! module . exports . is ( this ) ) {
throw new TypeError ( "Illegal invocation" ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return this . href ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( URL . prototype , "origin" , {
get ( ) {
return this [ impl ] . origin ;
} ,
enumerable : true ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( URL . prototype , "protocol" , {
get ( ) {
return this [ impl ] . protocol ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . protocol = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( URL . prototype , "username" , {
get ( ) {
return this [ impl ] . username ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . username = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( URL . prototype , "password" , {
get ( ) {
return this [ impl ] . password ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . password = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( URL . prototype , "host" , {
get ( ) {
return this [ impl ] . host ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . host = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( URL . prototype , "hostname" , {
get ( ) {
return this [ impl ] . hostname ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . hostname = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( URL . prototype , "port" , {
get ( ) {
return this [ impl ] . port ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . port = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( URL . prototype , "pathname" , {
get ( ) {
return this [ impl ] . pathname ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . pathname = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( URL . prototype , "search" , {
get ( ) {
return this [ impl ] . search ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . search = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
Object . defineProperty ( URL . prototype , "hash" , {
get ( ) {
return this [ impl ] . hash ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . hash = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports = {
is ( obj ) {
return ! ! obj && obj [ impl ] instanceof Impl . implementation ;
} ,
create ( constructorArgs , privateData ) {
let obj = Object . create ( URL . prototype ) ;
this . setup ( obj , constructorArgs , privateData ) ;
return obj ;
} ,
setup ( obj , constructorArgs , privateData ) {
if ( ! privateData ) privateData = { } ;
privateData . wrapper = obj ;
obj [ impl ] = new Impl . implementation ( constructorArgs , privateData ) ;
obj [ impl ] [ utils . wrapperSymbol ] = obj ;
} ,
interface : URL ,
expose : {
Window : { URL : URL } ,
Worker : { URL : URL }
}
2022-06-27 14:17:15 -04:00
} ;
2022-07-11 13:48:02 -04:00
2022-06-27 14:17:15 -04:00
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 2752 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
exports . URL = _ _nccwpck _require _ _ ( 8570 ) [ "interface" ] ;
exports . serializeURL = _ _nccwpck _require _ _ ( 7783 ) . serializeURL ;
exports . serializeURLOrigin = _ _nccwpck _require _ _ ( 7783 ) . serializeURLOrigin ;
exports . basicURLParse = _ _nccwpck _require _ _ ( 7783 ) . basicURLParse ;
exports . setTheUsername = _ _nccwpck _require _ _ ( 7783 ) . setTheUsername ;
exports . setThePassword = _ _nccwpck _require _ _ ( 7783 ) . setThePassword ;
exports . serializeHost = _ _nccwpck _require _ _ ( 7783 ) . serializeHost ;
exports . serializeInteger = _ _nccwpck _require _ _ ( 7783 ) . serializeInteger ;
exports . parseURL = _ _nccwpck _require _ _ ( 7783 ) . parseURL ;
2022-06-27 14:17:15 -04:00
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 7783 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-06-27 14:17:15 -04:00
"use strict" ;
2022-07-11 13:48:02 -04:00
const punycode = _ _nccwpck _require _ _ ( 5477 ) ;
const tr46 = _ _nccwpck _require _ _ ( 8992 ) ;
const specialSchemes = {
ftp : 21 ,
file : null ,
gopher : 70 ,
http : 80 ,
https : 443 ,
ws : 80 ,
wss : 443
} ;
const failure = Symbol ( "failure" ) ;
function countSymbols ( str ) {
return punycode . ucs2 . decode ( str ) . length ;
}
function at ( input , idx ) {
const c = input [ idx ] ;
return isNaN ( c ) ? undefined : String . fromCodePoint ( c ) ;
}
function isASCIIDigit ( c ) {
return c >= 0x30 && c <= 0x39 ;
}
function isASCIIAlpha ( c ) {
return ( c >= 0x41 && c <= 0x5A ) || ( c >= 0x61 && c <= 0x7A ) ;
}
function isASCIIAlphanumeric ( c ) {
return isASCIIAlpha ( c ) || isASCIIDigit ( c ) ;
}
function isASCIIHex ( c ) {
return isASCIIDigit ( c ) || ( c >= 0x41 && c <= 0x46 ) || ( c >= 0x61 && c <= 0x66 ) ;
}
function isSingleDot ( buffer ) {
return buffer === "." || buffer . toLowerCase ( ) === "%2e" ;
}
function isDoubleDot ( buffer ) {
buffer = buffer . toLowerCase ( ) ;
return buffer === ".." || buffer === "%2e." || buffer === ".%2e" || buffer === "%2e%2e" ;
}
function isWindowsDriveLetterCodePoints ( cp1 , cp2 ) {
return isASCIIAlpha ( cp1 ) && ( cp2 === 58 || cp2 === 124 ) ;
}
function isWindowsDriveLetterString ( string ) {
return string . length === 2 && isASCIIAlpha ( string . codePointAt ( 0 ) ) && ( string [ 1 ] === ":" || string [ 1 ] === "|" ) ;
}
function isNormalizedWindowsDriveLetterString ( string ) {
return string . length === 2 && isASCIIAlpha ( string . codePointAt ( 0 ) ) && string [ 1 ] === ":" ;
}
function containsForbiddenHostCodePoint ( string ) {
return string . search ( /\u0000|\u0009|\u000A|\u000D|\u0020|#|%|\/|:|\?|@|\[|\\|\]/ ) !== - 1 ;
}
function containsForbiddenHostCodePointExcludingPercent ( string ) {
return string . search ( /\u0000|\u0009|\u000A|\u000D|\u0020|#|\/|:|\?|@|\[|\\|\]/ ) !== - 1 ;
}
function isSpecialScheme ( scheme ) {
return specialSchemes [ scheme ] !== undefined ;
}
function isSpecial ( url ) {
return isSpecialScheme ( url . scheme ) ;
}
function defaultPort ( scheme ) {
return specialSchemes [ scheme ] ;
}
function percentEncode ( c ) {
let hex = c . toString ( 16 ) . toUpperCase ( ) ;
if ( hex . length === 1 ) {
hex = "0" + hex ;
}
return "%" + hex ;
}
function utf8PercentEncode ( c ) {
const buf = new Buffer ( c ) ;
let str = "" ;
for ( let i = 0 ; i < buf . length ; ++ i ) {
str += percentEncode ( buf [ i ] ) ;
}
return str ;
}
function utf8PercentDecode ( str ) {
const input = new Buffer ( str ) ;
const output = [ ] ;
for ( let i = 0 ; i < input . length ; ++ i ) {
if ( input [ i ] !== 37 ) {
output . push ( input [ i ] ) ;
} else if ( input [ i ] === 37 && isASCIIHex ( input [ i + 1 ] ) && isASCIIHex ( input [ i + 2 ] ) ) {
output . push ( parseInt ( input . slice ( i + 1 , i + 3 ) . toString ( ) , 16 ) ) ;
i += 2 ;
} else {
output . push ( input [ i ] ) ;
}
}
return new Buffer ( output ) . toString ( ) ;
}
function isC0ControlPercentEncode ( c ) {
return c <= 0x1F || c > 0x7E ;
}
const extraPathPercentEncodeSet = new Set ( [ 32 , 34 , 35 , 60 , 62 , 63 , 96 , 123 , 125 ] ) ;
function isPathPercentEncode ( c ) {
return isC0ControlPercentEncode ( c ) || extraPathPercentEncodeSet . has ( c ) ;
}
const extraUserinfoPercentEncodeSet =
new Set ( [ 47 , 58 , 59 , 61 , 64 , 91 , 92 , 93 , 94 , 124 ] ) ;
function isUserinfoPercentEncode ( c ) {
return isPathPercentEncode ( c ) || extraUserinfoPercentEncodeSet . has ( c ) ;
}
function percentEncodeChar ( c , encodeSetPredicate ) {
const cStr = String . fromCodePoint ( c ) ;
if ( encodeSetPredicate ( c ) ) {
return utf8PercentEncode ( cStr ) ;
}
return cStr ;
}
function parseIPv4Number ( input ) {
let R = 10 ;
if ( input . length >= 2 && input . charAt ( 0 ) === "0" && input . charAt ( 1 ) . toLowerCase ( ) === "x" ) {
input = input . substring ( 2 ) ;
R = 16 ;
} else if ( input . length >= 2 && input . charAt ( 0 ) === "0" ) {
input = input . substring ( 1 ) ;
R = 8 ;
}
if ( input === "" ) {
return 0 ;
}
const regex = R === 10 ? /[^0-9]/ : ( R === 16 ? /[^0-9A-Fa-f]/ : /[^0-7]/ ) ;
if ( regex . test ( input ) ) {
return failure ;
}
return parseInt ( input , R ) ;
}
function parseIPv4 ( input ) {
const parts = input . split ( "." ) ;
if ( parts [ parts . length - 1 ] === "" ) {
if ( parts . length > 1 ) {
parts . pop ( ) ;
}
}
if ( parts . length > 4 ) {
return input ;
}
const numbers = [ ] ;
for ( const part of parts ) {
if ( part === "" ) {
return input ;
}
const n = parseIPv4Number ( part ) ;
if ( n === failure ) {
return input ;
}
numbers . push ( n ) ;
}
for ( let i = 0 ; i < numbers . length - 1 ; ++ i ) {
if ( numbers [ i ] > 255 ) {
return failure ;
}
}
if ( numbers [ numbers . length - 1 ] >= Math . pow ( 256 , 5 - numbers . length ) ) {
return failure ;
}
let ipv4 = numbers . pop ( ) ;
let counter = 0 ;
for ( const n of numbers ) {
ipv4 += n * Math . pow ( 256 , 3 - counter ) ;
++ counter ;
}
return ipv4 ;
}
function serializeIPv4 ( address ) {
let output = "" ;
let n = address ;
for ( let i = 1 ; i <= 4 ; ++ i ) {
output = String ( n % 256 ) + output ;
if ( i !== 4 ) {
output = "." + output ;
}
n = Math . floor ( n / 256 ) ;
}
return output ;
}
function parseIPv6 ( input ) {
const address = [ 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 ] ;
let pieceIndex = 0 ;
let compress = null ;
let pointer = 0 ;
input = punycode . ucs2 . decode ( input ) ;
if ( input [ pointer ] === 58 ) {
if ( input [ pointer + 1 ] !== 58 ) {
return failure ;
}
pointer += 2 ;
++ pieceIndex ;
compress = pieceIndex ;
}
while ( pointer < input . length ) {
if ( pieceIndex === 8 ) {
return failure ;
}
if ( input [ pointer ] === 58 ) {
if ( compress !== null ) {
return failure ;
}
++ pointer ;
++ pieceIndex ;
compress = pieceIndex ;
continue ;
}
let value = 0 ;
let length = 0 ;
while ( length < 4 && isASCIIHex ( input [ pointer ] ) ) {
value = value * 0x10 + parseInt ( at ( input , pointer ) , 16 ) ;
++ pointer ;
++ length ;
}
if ( input [ pointer ] === 46 ) {
if ( length === 0 ) {
return failure ;
}
pointer -= length ;
if ( pieceIndex > 6 ) {
return failure ;
}
let numbersSeen = 0 ;
while ( input [ pointer ] !== undefined ) {
let ipv4Piece = null ;
if ( numbersSeen > 0 ) {
if ( input [ pointer ] === 46 && numbersSeen < 4 ) {
++ pointer ;
} else {
return failure ;
}
}
if ( ! isASCIIDigit ( input [ pointer ] ) ) {
return failure ;
}
while ( isASCIIDigit ( input [ pointer ] ) ) {
const number = parseInt ( at ( input , pointer ) ) ;
if ( ipv4Piece === null ) {
ipv4Piece = number ;
} else if ( ipv4Piece === 0 ) {
return failure ;
} else {
ipv4Piece = ipv4Piece * 10 + number ;
}
if ( ipv4Piece > 255 ) {
return failure ;
}
++ pointer ;
}
address [ pieceIndex ] = address [ pieceIndex ] * 0x100 + ipv4Piece ;
++ numbersSeen ;
if ( numbersSeen === 2 || numbersSeen === 4 ) {
++ pieceIndex ;
}
}
if ( numbersSeen !== 4 ) {
return failure ;
}
break ;
} else if ( input [ pointer ] === 58 ) {
++ pointer ;
if ( input [ pointer ] === undefined ) {
return failure ;
}
} else if ( input [ pointer ] !== undefined ) {
return failure ;
}
address [ pieceIndex ] = value ;
++ pieceIndex ;
}
if ( compress !== null ) {
let swaps = pieceIndex - compress ;
pieceIndex = 7 ;
while ( pieceIndex !== 0 && swaps > 0 ) {
const temp = address [ compress + swaps - 1 ] ;
address [ compress + swaps - 1 ] = address [ pieceIndex ] ;
address [ pieceIndex ] = temp ;
-- pieceIndex ;
-- swaps ;
}
} else if ( compress === null && pieceIndex !== 8 ) {
return failure ;
}
return address ;
}
function serializeIPv6 ( address ) {
let output = "" ;
const seqResult = findLongestZeroSequence ( address ) ;
const compress = seqResult . idx ;
let ignore0 = false ;
for ( let pieceIndex = 0 ; pieceIndex <= 7 ; ++ pieceIndex ) {
if ( ignore0 && address [ pieceIndex ] === 0 ) {
continue ;
} else if ( ignore0 ) {
ignore0 = false ;
}
if ( compress === pieceIndex ) {
const separator = pieceIndex === 0 ? "::" : ":" ;
output += separator ;
ignore0 = true ;
continue ;
}
output += address [ pieceIndex ] . toString ( 16 ) ;
if ( pieceIndex !== 7 ) {
output += ":" ;
}
}
return output ;
}
function parseHost ( input , isSpecialArg ) {
if ( input [ 0 ] === "[" ) {
if ( input [ input . length - 1 ] !== "]" ) {
return failure ;
}
return parseIPv6 ( input . substring ( 1 , input . length - 1 ) ) ;
}
if ( ! isSpecialArg ) {
return parseOpaqueHost ( input ) ;
}
const domain = utf8PercentDecode ( input ) ;
const asciiDomain = tr46 . toASCII ( domain , false , tr46 . PROCESSING _OPTIONS . NONTRANSITIONAL , false ) ;
if ( asciiDomain === null ) {
return failure ;
}
if ( containsForbiddenHostCodePoint ( asciiDomain ) ) {
return failure ;
}
const ipv4Host = parseIPv4 ( asciiDomain ) ;
if ( typeof ipv4Host === "number" || ipv4Host === failure ) {
return ipv4Host ;
}
return asciiDomain ;
}
function parseOpaqueHost ( input ) {
if ( containsForbiddenHostCodePointExcludingPercent ( input ) ) {
return failure ;
}
let output = "" ;
const decoded = punycode . ucs2 . decode ( input ) ;
for ( let i = 0 ; i < decoded . length ; ++ i ) {
output += percentEncodeChar ( decoded [ i ] , isC0ControlPercentEncode ) ;
}
return output ;
}
function findLongestZeroSequence ( arr ) {
let maxIdx = null ;
let maxLen = 1 ; // only find elements > 1
let currStart = null ;
let currLen = 0 ;
for ( let i = 0 ; i < arr . length ; ++ i ) {
if ( arr [ i ] !== 0 ) {
if ( currLen > maxLen ) {
maxIdx = currStart ;
maxLen = currLen ;
}
currStart = null ;
currLen = 0 ;
} else {
if ( currStart === null ) {
currStart = i ;
}
++ currLen ;
}
}
// if trailing zeros
if ( currLen > maxLen ) {
maxIdx = currStart ;
maxLen = currLen ;
}
return {
idx : maxIdx ,
len : maxLen
} ;
}
function serializeHost ( host ) {
if ( typeof host === "number" ) {
return serializeIPv4 ( host ) ;
}
// IPv6 serializer
if ( host instanceof Array ) {
return "[" + serializeIPv6 ( host ) + "]" ;
}
return host ;
}
function trimControlChars ( url ) {
return url . replace ( /^[\u0000-\u001F\u0020]+|[\u0000-\u001F\u0020]+$/g , "" ) ;
}
function trimTabAndNewline ( url ) {
return url . replace ( /\u0009|\u000A|\u000D/g , "" ) ;
}
function shortenPath ( url ) {
const path = url . path ;
if ( path . length === 0 ) {
return ;
}
if ( url . scheme === "file" && path . length === 1 && isNormalizedWindowsDriveLetter ( path [ 0 ] ) ) {
return ;
}
path . pop ( ) ;
}
function includesCredentials ( url ) {
return url . username !== "" || url . password !== "" ;
}
function cannotHaveAUsernamePasswordPort ( url ) {
return url . host === null || url . host === "" || url . cannotBeABaseURL || url . scheme === "file" ;
}
function isNormalizedWindowsDriveLetter ( string ) {
return /^[A-Za-z]:$/ . test ( string ) ;
}
function URLStateMachine ( input , base , encodingOverride , url , stateOverride ) {
this . pointer = 0 ;
this . input = input ;
this . base = base || null ;
this . encodingOverride = encodingOverride || "utf-8" ;
this . stateOverride = stateOverride ;
this . url = url ;
this . failure = false ;
this . parseError = false ;
if ( ! this . url ) {
this . url = {
scheme : "" ,
username : "" ,
password : "" ,
host : null ,
port : null ,
path : [ ] ,
query : null ,
fragment : null ,
cannotBeABaseURL : false
} ;
const res = trimControlChars ( this . input ) ;
if ( res !== this . input ) {
this . parseError = true ;
}
this . input = res ;
}
const res = trimTabAndNewline ( this . input ) ;
if ( res !== this . input ) {
this . parseError = true ;
}
this . input = res ;
this . state = stateOverride || "scheme start" ;
this . buffer = "" ;
this . atFlag = false ;
this . arrFlag = false ;
this . passwordTokenSeenFlag = false ;
this . input = punycode . ucs2 . decode ( this . input ) ;
for ( ; this . pointer <= this . input . length ; ++ this . pointer ) {
const c = this . input [ this . pointer ] ;
const cStr = isNaN ( c ) ? undefined : String . fromCodePoint ( c ) ;
// exec state machine
const ret = this [ "parse " + this . state ] ( c , cStr ) ;
if ( ! ret ) {
break ; // terminate algorithm
} else if ( ret === failure ) {
this . failure = true ;
break ;
}
}
}
URLStateMachine . prototype [ "parse scheme start" ] = function parseSchemeStart ( c , cStr ) {
if ( isASCIIAlpha ( c ) ) {
this . buffer += cStr . toLowerCase ( ) ;
this . state = "scheme" ;
} else if ( ! this . stateOverride ) {
this . state = "no scheme" ;
-- this . pointer ;
} else {
this . parseError = true ;
return failure ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse scheme" ] = function parseScheme ( c , cStr ) {
if ( isASCIIAlphanumeric ( c ) || c === 43 || c === 45 || c === 46 ) {
this . buffer += cStr . toLowerCase ( ) ;
} else if ( c === 58 ) {
if ( this . stateOverride ) {
if ( isSpecial ( this . url ) && ! isSpecialScheme ( this . buffer ) ) {
return false ;
}
if ( ! isSpecial ( this . url ) && isSpecialScheme ( this . buffer ) ) {
return false ;
}
if ( ( includesCredentials ( this . url ) || this . url . port !== null ) && this . buffer === "file" ) {
return false ;
}
if ( this . url . scheme === "file" && ( this . url . host === "" || this . url . host === null ) ) {
return false ;
}
}
this . url . scheme = this . buffer ;
this . buffer = "" ;
if ( this . stateOverride ) {
return false ;
}
if ( this . url . scheme === "file" ) {
if ( this . input [ this . pointer + 1 ] !== 47 || this . input [ this . pointer + 2 ] !== 47 ) {
this . parseError = true ;
}
this . state = "file" ;
} else if ( isSpecial ( this . url ) && this . base !== null && this . base . scheme === this . url . scheme ) {
this . state = "special relative or authority" ;
} else if ( isSpecial ( this . url ) ) {
this . state = "special authority slashes" ;
} else if ( this . input [ this . pointer + 1 ] === 47 ) {
this . state = "path or authority" ;
++ this . pointer ;
} else {
this . url . cannotBeABaseURL = true ;
this . url . path . push ( "" ) ;
this . state = "cannot-be-a-base-URL path" ;
}
} else if ( ! this . stateOverride ) {
this . buffer = "" ;
this . state = "no scheme" ;
this . pointer = - 1 ;
} else {
this . parseError = true ;
return failure ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse no scheme" ] = function parseNoScheme ( c ) {
if ( this . base === null || ( this . base . cannotBeABaseURL && c !== 35 ) ) {
return failure ;
} else if ( this . base . cannotBeABaseURL && c === 35 ) {
this . url . scheme = this . base . scheme ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = this . base . query ;
this . url . fragment = "" ;
this . url . cannotBeABaseURL = true ;
this . state = "fragment" ;
} else if ( this . base . scheme === "file" ) {
this . state = "file" ;
-- this . pointer ;
} else {
this . state = "relative" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse special relative or authority" ] = function parseSpecialRelativeOrAuthority ( c ) {
if ( c === 47 && this . input [ this . pointer + 1 ] === 47 ) {
this . state = "special authority ignore slashes" ;
++ this . pointer ;
} else {
this . parseError = true ;
this . state = "relative" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse path or authority" ] = function parsePathOrAuthority ( c ) {
if ( c === 47 ) {
this . state = "authority" ;
} else {
this . state = "path" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse relative" ] = function parseRelative ( c ) {
this . url . scheme = this . base . scheme ;
if ( isNaN ( c ) ) {
this . url . username = this . base . username ;
this . url . password = this . base . password ;
this . url . host = this . base . host ;
this . url . port = this . base . port ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = this . base . query ;
} else if ( c === 47 ) {
this . state = "relative slash" ;
} else if ( c === 63 ) {
this . url . username = this . base . username ;
this . url . password = this . base . password ;
this . url . host = this . base . host ;
this . url . port = this . base . port ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = "" ;
this . state = "query" ;
} else if ( c === 35 ) {
this . url . username = this . base . username ;
this . url . password = this . base . password ;
this . url . host = this . base . host ;
this . url . port = this . base . port ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = this . base . query ;
this . url . fragment = "" ;
this . state = "fragment" ;
} else if ( isSpecial ( this . url ) && c === 92 ) {
this . parseError = true ;
this . state = "relative slash" ;
} else {
this . url . username = this . base . username ;
this . url . password = this . base . password ;
this . url . host = this . base . host ;
this . url . port = this . base . port ;
this . url . path = this . base . path . slice ( 0 , this . base . path . length - 1 ) ;
this . state = "path" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse relative slash" ] = function parseRelativeSlash ( c ) {
if ( isSpecial ( this . url ) && ( c === 47 || c === 92 ) ) {
if ( c === 92 ) {
this . parseError = true ;
}
this . state = "special authority ignore slashes" ;
} else if ( c === 47 ) {
this . state = "authority" ;
} else {
this . url . username = this . base . username ;
this . url . password = this . base . password ;
this . url . host = this . base . host ;
this . url . port = this . base . port ;
this . state = "path" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse special authority slashes" ] = function parseSpecialAuthoritySlashes ( c ) {
if ( c === 47 && this . input [ this . pointer + 1 ] === 47 ) {
this . state = "special authority ignore slashes" ;
++ this . pointer ;
} else {
this . parseError = true ;
this . state = "special authority ignore slashes" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse special authority ignore slashes" ] = function parseSpecialAuthorityIgnoreSlashes ( c ) {
if ( c !== 47 && c !== 92 ) {
this . state = "authority" ;
-- this . pointer ;
} else {
this . parseError = true ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse authority" ] = function parseAuthority ( c , cStr ) {
if ( c === 64 ) {
this . parseError = true ;
if ( this . atFlag ) {
this . buffer = "%40" + this . buffer ;
}
this . atFlag = true ;
// careful, this is based on buffer and has its own pointer (this.pointer != pointer) and inner chars
const len = countSymbols ( this . buffer ) ;
for ( let pointer = 0 ; pointer < len ; ++ pointer ) {
const codePoint = this . buffer . codePointAt ( pointer ) ;
if ( codePoint === 58 && ! this . passwordTokenSeenFlag ) {
this . passwordTokenSeenFlag = true ;
continue ;
}
const encodedCodePoints = percentEncodeChar ( codePoint , isUserinfoPercentEncode ) ;
if ( this . passwordTokenSeenFlag ) {
this . url . password += encodedCodePoints ;
} else {
this . url . username += encodedCodePoints ;
}
}
this . buffer = "" ;
} else if ( isNaN ( c ) || c === 47 || c === 63 || c === 35 ||
( isSpecial ( this . url ) && c === 92 ) ) {
if ( this . atFlag && this . buffer === "" ) {
this . parseError = true ;
return failure ;
}
this . pointer -= countSymbols ( this . buffer ) + 1 ;
this . buffer = "" ;
this . state = "host" ;
} else {
this . buffer += cStr ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse hostname" ] =
URLStateMachine . prototype [ "parse host" ] = function parseHostName ( c , cStr ) {
if ( this . stateOverride && this . url . scheme === "file" ) {
-- this . pointer ;
this . state = "file host" ;
} else if ( c === 58 && ! this . arrFlag ) {
if ( this . buffer === "" ) {
this . parseError = true ;
return failure ;
}
const host = parseHost ( this . buffer , isSpecial ( this . url ) ) ;
if ( host === failure ) {
return failure ;
}
this . url . host = host ;
this . buffer = "" ;
this . state = "port" ;
if ( this . stateOverride === "hostname" ) {
return false ;
}
} else if ( isNaN ( c ) || c === 47 || c === 63 || c === 35 ||
( isSpecial ( this . url ) && c === 92 ) ) {
-- this . pointer ;
if ( isSpecial ( this . url ) && this . buffer === "" ) {
this . parseError = true ;
return failure ;
} else if ( this . stateOverride && this . buffer === "" &&
( includesCredentials ( this . url ) || this . url . port !== null ) ) {
this . parseError = true ;
return false ;
}
const host = parseHost ( this . buffer , isSpecial ( this . url ) ) ;
if ( host === failure ) {
return failure ;
}
this . url . host = host ;
this . buffer = "" ;
this . state = "path start" ;
if ( this . stateOverride ) {
return false ;
}
} else {
if ( c === 91 ) {
this . arrFlag = true ;
} else if ( c === 93 ) {
this . arrFlag = false ;
}
this . buffer += cStr ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse port" ] = function parsePort ( c , cStr ) {
if ( isASCIIDigit ( c ) ) {
this . buffer += cStr ;
} else if ( isNaN ( c ) || c === 47 || c === 63 || c === 35 ||
( isSpecial ( this . url ) && c === 92 ) ||
this . stateOverride ) {
if ( this . buffer !== "" ) {
const port = parseInt ( this . buffer ) ;
if ( port > Math . pow ( 2 , 16 ) - 1 ) {
this . parseError = true ;
return failure ;
}
this . url . port = port === defaultPort ( this . url . scheme ) ? null : port ;
this . buffer = "" ;
}
if ( this . stateOverride ) {
return false ;
}
this . state = "path start" ;
-- this . pointer ;
} else {
this . parseError = true ;
return failure ;
}
return true ;
} ;
const fileOtherwiseCodePoints = new Set ( [ 47 , 92 , 63 , 35 ] ) ;
URLStateMachine . prototype [ "parse file" ] = function parseFile ( c ) {
this . url . scheme = "file" ;
if ( c === 47 || c === 92 ) {
if ( c === 92 ) {
this . parseError = true ;
}
this . state = "file slash" ;
} else if ( this . base !== null && this . base . scheme === "file" ) {
if ( isNaN ( c ) ) {
this . url . host = this . base . host ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = this . base . query ;
} else if ( c === 63 ) {
this . url . host = this . base . host ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = "" ;
this . state = "query" ;
} else if ( c === 35 ) {
this . url . host = this . base . host ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = this . base . query ;
this . url . fragment = "" ;
this . state = "fragment" ;
} else {
if ( this . input . length - this . pointer - 1 === 0 || // remaining consists of 0 code points
! isWindowsDriveLetterCodePoints ( c , this . input [ this . pointer + 1 ] ) ||
( this . input . length - this . pointer - 1 >= 2 && // remaining has at least 2 code points
! fileOtherwiseCodePoints . has ( this . input [ this . pointer + 2 ] ) ) ) {
this . url . host = this . base . host ;
this . url . path = this . base . path . slice ( ) ;
shortenPath ( this . url ) ;
} else {
this . parseError = true ;
}
this . state = "path" ;
-- this . pointer ;
}
} else {
this . state = "path" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse file slash" ] = function parseFileSlash ( c ) {
if ( c === 47 || c === 92 ) {
if ( c === 92 ) {
this . parseError = true ;
}
this . state = "file host" ;
} else {
if ( this . base !== null && this . base . scheme === "file" ) {
if ( isNormalizedWindowsDriveLetterString ( this . base . path [ 0 ] ) ) {
this . url . path . push ( this . base . path [ 0 ] ) ;
} else {
this . url . host = this . base . host ;
}
}
this . state = "path" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse file host" ] = function parseFileHost ( c , cStr ) {
if ( isNaN ( c ) || c === 47 || c === 92 || c === 63 || c === 35 ) {
-- this . pointer ;
if ( ! this . stateOverride && isWindowsDriveLetterString ( this . buffer ) ) {
this . parseError = true ;
this . state = "path" ;
} else if ( this . buffer === "" ) {
this . url . host = "" ;
if ( this . stateOverride ) {
return false ;
}
this . state = "path start" ;
} else {
let host = parseHost ( this . buffer , isSpecial ( this . url ) ) ;
if ( host === failure ) {
return failure ;
}
if ( host === "localhost" ) {
host = "" ;
}
this . url . host = host ;
if ( this . stateOverride ) {
return false ;
}
this . buffer = "" ;
this . state = "path start" ;
}
} else {
this . buffer += cStr ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse path start" ] = function parsePathStart ( c ) {
if ( isSpecial ( this . url ) ) {
if ( c === 92 ) {
this . parseError = true ;
}
this . state = "path" ;
if ( c !== 47 && c !== 92 ) {
-- this . pointer ;
}
} else if ( ! this . stateOverride && c === 63 ) {
this . url . query = "" ;
this . state = "query" ;
} else if ( ! this . stateOverride && c === 35 ) {
this . url . fragment = "" ;
this . state = "fragment" ;
} else if ( c !== undefined ) {
this . state = "path" ;
if ( c !== 47 ) {
-- this . pointer ;
}
}
return true ;
} ;
URLStateMachine . prototype [ "parse path" ] = function parsePath ( c ) {
if ( isNaN ( c ) || c === 47 || ( isSpecial ( this . url ) && c === 92 ) ||
( ! this . stateOverride && ( c === 63 || c === 35 ) ) ) {
if ( isSpecial ( this . url ) && c === 92 ) {
this . parseError = true ;
}
if ( isDoubleDot ( this . buffer ) ) {
shortenPath ( this . url ) ;
if ( c !== 47 && ! ( isSpecial ( this . url ) && c === 92 ) ) {
this . url . path . push ( "" ) ;
}
} else if ( isSingleDot ( this . buffer ) && c !== 47 &&
! ( isSpecial ( this . url ) && c === 92 ) ) {
this . url . path . push ( "" ) ;
} else if ( ! isSingleDot ( this . buffer ) ) {
if ( this . url . scheme === "file" && this . url . path . length === 0 && isWindowsDriveLetterString ( this . buffer ) ) {
if ( this . url . host !== "" && this . url . host !== null ) {
this . parseError = true ;
this . url . host = "" ;
}
this . buffer = this . buffer [ 0 ] + ":" ;
}
this . url . path . push ( this . buffer ) ;
}
this . buffer = "" ;
if ( this . url . scheme === "file" && ( c === undefined || c === 63 || c === 35 ) ) {
while ( this . url . path . length > 1 && this . url . path [ 0 ] === "" ) {
this . parseError = true ;
this . url . path . shift ( ) ;
}
}
if ( c === 63 ) {
this . url . query = "" ;
this . state = "query" ;
}
if ( c === 35 ) {
this . url . fragment = "" ;
this . state = "fragment" ;
}
} else {
// TODO: If c is not a URL code point and not "%", parse error.
if ( c === 37 &&
( ! isASCIIHex ( this . input [ this . pointer + 1 ] ) ||
! isASCIIHex ( this . input [ this . pointer + 2 ] ) ) ) {
this . parseError = true ;
}
this . buffer += percentEncodeChar ( c , isPathPercentEncode ) ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse cannot-be-a-base-URL path" ] = function parseCannotBeABaseURLPath ( c ) {
if ( c === 63 ) {
this . url . query = "" ;
this . state = "query" ;
} else if ( c === 35 ) {
this . url . fragment = "" ;
this . state = "fragment" ;
} else {
// TODO: Add: not a URL code point
if ( ! isNaN ( c ) && c !== 37 ) {
this . parseError = true ;
}
if ( c === 37 &&
( ! isASCIIHex ( this . input [ this . pointer + 1 ] ) ||
! isASCIIHex ( this . input [ this . pointer + 2 ] ) ) ) {
this . parseError = true ;
}
if ( ! isNaN ( c ) ) {
this . url . path [ 0 ] = this . url . path [ 0 ] + percentEncodeChar ( c , isC0ControlPercentEncode ) ;
}
}
return true ;
} ;
URLStateMachine . prototype [ "parse query" ] = function parseQuery ( c , cStr ) {
if ( isNaN ( c ) || ( ! this . stateOverride && c === 35 ) ) {
if ( ! isSpecial ( this . url ) || this . url . scheme === "ws" || this . url . scheme === "wss" ) {
this . encodingOverride = "utf-8" ;
}
const buffer = new Buffer ( this . buffer ) ; // TODO: Use encoding override instead
for ( let i = 0 ; i < buffer . length ; ++ i ) {
if ( buffer [ i ] < 0x21 || buffer [ i ] > 0x7E || buffer [ i ] === 0x22 || buffer [ i ] === 0x23 ||
buffer [ i ] === 0x3C || buffer [ i ] === 0x3E ) {
this . url . query += percentEncode ( buffer [ i ] ) ;
} else {
this . url . query += String . fromCodePoint ( buffer [ i ] ) ;
}
}
this . buffer = "" ;
if ( c === 35 ) {
this . url . fragment = "" ;
this . state = "fragment" ;
}
} else {
// TODO: If c is not a URL code point and not "%", parse error.
if ( c === 37 &&
( ! isASCIIHex ( this . input [ this . pointer + 1 ] ) ||
! isASCIIHex ( this . input [ this . pointer + 2 ] ) ) ) {
this . parseError = true ;
}
this . buffer += cStr ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse fragment" ] = function parseFragment ( c ) {
if ( isNaN ( c ) ) { // do nothing
} else if ( c === 0x0 ) {
this . parseError = true ;
} else {
// TODO: If c is not a URL code point and not "%", parse error.
if ( c === 37 &&
( ! isASCIIHex ( this . input [ this . pointer + 1 ] ) ||
! isASCIIHex ( this . input [ this . pointer + 2 ] ) ) ) {
this . parseError = true ;
}
this . url . fragment += percentEncodeChar ( c , isC0ControlPercentEncode ) ;
}
return true ;
} ;
function serializeURL ( url , excludeFragment ) {
let output = url . scheme + ":" ;
if ( url . host !== null ) {
output += "//" ;
if ( url . username !== "" || url . password !== "" ) {
output += url . username ;
if ( url . password !== "" ) {
output += ":" + url . password ;
}
output += "@" ;
}
output += serializeHost ( url . host ) ;
if ( url . port !== null ) {
output += ":" + url . port ;
}
} else if ( url . host === null && url . scheme === "file" ) {
output += "//" ;
}
if ( url . cannotBeABaseURL ) {
output += url . path [ 0 ] ;
} else {
for ( const string of url . path ) {
output += "/" + string ;
}
}
if ( url . query !== null ) {
output += "?" + url . query ;
}
if ( ! excludeFragment && url . fragment !== null ) {
output += "#" + url . fragment ;
}
return output ;
}
function serializeOrigin ( tuple ) {
let result = tuple . scheme + "://" ;
result += serializeHost ( tuple . host ) ;
if ( tuple . port !== null ) {
result += ":" + tuple . port ;
}
return result ;
}
module . exports . serializeURL = serializeURL ;
module . exports . serializeURLOrigin = function ( url ) {
// https://url.spec.whatwg.org/#concept-url-origin
switch ( url . scheme ) {
case "blob" :
try {
return module . exports . serializeURLOrigin ( module . exports . parseURL ( url . path [ 0 ] ) ) ;
} catch ( e ) {
// serializing an opaque origin returns "null"
return "null" ;
}
case "ftp" :
case "gopher" :
case "http" :
case "https" :
case "ws" :
case "wss" :
return serializeOrigin ( {
scheme : url . scheme ,
host : url . host ,
port : url . port
} ) ;
case "file" :
// spec says "exercise to the reader", chrome says "file://"
return "file://" ;
default :
// serializing an opaque origin returns "null"
return "null" ;
}
} ;
module . exports . basicURLParse = function ( input , options ) {
if ( options === undefined ) {
options = { } ;
}
const usm = new URLStateMachine ( input , options . baseURL , options . encodingOverride , options . url , options . stateOverride ) ;
if ( usm . failure ) {
return "failure" ;
}
return usm . url ;
} ;
module . exports . setTheUsername = function ( url , username ) {
url . username = "" ;
const decoded = punycode . ucs2 . decode ( username ) ;
for ( let i = 0 ; i < decoded . length ; ++ i ) {
url . username += percentEncodeChar ( decoded [ i ] , isUserinfoPercentEncode ) ;
}
} ;
module . exports . setThePassword = function ( url , password ) {
url . password = "" ;
const decoded = punycode . ucs2 . decode ( password ) ;
for ( let i = 0 ; i < decoded . length ; ++ i ) {
url . password += percentEncodeChar ( decoded [ i ] , isUserinfoPercentEncode ) ;
}
} ;
module . exports . serializeHost = serializeHost ;
module . exports . cannotHaveAUsernamePasswordPort = cannotHaveAUsernamePasswordPort ;
module . exports . serializeInteger = function ( integer ) {
return String ( integer ) ;
} ;
module . exports . parseURL = function ( input , options ) {
if ( options === undefined ) {
options = { } ;
}
// We don't handle blobs, so this just delegates:
return module . exports . basicURLParse ( input , { baseURL : options . baseURL , encodingOverride : options . encodingOverride } ) ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 6048 :
/***/ ( ( module ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
"use strict" ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports . mixin = function mixin ( target , source ) {
const keys = Object . getOwnPropertyNames ( source ) ;
for ( let i = 0 ; i < keys . length ; ++ i ) {
Object . defineProperty ( target , keys [ i ] , Object . getOwnPropertyDescriptor ( source , keys [ i ] ) ) ;
}
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports . wrapperSymbol = Symbol ( "wrapper" ) ;
module . exports . implSymbol = Symbol ( "impl" ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports . wrapperForImpl = function ( impl ) {
return impl [ module . exports . wrapperSymbol ] ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports . implForWrapper = function ( wrapper ) {
return wrapper [ module . exports . implSymbol ] ;
} ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ } ) ,
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
/***/ 3343 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var hasMap = typeof Map === 'function' && Map . prototype ;
var mapSizeDescriptor = Object . getOwnPropertyDescriptor && hasMap ? Object . getOwnPropertyDescriptor ( Map . prototype , 'size' ) : null ;
var mapSize = hasMap && mapSizeDescriptor && typeof mapSizeDescriptor . get === 'function' ? mapSizeDescriptor . get : null ;
var mapForEach = hasMap && Map . prototype . forEach ;
var hasSet = typeof Set === 'function' && Set . prototype ;
var setSizeDescriptor = Object . getOwnPropertyDescriptor && hasSet ? Object . getOwnPropertyDescriptor ( Set . prototype , 'size' ) : null ;
var setSize = hasSet && setSizeDescriptor && typeof setSizeDescriptor . get === 'function' ? setSizeDescriptor . get : null ;
var setForEach = hasSet && Set . prototype . forEach ;
var hasWeakMap = typeof WeakMap === 'function' && WeakMap . prototype ;
var weakMapHas = hasWeakMap ? WeakMap . prototype . has : null ;
var hasWeakSet = typeof WeakSet === 'function' && WeakSet . prototype ;
var weakSetHas = hasWeakSet ? WeakSet . prototype . has : null ;
var hasWeakRef = typeof WeakRef === 'function' && WeakRef . prototype ;
var weakRefDeref = hasWeakRef ? WeakRef . prototype . deref : null ;
var booleanValueOf = Boolean . prototype . valueOf ;
var objectToString = Object . prototype . toString ;
var functionToString = Function . prototype . toString ;
var $match = String . prototype . match ;
var $slice = String . prototype . slice ;
var $replace = String . prototype . replace ;
var $toUpperCase = String . prototype . toUpperCase ;
var $toLowerCase = String . prototype . toLowerCase ;
var $test = RegExp . prototype . test ;
var $concat = Array . prototype . concat ;
var $join = Array . prototype . join ;
var $arrSlice = Array . prototype . slice ;
var $floor = Math . floor ;
var bigIntValueOf = typeof BigInt === 'function' ? BigInt . prototype . valueOf : null ;
var gOPS = Object . getOwnPropertySymbols ;
var symToString = typeof Symbol === 'function' && typeof Symbol . iterator === 'symbol' ? Symbol . prototype . toString : null ;
var hasShammedSymbols = typeof Symbol === 'function' && typeof Symbol . iterator === 'object' ;
// ie, `has-tostringtag/shams
var toStringTag = typeof Symbol === 'function' && Symbol . toStringTag && ( typeof Symbol . toStringTag === hasShammedSymbols ? 'object' : 'symbol' )
? Symbol . toStringTag
: null ;
var isEnumerable = Object . prototype . propertyIsEnumerable ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var gPO = ( typeof Reflect === 'function' ? Reflect . getPrototypeOf : Object . getPrototypeOf ) || (
[ ] . _ _proto _ _ === Array . prototype // eslint-disable-line no-proto
? function ( O ) {
return O . _ _proto _ _ ; // eslint-disable-line no-proto
}
: null
) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function addNumericSeparator ( num , str ) {
if (
num === Infinity
|| num === - Infinity
|| num !== num
|| ( num && num > - 1000 && num < 1000 )
|| $test . call ( /e/ , str )
) {
return str ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
var sepRegex = /[0-9](?=(?:[0-9]{3})+(?![0-9]))/g ;
if ( typeof num === 'number' ) {
var int = num < 0 ? - $floor ( - num ) : $floor ( num ) ; // trunc(num)
if ( int !== num ) {
var intStr = String ( int ) ;
var dec = $slice . call ( str , intStr . length + 1 ) ;
return $replace . call ( intStr , sepRegex , '$&_' ) + '.' + $replace . call ( $replace . call ( dec , /([0-9]{3})/g , '$&_' ) , /_$/ , '' ) ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return $replace . call ( str , sepRegex , '$&_' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var utilInspect = _ _nccwpck _require _ _ ( 5038 ) ;
var inspectCustom = utilInspect . custom ;
var inspectSymbol = isSymbol ( inspectCustom ) ? inspectCustom : null ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
module . exports = function inspect _ ( obj , options , depth , seen ) {
var opts = options || { } ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( has ( opts , 'quoteStyle' ) && ( opts . quoteStyle !== 'single' && opts . quoteStyle !== 'double' ) ) {
throw new TypeError ( 'option "quoteStyle" must be "single" or "double"' ) ;
}
if (
has ( opts , 'maxStringLength' ) && ( typeof opts . maxStringLength === 'number'
? opts . maxStringLength < 0 && opts . maxStringLength !== Infinity
: opts . maxStringLength !== null
)
) {
throw new TypeError ( 'option "maxStringLength", if provided, must be a positive integer, Infinity, or `null`' ) ;
}
var customInspect = has ( opts , 'customInspect' ) ? opts . customInspect : true ;
if ( typeof customInspect !== 'boolean' && customInspect !== 'symbol' ) {
throw new TypeError ( 'option "customInspect", if provided, must be `true`, `false`, or `\'symbol\'`' ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if (
has ( opts , 'indent' )
&& opts . indent !== null
&& opts . indent !== '\t'
&& ! ( parseInt ( opts . indent , 10 ) === opts . indent && opts . indent > 0 )
) {
throw new TypeError ( 'option "indent" must be "\\t", an integer > 0, or `null`' ) ;
}
if ( has ( opts , 'numericSeparator' ) && typeof opts . numericSeparator !== 'boolean' ) {
throw new TypeError ( 'option "numericSeparator", if provided, must be `true` or `false`' ) ;
}
var numericSeparator = opts . numericSeparator ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( typeof obj === 'undefined' ) {
return 'undefined' ;
}
if ( obj === null ) {
return 'null' ;
}
if ( typeof obj === 'boolean' ) {
return obj ? 'true' : 'false' ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( typeof obj === 'string' ) {
return inspectString ( obj , opts ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
if ( typeof obj === 'number' ) {
if ( obj === 0 ) {
return Infinity / obj > 0 ? '0' : '-0' ;
}
var str = String ( obj ) ;
return numericSeparator ? addNumericSeparator ( obj , str ) : str ;
}
if ( typeof obj === 'bigint' ) {
var bigIntStr = String ( obj ) + 'n' ;
return numericSeparator ? addNumericSeparator ( obj , bigIntStr ) : bigIntStr ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
var maxDepth = typeof opts . depth === 'undefined' ? 5 : opts . depth ;
if ( typeof depth === 'undefined' ) { depth = 0 ; }
if ( depth >= maxDepth && maxDepth > 0 && typeof obj === 'object' ) {
return isArray ( obj ) ? '[Array]' : '[Object]' ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
var indent = getIndent ( opts , depth ) ;
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
if ( typeof seen === 'undefined' ) {
seen = [ ] ;
} else if ( indexOf ( seen , obj ) >= 0 ) {
return '[Circular]' ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function inspect ( value , from , noIndent ) {
if ( from ) {
seen = $arrSlice . call ( seen ) ;
seen . push ( from ) ;
}
if ( noIndent ) {
var newOpts = {
depth : opts . depth
} ;
if ( has ( opts , 'quoteStyle' ) ) {
newOpts . quoteStyle = opts . quoteStyle ;
}
return inspect _ ( value , newOpts , depth + 1 , seen ) ;
}
return inspect _ ( value , opts , depth + 1 , seen ) ;
}
if ( typeof obj === 'function' && ! isRegExp ( obj ) ) { // in older engines, regexes are callable
var name = nameOf ( obj ) ;
var keys = arrObjKeys ( obj , inspect ) ;
return '[Function' + ( name ? ': ' + name : ' (anonymous)' ) + ']' + ( keys . length > 0 ? ' { ' + $join . call ( keys , ', ' ) + ' }' : '' ) ;
}
if ( isSymbol ( obj ) ) {
var symString = hasShammedSymbols ? $replace . call ( String ( obj ) , /^(Symbol\(.*\))_[^)]*$/ , '$1' ) : symToString . call ( obj ) ;
return typeof obj === 'object' && ! hasShammedSymbols ? markBoxed ( symString ) : symString ;
}
if ( isElement ( obj ) ) {
var s = '<' + $toLowerCase . call ( String ( obj . nodeName ) ) ;
var attrs = obj . attributes || [ ] ;
for ( var i = 0 ; i < attrs . length ; i ++ ) {
s += ' ' + attrs [ i ] . name + '=' + wrapQuotes ( quote ( attrs [ i ] . value ) , 'double' , opts ) ;
}
s += '>' ;
if ( obj . childNodes && obj . childNodes . length ) { s += '...' ; }
s += '</' + $toLowerCase . call ( String ( obj . nodeName ) ) + '>' ;
return s ;
}
if ( isArray ( obj ) ) {
if ( obj . length === 0 ) { return '[]' ; }
var xs = arrObjKeys ( obj , inspect ) ;
if ( indent && ! singleLineValues ( xs ) ) {
return '[' + indentedJoin ( xs , indent ) + ']' ;
}
return '[ ' + $join . call ( xs , ', ' ) + ' ]' ;
}
if ( isError ( obj ) ) {
var parts = arrObjKeys ( obj , inspect ) ;
if ( ! ( 'cause' in Error . prototype ) && 'cause' in obj && ! isEnumerable . call ( obj , 'cause' ) ) {
return '{ [' + String ( obj ) + '] ' + $join . call ( $concat . call ( '[cause]: ' + inspect ( obj . cause ) , parts ) , ', ' ) + ' }' ;
}
if ( parts . length === 0 ) { return '[' + String ( obj ) + ']' ; }
return '{ [' + String ( obj ) + '] ' + $join . call ( parts , ', ' ) + ' }' ;
}
if ( typeof obj === 'object' && customInspect ) {
if ( inspectSymbol && typeof obj [ inspectSymbol ] === 'function' && utilInspect ) {
return utilInspect ( obj , { depth : maxDepth - depth } ) ;
} else if ( customInspect !== 'symbol' && typeof obj . inspect === 'function' ) {
return obj . inspect ( ) ;
}
}
if ( isMap ( obj ) ) {
var mapParts = [ ] ;
mapForEach . call ( obj , function ( value , key ) {
mapParts . push ( inspect ( key , obj , true ) + ' => ' + inspect ( value , obj ) ) ;
} ) ;
return collectionOf ( 'Map' , mapSize . call ( obj ) , mapParts , indent ) ;
}
if ( isSet ( obj ) ) {
var setParts = [ ] ;
setForEach . call ( obj , function ( value ) {
setParts . push ( inspect ( value , obj ) ) ;
} ) ;
return collectionOf ( 'Set' , setSize . call ( obj ) , setParts , indent ) ;
}
if ( isWeakMap ( obj ) ) {
return weakCollectionOf ( 'WeakMap' ) ;
}
if ( isWeakSet ( obj ) ) {
return weakCollectionOf ( 'WeakSet' ) ;
}
if ( isWeakRef ( obj ) ) {
return weakCollectionOf ( 'WeakRef' ) ;
}
if ( isNumber ( obj ) ) {
return markBoxed ( inspect ( Number ( obj ) ) ) ;
}
if ( isBigInt ( obj ) ) {
return markBoxed ( inspect ( bigIntValueOf . call ( obj ) ) ) ;
}
if ( isBoolean ( obj ) ) {
return markBoxed ( booleanValueOf . call ( obj ) ) ;
}
if ( isString ( obj ) ) {
return markBoxed ( inspect ( String ( obj ) ) ) ;
}
if ( ! isDate ( obj ) && ! isRegExp ( obj ) ) {
var ys = arrObjKeys ( obj , inspect ) ;
var isPlainObject = gPO ? gPO ( obj ) === Object . prototype : obj instanceof Object || obj . constructor === Object ;
var protoTag = obj instanceof Object ? '' : 'null prototype' ;
var stringTag = ! isPlainObject && toStringTag && Object ( obj ) === obj && toStringTag in obj ? $slice . call ( toStr ( obj ) , 8 , - 1 ) : protoTag ? 'Object' : '' ;
var constructorTag = isPlainObject || typeof obj . constructor !== 'function' ? '' : obj . constructor . name ? obj . constructor . name + ' ' : '' ;
var tag = constructorTag + ( stringTag || protoTag ? '[' + $join . call ( $concat . call ( [ ] , stringTag || [ ] , protoTag || [ ] ) , ': ' ) + '] ' : '' ) ;
if ( ys . length === 0 ) { return tag + '{}' ; }
if ( indent ) {
return tag + '{' + indentedJoin ( ys , indent ) + '}' ;
}
return tag + '{ ' + $join . call ( ys , ', ' ) + ' }' ;
}
return String ( obj ) ;
2022-06-27 14:17:15 -04:00
} ;
2022-07-11 13:48:02 -04:00
function wrapQuotes ( s , defaultStyle , opts ) {
var quoteChar = ( opts . quoteStyle || defaultStyle ) === 'double' ? '"' : "'" ;
return quoteChar + s + quoteChar ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function quote ( s ) {
return $replace . call ( String ( s ) , /"/g , '"' ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
function isArray ( obj ) { return toStr ( obj ) === '[object Array]' && ( ! toStringTag || ! ( typeof obj === 'object' && toStringTag in obj ) ) ; }
function isDate ( obj ) { return toStr ( obj ) === '[object Date]' && ( ! toStringTag || ! ( typeof obj === 'object' && toStringTag in obj ) ) ; }
function isRegExp ( obj ) { return toStr ( obj ) === '[object RegExp]' && ( ! toStringTag || ! ( typeof obj === 'object' && toStringTag in obj ) ) ; }
function isError ( obj ) { return toStr ( obj ) === '[object Error]' && ( ! toStringTag || ! ( typeof obj === 'object' && toStringTag in obj ) ) ; }
function isString ( obj ) { return toStr ( obj ) === '[object String]' && ( ! toStringTag || ! ( typeof obj === 'object' && toStringTag in obj ) ) ; }
function isNumber ( obj ) { return toStr ( obj ) === '[object Number]' && ( ! toStringTag || ! ( typeof obj === 'object' && toStringTag in obj ) ) ; }
function isBoolean ( obj ) { return toStr ( obj ) === '[object Boolean]' && ( ! toStringTag || ! ( typeof obj === 'object' && toStringTag in obj ) ) ; }
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
// Symbol and BigInt do have Symbol.toStringTag by spec, so that can't be used to eliminate false positives
function isSymbol ( obj ) {
if ( hasShammedSymbols ) {
return obj && typeof obj === 'object' && obj instanceof Symbol ;
}
if ( typeof obj === 'symbol' ) {
return true ;
}
if ( ! obj || typeof obj !== 'object' || ! symToString ) {
return false ;
}
try {
symToString . call ( obj ) ;
return true ;
} catch ( e ) { }
return false ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
function isBigInt ( obj ) {
if ( ! obj || typeof obj !== 'object' || ! bigIntValueOf ) {
return false ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
try {
bigIntValueOf . call ( obj ) ;
return true ;
} catch ( e ) { }
return false ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
var hasOwn = Object . prototype . hasOwnProperty || function ( key ) { return key in this ; } ;
function has ( obj , key ) {
return hasOwn . call ( obj , key ) ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function toStr ( obj ) {
return objectToString . call ( obj ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
function nameOf ( f ) {
if ( f . name ) { return f . name ; }
var m = $match . call ( functionToString . call ( f ) , /^function\s*([\w$]+)/ ) ;
if ( m ) { return m [ 1 ] ; }
return null ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function indexOf ( xs , x ) {
if ( xs . indexOf ) { return xs . indexOf ( x ) ; }
for ( var i = 0 , l = xs . length ; i < l ; i ++ ) {
if ( xs [ i ] === x ) { return i ; }
}
return - 1 ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function isMap ( x ) {
if ( ! mapSize || ! x || typeof x !== 'object' ) {
return false ;
}
try {
mapSize . call ( x ) ;
try {
setSize . call ( x ) ;
} catch ( s ) {
return true ;
}
return x instanceof Map ; // core-js workaround, pre-v2.5.0
} catch ( e ) { }
return false ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function isWeakMap ( x ) {
if ( ! weakMapHas || ! x || typeof x !== 'object' ) {
return false ;
}
try {
weakMapHas . call ( x , weakMapHas ) ;
try {
weakSetHas . call ( x , weakSetHas ) ;
} catch ( s ) {
return true ;
}
return x instanceof WeakMap ; // core-js workaround, pre-v2.5.0
} catch ( e ) { }
return false ;
}
2022-06-27 14:17:15 -04:00
2022-07-11 13:48:02 -04:00
function isWeakRef ( x ) {
if ( ! weakRefDeref || ! x || typeof x !== 'object' ) {
return false ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
try {
weakRefDeref . call ( x ) ;
return true ;
} catch ( e ) { }
return false ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
function isSet ( x ) {
if ( ! setSize || ! x || typeof x !== 'object' ) {
return false ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
try {
setSize . call ( x ) ;
try {
mapSize . call ( x ) ;
} catch ( m ) {
return true ;
}
return x instanceof Set ; // core-js workaround, pre-v2.5.0
} catch ( e ) { }
return false ;
}
function isWeakSet ( x ) {
if ( ! weakSetHas || ! x || typeof x !== 'object' ) {
return false ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
try {
weakSetHas . call ( x , weakSetHas ) ;
try {
weakMapHas . call ( x , weakMapHas ) ;
} catch ( s ) {
return true ;
}
return x instanceof WeakSet ; // core-js workaround, pre-v2.5.0
} catch ( e ) { }
return false ;
}
function isElement ( x ) {
if ( ! x || typeof x !== 'object' ) { return false ; }
if ( typeof HTMLElement !== 'undefined' && x instanceof HTMLElement ) {
return true ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return typeof x . nodeName === 'string' && typeof x . getAttribute === 'function' ;
}
function inspectString ( str , opts ) {
if ( str . length > opts . maxStringLength ) {
var remaining = str . length - opts . maxStringLength ;
var trailer = '... ' + remaining + ' more character' + ( remaining > 1 ? 's' : '' ) ;
return inspectString ( $slice . call ( str , 0 , opts . maxStringLength ) , opts ) + trailer ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
// eslint-disable-next-line no-control-regex
var s = $replace . call ( $replace . call ( str , /(['\\])/g , '\\$1' ) , /[\x00-\x1f]/g , lowbyte ) ;
return wrapQuotes ( s , 'single' , opts ) ;
}
function lowbyte ( c ) {
var n = c . charCodeAt ( 0 ) ;
var x = {
8 : 'b' ,
9 : 't' ,
10 : 'n' ,
12 : 'f' ,
13 : 'r'
} [ n ] ;
if ( x ) { return '\\' + x ; }
return '\\x' + ( n < 0x10 ? '0' : '' ) + $toUpperCase . call ( n . toString ( 16 ) ) ;
}
function markBoxed ( str ) {
return 'Object(' + str + ')' ;
}
function weakCollectionOf ( type ) {
return type + ' { ? }' ;
}
function collectionOf ( type , size , entries , indent ) {
var joinedEntries = indent ? indentedJoin ( entries , indent ) : $join . call ( entries , ', ' ) ;
return type + ' (' + size + ') {' + joinedEntries + '}' ;
}
function singleLineValues ( xs ) {
for ( var i = 0 ; i < xs . length ; i ++ ) {
if ( indexOf ( xs [ i ] , '\n' ) >= 0 ) {
return false ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return true ;
}
function getIndent ( opts , depth ) {
var baseIndent ;
if ( opts . indent === '\t' ) {
baseIndent = '\t' ;
} else if ( typeof opts . indent === 'number' && opts . indent > 0 ) {
baseIndent = $join . call ( Array ( opts . indent + 1 ) , ' ' ) ;
} else {
return null ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return {
base : baseIndent ,
prev : $join . call ( Array ( depth + 1 ) , baseIndent )
} ;
}
function indentedJoin ( xs , indent ) {
if ( xs . length === 0 ) { return '' ; }
var lineJoiner = '\n' + indent . prev + indent . base ;
return lineJoiner + $join . call ( xs , ',' + lineJoiner ) + '\n' + indent . prev ;
}
function arrObjKeys ( obj , inspect ) {
var isArr = isArray ( obj ) ;
var xs = [ ] ;
if ( isArr ) {
xs . length = obj . length ;
for ( var i = 0 ; i < obj . length ; i ++ ) {
xs [ i ] = has ( obj , i ) ? inspect ( obj [ i ] , obj ) : '' ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
var syms = typeof gOPS === 'function' ? gOPS ( obj ) : [ ] ;
var symMap ;
if ( hasShammedSymbols ) {
symMap = { } ;
for ( var k = 0 ; k < syms . length ; k ++ ) {
symMap [ '$' + syms [ k ] ] = syms [ k ] ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
for ( var key in obj ) { // eslint-disable-line no-restricted-syntax
if ( ! has ( obj , key ) ) { continue ; } // eslint-disable-line no-restricted-syntax, no-continue
if ( isArr && String ( Number ( key ) ) === key && key < obj . length ) { continue ; } // eslint-disable-line no-restricted-syntax, no-continue
if ( hasShammedSymbols && symMap [ '$' + key ] instanceof Symbol ) {
// this is to prevent shammed Symbols, which are stored as strings, from being included in the string key section
continue ; // eslint-disable-line no-restricted-syntax, no-continue
} else if ( $test . call ( /[^\w$]/ , key ) ) {
xs . push ( inspect ( key , obj ) + ': ' + inspect ( obj [ key ] , obj ) ) ;
} else {
xs . push ( key + ': ' + inspect ( obj [ key ] , obj ) ) ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
if ( typeof gOPS === 'function' ) {
for ( var j = 0 ; j < syms . length ; j ++ ) {
if ( isEnumerable . call ( obj , syms [ j ] ) ) {
xs . push ( '[' + inspect ( syms [ j ] ) + ']: ' + inspect ( obj [ syms [ j ] ] , obj ) ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return xs ;
}
/***/ } ) ,
/***/ 5038 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
module . exports = _ _nccwpck _require _ _ ( 3837 ) . inspect ;
/***/ } ) ,
/***/ 8953 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
var wrappy = _ _nccwpck _require _ _ ( 3985 )
module . exports = wrappy ( once )
module . exports . strict = wrappy ( onceStrict )
once . proto = once ( function ( ) {
Object . defineProperty ( Function . prototype , 'once' , {
value : function ( ) {
return once ( this )
} ,
configurable : true
} )
Object . defineProperty ( Function . prototype , 'onceStrict' , {
value : function ( ) {
return onceStrict ( this )
} ,
configurable : true
} )
} )
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
}
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
}
/***/ } ) ,
/***/ 1466 :
/***/ ( ( module ) => {
"use strict" ;
var replace = String . prototype . replace ;
var percentTwenties = /%20/g ;
var Format = {
RFC1738 : 'RFC1738' ,
RFC3986 : 'RFC3986'
} ;
module . exports = {
'default' : Format . RFC3986 ,
formatters : {
RFC1738 : function ( value ) {
return replace . call ( value , percentTwenties , '+' ) ;
} ,
RFC3986 : function ( value ) {
return String ( value ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
} ,
RFC1738 : Format . RFC1738 ,
RFC3986 : Format . RFC3986
} ;
/***/ } ) ,
/***/ 737 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
var stringify = _ _nccwpck _require _ _ ( 3769 ) ;
var parse = _ _nccwpck _require _ _ ( 2061 ) ;
var formats = _ _nccwpck _require _ _ ( 1466 ) ;
module . exports = {
formats : formats ,
parse : parse ,
stringify : stringify
} ;
/***/ } ) ,
/***/ 2061 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
var utils = _ _nccwpck _require _ _ ( 3763 ) ;
var has = Object . prototype . hasOwnProperty ;
var isArray = Array . isArray ;
var defaults = {
allowDots : false ,
allowPrototypes : false ,
allowSparse : false ,
arrayLimit : 20 ,
charset : 'utf-8' ,
charsetSentinel : false ,
comma : false ,
decoder : utils . decode ,
delimiter : '&' ,
depth : 5 ,
ignoreQueryPrefix : false ,
interpretNumericEntities : false ,
parameterLimit : 1000 ,
parseArrays : true ,
plainObjects : false ,
strictNullHandling : false
} ;
var interpretNumericEntities = function ( str ) {
return str . replace ( /&#(\d+);/g , function ( $0 , numberStr ) {
return String . fromCharCode ( parseInt ( numberStr , 10 ) ) ;
} ) ;
} ;
var parseArrayValue = function ( val , options ) {
if ( val && typeof val === 'string' && options . comma && val . indexOf ( ',' ) > - 1 ) {
return val . split ( ',' ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return val ;
} ;
// This is what browsers will submit when the ✓ character occurs in an
// application/x-www-form-urlencoded body and the encoding of the page containing
// the form is iso-8859-1, or when the submitted form has an accept-charset
// attribute of iso-8859-1. Presumably also with other charsets that do not contain
// the ✓ character, such as us-ascii.
var isoSentinel = 'utf8=%26%2310003%3B' ; // encodeURIComponent('✓')
// These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded.
var charsetSentinel = 'utf8=%E2%9C%93' ; // encodeURIComponent('✓')
var parseValues = function parseQueryStringValues ( str , options ) {
var obj = { } ;
var cleanStr = options . ignoreQueryPrefix ? str . replace ( /^\?/ , '' ) : str ;
var limit = options . parameterLimit === Infinity ? undefined : options . parameterLimit ;
var parts = cleanStr . split ( options . delimiter , limit ) ;
var skipIndex = - 1 ; // Keep track of where the utf8 sentinel was found
var i ;
var charset = options . charset ;
if ( options . charsetSentinel ) {
for ( i = 0 ; i < parts . length ; ++ i ) {
if ( parts [ i ] . indexOf ( 'utf8=' ) === 0 ) {
if ( parts [ i ] === charsetSentinel ) {
charset = 'utf-8' ;
} else if ( parts [ i ] === isoSentinel ) {
charset = 'iso-8859-1' ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
skipIndex = i ;
i = parts . length ; // The eslint settings do not allow break;
2022-06-27 14:17:15 -04:00
}
}
}
2022-07-11 13:48:02 -04:00
for ( i = 0 ; i < parts . length ; ++ i ) {
if ( i === skipIndex ) {
continue ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
var part = parts [ i ] ;
var bracketEqualsPos = part . indexOf ( ']=' ) ;
var pos = bracketEqualsPos === - 1 ? part . indexOf ( '=' ) : bracketEqualsPos + 1 ;
var key , val ;
if ( pos === - 1 ) {
key = options . decoder ( part , defaults . decoder , charset , 'key' ) ;
val = options . strictNullHandling ? null : '' ;
} else {
key = options . decoder ( part . slice ( 0 , pos ) , defaults . decoder , charset , 'key' ) ;
val = utils . maybeMap (
parseArrayValue ( part . slice ( pos + 1 ) , options ) ,
function ( encodedVal ) {
return options . decoder ( encodedVal , defaults . decoder , charset , 'value' ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
if ( val && options . interpretNumericEntities && charset === 'iso-8859-1' ) {
val = interpretNumericEntities ( val ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
if ( part . indexOf ( '[]=' ) > - 1 ) {
val = isArray ( val ) ? [ val ] : val ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
if ( has . call ( obj , key ) ) {
obj [ key ] = utils . combine ( obj [ key ] , val ) ;
} else {
obj [ key ] = val ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
}
return obj ;
} ;
var parseObject = function ( chain , val , options , valuesParsed ) {
var leaf = valuesParsed ? val : parseArrayValue ( val , options ) ;
for ( var i = chain . length - 1 ; i >= 0 ; -- i ) {
var obj ;
var root = chain [ i ] ;
if ( root === '[]' && options . parseArrays ) {
obj = [ ] . concat ( leaf ) ;
} else {
obj = options . plainObjects ? Object . create ( null ) : { } ;
var cleanRoot = root . charAt ( 0 ) === '[' && root . charAt ( root . length - 1 ) === ']' ? root . slice ( 1 , - 1 ) : root ;
var index = parseInt ( cleanRoot , 10 ) ;
if ( ! options . parseArrays && cleanRoot === '' ) {
obj = { 0 : leaf } ;
} else if (
! isNaN ( index )
&& root !== cleanRoot
&& String ( index ) === cleanRoot
&& index >= 0
&& ( options . parseArrays && index <= options . arrayLimit )
) {
obj = [ ] ;
obj [ index ] = leaf ;
} else if ( cleanRoot !== '__proto__' ) {
obj [ cleanRoot ] = leaf ;
2022-06-27 14:17:15 -04:00
}
}
2022-07-11 13:48:02 -04:00
leaf = obj ;
}
return leaf ;
} ;
var parseKeys = function parseQueryStringKeys ( givenKey , val , options , valuesParsed ) {
if ( ! givenKey ) {
return ;
}
// Transform dot notation to bracket notation
var key = options . allowDots ? givenKey . replace ( /\.([^.[]+)/g , '[$1]' ) : givenKey ;
// The regex chunks
var brackets = /(\[[^[\]]*])/ ;
var child = /(\[[^[\]]*])/g ;
// Get the parent
var segment = options . depth > 0 && brackets . exec ( key ) ;
var parent = segment ? key . slice ( 0 , segment . index ) : key ;
// Stash the parent if it exists
var keys = [ ] ;
if ( parent ) {
// If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties
if ( ! options . plainObjects && has . call ( Object . prototype , parent ) ) {
if ( ! options . allowPrototypes ) {
return ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
keys . push ( parent ) ;
}
// Loop through children appending to the array until we hit depth
var i = 0 ;
while ( options . depth > 0 && ( segment = child . exec ( key ) ) !== null && i < options . depth ) {
i += 1 ;
if ( ! options . plainObjects && has . call ( Object . prototype , segment [ 1 ] . slice ( 1 , - 1 ) ) ) {
if ( ! options . allowPrototypes ) {
return ;
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
keys . push ( segment [ 1 ] ) ;
}
// If there's a remainder, just add whatever is left
if ( segment ) {
keys . push ( '[' + key . slice ( segment . index ) + ']' ) ;
}
return parseObject ( keys , val , options , valuesParsed ) ;
} ;
var normalizeParseOptions = function normalizeParseOptions ( opts ) {
if ( ! opts ) {
return defaults ;
}
if ( opts . decoder !== null && opts . decoder !== undefined && typeof opts . decoder !== 'function' ) {
throw new TypeError ( 'Decoder has to be a function.' ) ;
}
if ( typeof opts . charset !== 'undefined' && opts . charset !== 'utf-8' && opts . charset !== 'iso-8859-1' ) {
throw new TypeError ( 'The charset option must be either utf-8, iso-8859-1, or undefined' ) ;
}
var charset = typeof opts . charset === 'undefined' ? defaults . charset : opts . charset ;
return {
allowDots : typeof opts . allowDots === 'undefined' ? defaults . allowDots : ! ! opts . allowDots ,
allowPrototypes : typeof opts . allowPrototypes === 'boolean' ? opts . allowPrototypes : defaults . allowPrototypes ,
allowSparse : typeof opts . allowSparse === 'boolean' ? opts . allowSparse : defaults . allowSparse ,
arrayLimit : typeof opts . arrayLimit === 'number' ? opts . arrayLimit : defaults . arrayLimit ,
charset : charset ,
charsetSentinel : typeof opts . charsetSentinel === 'boolean' ? opts . charsetSentinel : defaults . charsetSentinel ,
comma : typeof opts . comma === 'boolean' ? opts . comma : defaults . comma ,
decoder : typeof opts . decoder === 'function' ? opts . decoder : defaults . decoder ,
delimiter : typeof opts . delimiter === 'string' || utils . isRegExp ( opts . delimiter ) ? opts . delimiter : defaults . delimiter ,
// eslint-disable-next-line no-implicit-coercion, no-extra-parens
depth : ( typeof opts . depth === 'number' || opts . depth === false ) ? + opts . depth : defaults . depth ,
ignoreQueryPrefix : opts . ignoreQueryPrefix === true ,
interpretNumericEntities : typeof opts . interpretNumericEntities === 'boolean' ? opts . interpretNumericEntities : defaults . interpretNumericEntities ,
parameterLimit : typeof opts . parameterLimit === 'number' ? opts . parameterLimit : defaults . parameterLimit ,
parseArrays : opts . parseArrays !== false ,
plainObjects : typeof opts . plainObjects === 'boolean' ? opts . plainObjects : defaults . plainObjects ,
strictNullHandling : typeof opts . strictNullHandling === 'boolean' ? opts . strictNullHandling : defaults . strictNullHandling
} ;
} ;
module . exports = function ( str , opts ) {
var options = normalizeParseOptions ( opts ) ;
if ( str === '' || str === null || typeof str === 'undefined' ) {
return options . plainObjects ? Object . create ( null ) : { } ;
}
var tempObj = typeof str === 'string' ? parseValues ( str , options ) : str ;
var obj = options . plainObjects ? Object . create ( null ) : { } ;
// Iterate over the keys and setup the new object
var keys = Object . keys ( tempObj ) ;
for ( var i = 0 ; i < keys . length ; ++ i ) {
var key = keys [ i ] ;
var newObj = parseKeys ( key , tempObj [ key ] , options , typeof str === 'string' ) ;
obj = utils . merge ( obj , newObj , options ) ;
}
if ( options . allowSparse === true ) {
return obj ;
}
return utils . compact ( obj ) ;
} ;
/***/ } ) ,
/***/ 3769 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
var getSideChannel = _ _nccwpck _require _ _ ( 3355 ) ;
var utils = _ _nccwpck _require _ _ ( 3763 ) ;
var formats = _ _nccwpck _require _ _ ( 1466 ) ;
var has = Object . prototype . hasOwnProperty ;
var arrayPrefixGenerators = {
brackets : function brackets ( prefix ) {
return prefix + '[]' ;
} ,
comma : 'comma' ,
indices : function indices ( prefix , key ) {
return prefix + '[' + key + ']' ;
} ,
repeat : function repeat ( prefix ) {
return prefix ;
}
} ;
var isArray = Array . isArray ;
var split = String . prototype . split ;
var push = Array . prototype . push ;
var pushToArray = function ( arr , valueOrArray ) {
push . apply ( arr , isArray ( valueOrArray ) ? valueOrArray : [ valueOrArray ] ) ;
} ;
var toISO = Date . prototype . toISOString ;
var defaultFormat = formats [ 'default' ] ;
var defaults = {
addQueryPrefix : false ,
allowDots : false ,
charset : 'utf-8' ,
charsetSentinel : false ,
delimiter : '&' ,
encode : true ,
encoder : utils . encode ,
encodeValuesOnly : false ,
format : defaultFormat ,
formatter : formats . formatters [ defaultFormat ] ,
// deprecated
indices : false ,
serializeDate : function serializeDate ( date ) {
return toISO . call ( date ) ;
} ,
skipNulls : false ,
strictNullHandling : false
} ;
var isNonNullishPrimitive = function isNonNullishPrimitive ( v ) {
return typeof v === 'string'
|| typeof v === 'number'
|| typeof v === 'boolean'
|| typeof v === 'symbol'
|| typeof v === 'bigint' ;
} ;
var sentinel = { } ;
var stringify = function stringify (
object ,
prefix ,
generateArrayPrefix ,
commaRoundTrip ,
strictNullHandling ,
skipNulls ,
encoder ,
filter ,
sort ,
allowDots ,
serializeDate ,
format ,
formatter ,
encodeValuesOnly ,
charset ,
sideChannel
) {
var obj = object ;
var tmpSc = sideChannel ;
var step = 0 ;
var findFlag = false ;
while ( ( tmpSc = tmpSc . get ( sentinel ) ) !== void undefined && ! findFlag ) {
// Where object last appeared in the ref tree
var pos = tmpSc . get ( object ) ;
step += 1 ;
if ( typeof pos !== 'undefined' ) {
if ( pos === step ) {
throw new RangeError ( 'Cyclic object value' ) ;
} else {
findFlag = true ; // Break while
}
}
if ( typeof tmpSc . get ( sentinel ) === 'undefined' ) {
step = 0 ;
}
}
if ( typeof filter === 'function' ) {
obj = filter ( prefix , obj ) ;
} else if ( obj instanceof Date ) {
obj = serializeDate ( obj ) ;
} else if ( generateArrayPrefix === 'comma' && isArray ( obj ) ) {
obj = utils . maybeMap ( obj , function ( value ) {
if ( value instanceof Date ) {
return serializeDate ( value ) ;
}
return value ;
} ) ;
}
if ( obj === null ) {
if ( strictNullHandling ) {
return encoder && ! encodeValuesOnly ? encoder ( prefix , defaults . encoder , charset , 'key' , format ) : prefix ;
}
obj = '' ;
}
if ( isNonNullishPrimitive ( obj ) || utils . isBuffer ( obj ) ) {
if ( encoder ) {
var keyValue = encodeValuesOnly ? prefix : encoder ( prefix , defaults . encoder , charset , 'key' , format ) ;
if ( generateArrayPrefix === 'comma' && encodeValuesOnly ) {
var valuesArray = split . call ( String ( obj ) , ',' ) ;
var valuesJoined = '' ;
for ( var i = 0 ; i < valuesArray . length ; ++ i ) {
valuesJoined += ( i === 0 ? '' : ',' ) + formatter ( encoder ( valuesArray [ i ] , defaults . encoder , charset , 'value' , format ) ) ;
}
return [ formatter ( keyValue ) + ( commaRoundTrip && isArray ( obj ) && valuesArray . length === 1 ? '[]' : '' ) + '=' + valuesJoined ] ;
}
return [ formatter ( keyValue ) + '=' + formatter ( encoder ( obj , defaults . encoder , charset , 'value' , format ) ) ] ;
}
return [ formatter ( prefix ) + '=' + formatter ( String ( obj ) ) ] ;
}
var values = [ ] ;
if ( typeof obj === 'undefined' ) {
return values ;
}
var objKeys ;
if ( generateArrayPrefix === 'comma' && isArray ( obj ) ) {
// we need to join elements in
objKeys = [ { value : obj . length > 0 ? obj . join ( ',' ) || null : void undefined } ] ;
} else if ( isArray ( filter ) ) {
objKeys = filter ;
} else {
var keys = Object . keys ( obj ) ;
objKeys = sort ? keys . sort ( sort ) : keys ;
}
var adjustedPrefix = commaRoundTrip && isArray ( obj ) && obj . length === 1 ? prefix + '[]' : prefix ;
for ( var j = 0 ; j < objKeys . length ; ++ j ) {
var key = objKeys [ j ] ;
var value = typeof key === 'object' && typeof key . value !== 'undefined' ? key . value : obj [ key ] ;
if ( skipNulls && value === null ) {
continue ;
}
var keyPrefix = isArray ( obj )
? typeof generateArrayPrefix === 'function' ? generateArrayPrefix ( adjustedPrefix , key ) : adjustedPrefix
: adjustedPrefix + ( allowDots ? '.' + key : '[' + key + ']' ) ;
sideChannel . set ( object , step ) ;
var valueSideChannel = getSideChannel ( ) ;
valueSideChannel . set ( sentinel , sideChannel ) ;
pushToArray ( values , stringify (
value ,
keyPrefix ,
generateArrayPrefix ,
commaRoundTrip ,
strictNullHandling ,
skipNulls ,
encoder ,
filter ,
sort ,
allowDots ,
serializeDate ,
format ,
formatter ,
encodeValuesOnly ,
charset ,
valueSideChannel
) ) ;
}
return values ;
} ;
var normalizeStringifyOptions = function normalizeStringifyOptions ( opts ) {
if ( ! opts ) {
return defaults ;
}
if ( opts . encoder !== null && typeof opts . encoder !== 'undefined' && typeof opts . encoder !== 'function' ) {
throw new TypeError ( 'Encoder has to be a function.' ) ;
}
var charset = opts . charset || defaults . charset ;
if ( typeof opts . charset !== 'undefined' && opts . charset !== 'utf-8' && opts . charset !== 'iso-8859-1' ) {
throw new TypeError ( 'The charset option must be either utf-8, iso-8859-1, or undefined' ) ;
}
var format = formats [ 'default' ] ;
if ( typeof opts . format !== 'undefined' ) {
if ( ! has . call ( formats . formatters , opts . format ) ) {
throw new TypeError ( 'Unknown format option provided.' ) ;
}
format = opts . format ;
}
var formatter = formats . formatters [ format ] ;
var filter = defaults . filter ;
if ( typeof opts . filter === 'function' || isArray ( opts . filter ) ) {
filter = opts . filter ;
}
return {
addQueryPrefix : typeof opts . addQueryPrefix === 'boolean' ? opts . addQueryPrefix : defaults . addQueryPrefix ,
allowDots : typeof opts . allowDots === 'undefined' ? defaults . allowDots : ! ! opts . allowDots ,
charset : charset ,
charsetSentinel : typeof opts . charsetSentinel === 'boolean' ? opts . charsetSentinel : defaults . charsetSentinel ,
delimiter : typeof opts . delimiter === 'undefined' ? defaults . delimiter : opts . delimiter ,
encode : typeof opts . encode === 'boolean' ? opts . encode : defaults . encode ,
encoder : typeof opts . encoder === 'function' ? opts . encoder : defaults . encoder ,
encodeValuesOnly : typeof opts . encodeValuesOnly === 'boolean' ? opts . encodeValuesOnly : defaults . encodeValuesOnly ,
filter : filter ,
format : format ,
formatter : formatter ,
serializeDate : typeof opts . serializeDate === 'function' ? opts . serializeDate : defaults . serializeDate ,
skipNulls : typeof opts . skipNulls === 'boolean' ? opts . skipNulls : defaults . skipNulls ,
sort : typeof opts . sort === 'function' ? opts . sort : null ,
strictNullHandling : typeof opts . strictNullHandling === 'boolean' ? opts . strictNullHandling : defaults . strictNullHandling
} ;
} ;
module . exports = function ( object , opts ) {
var obj = object ;
var options = normalizeStringifyOptions ( opts ) ;
var objKeys ;
var filter ;
if ( typeof options . filter === 'function' ) {
filter = options . filter ;
obj = filter ( '' , obj ) ;
} else if ( isArray ( options . filter ) ) {
filter = options . filter ;
objKeys = filter ;
}
var keys = [ ] ;
if ( typeof obj !== 'object' || obj === null ) {
return '' ;
}
var arrayFormat ;
if ( opts && opts . arrayFormat in arrayPrefixGenerators ) {
arrayFormat = opts . arrayFormat ;
} else if ( opts && 'indices' in opts ) {
arrayFormat = opts . indices ? 'indices' : 'repeat' ;
} else {
arrayFormat = 'indices' ;
}
var generateArrayPrefix = arrayPrefixGenerators [ arrayFormat ] ;
if ( opts && 'commaRoundTrip' in opts && typeof opts . commaRoundTrip !== 'boolean' ) {
throw new TypeError ( '`commaRoundTrip` must be a boolean, or absent' ) ;
}
var commaRoundTrip = generateArrayPrefix === 'comma' && opts && opts . commaRoundTrip ;
if ( ! objKeys ) {
objKeys = Object . keys ( obj ) ;
}
if ( options . sort ) {
objKeys . sort ( options . sort ) ;
}
var sideChannel = getSideChannel ( ) ;
for ( var i = 0 ; i < objKeys . length ; ++ i ) {
var key = objKeys [ i ] ;
if ( options . skipNulls && obj [ key ] === null ) {
continue ;
}
pushToArray ( keys , stringify (
obj [ key ] ,
key ,
generateArrayPrefix ,
commaRoundTrip ,
options . strictNullHandling ,
options . skipNulls ,
options . encode ? options . encoder : null ,
options . filter ,
options . sort ,
options . allowDots ,
options . serializeDate ,
options . format ,
options . formatter ,
options . encodeValuesOnly ,
options . charset ,
sideChannel
) ) ;
}
var joined = keys . join ( options . delimiter ) ;
var prefix = options . addQueryPrefix === true ? '?' : '' ;
if ( options . charsetSentinel ) {
if ( options . charset === 'iso-8859-1' ) {
// encodeURIComponent('✓'), the "numeric entity" representation of a checkmark
prefix += 'utf8=%26%2310003%3B&' ;
} else {
// encodeURIComponent('✓')
prefix += 'utf8=%E2%9C%93&' ;
}
}
return joined . length > 0 ? prefix + joined : '' ;
} ;
/***/ } ) ,
/***/ 3763 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
var formats = _ _nccwpck _require _ _ ( 1466 ) ;
var has = Object . prototype . hasOwnProperty ;
var isArray = Array . isArray ;
var hexTable = ( function ( ) {
var array = [ ] ;
for ( var i = 0 ; i < 256 ; ++ i ) {
array . push ( '%' + ( ( i < 16 ? '0' : '' ) + i . toString ( 16 ) ) . toUpperCase ( ) ) ;
}
return array ;
} ( ) ) ;
var compactQueue = function compactQueue ( queue ) {
while ( queue . length > 1 ) {
var item = queue . pop ( ) ;
var obj = item . obj [ item . prop ] ;
if ( isArray ( obj ) ) {
var compacted = [ ] ;
for ( var j = 0 ; j < obj . length ; ++ j ) {
if ( typeof obj [ j ] !== 'undefined' ) {
compacted . push ( obj [ j ] ) ;
}
}
item . obj [ item . prop ] = compacted ;
}
}
} ;
var arrayToObject = function arrayToObject ( source , options ) {
var obj = options && options . plainObjects ? Object . create ( null ) : { } ;
for ( var i = 0 ; i < source . length ; ++ i ) {
if ( typeof source [ i ] !== 'undefined' ) {
obj [ i ] = source [ i ] ;
}
}
return obj ;
} ;
var merge = function merge ( target , source , options ) {
/* eslint no-param-reassign: 0 */
if ( ! source ) {
return target ;
}
if ( typeof source !== 'object' ) {
if ( isArray ( target ) ) {
target . push ( source ) ;
} else if ( target && typeof target === 'object' ) {
if ( ( options && ( options . plainObjects || options . allowPrototypes ) ) || ! has . call ( Object . prototype , source ) ) {
target [ source ] = true ;
}
} else {
return [ target , source ] ;
}
return target ;
}
if ( ! target || typeof target !== 'object' ) {
return [ target ] . concat ( source ) ;
}
var mergeTarget = target ;
if ( isArray ( target ) && ! isArray ( source ) ) {
mergeTarget = arrayToObject ( target , options ) ;
}
if ( isArray ( target ) && isArray ( source ) ) {
source . forEach ( function ( item , i ) {
if ( has . call ( target , i ) ) {
var targetItem = target [ i ] ;
if ( targetItem && typeof targetItem === 'object' && item && typeof item === 'object' ) {
target [ i ] = merge ( targetItem , item , options ) ;
} else {
target . push ( item ) ;
}
} else {
target [ i ] = item ;
}
} ) ;
return target ;
}
return Object . keys ( source ) . reduce ( function ( acc , key ) {
var value = source [ key ] ;
if ( has . call ( acc , key ) ) {
acc [ key ] = merge ( acc [ key ] , value , options ) ;
} else {
acc [ key ] = value ;
}
return acc ;
} , mergeTarget ) ;
} ;
var assign = function assignSingleSource ( target , source ) {
return Object . keys ( source ) . reduce ( function ( acc , key ) {
acc [ key ] = source [ key ] ;
return acc ;
} , target ) ;
} ;
var decode = function ( str , decoder , charset ) {
var strWithoutPlus = str . replace ( /\+/g , ' ' ) ;
if ( charset === 'iso-8859-1' ) {
// unescape never throws, no try...catch needed:
return strWithoutPlus . replace ( /%[0-9a-f]{2}/gi , unescape ) ;
}
// utf-8
try {
return decodeURIComponent ( strWithoutPlus ) ;
} catch ( e ) {
return strWithoutPlus ;
}
} ;
var encode = function encode ( str , defaultEncoder , charset , kind , format ) {
// This code was originally written by Brian White (mscdex) for the io.js core querystring library.
// It has been adapted here for stricter adherence to RFC 3986
if ( str . length === 0 ) {
return str ;
}
var string = str ;
if ( typeof str === 'symbol' ) {
string = Symbol . prototype . toString . call ( str ) ;
} else if ( typeof str !== 'string' ) {
string = String ( str ) ;
}
if ( charset === 'iso-8859-1' ) {
return escape ( string ) . replace ( /%u[0-9a-f]{4}/gi , function ( $0 ) {
return '%26%23' + parseInt ( $0 . slice ( 2 ) , 16 ) + '%3B' ;
} ) ;
}
var out = '' ;
for ( var i = 0 ; i < string . length ; ++ i ) {
var c = string . charCodeAt ( i ) ;
if (
c === 0x2D // -
|| c === 0x2E // .
|| c === 0x5F // _
|| c === 0x7E // ~
|| ( c >= 0x30 && c <= 0x39 ) // 0-9
|| ( c >= 0x41 && c <= 0x5A ) // a-z
|| ( c >= 0x61 && c <= 0x7A ) // A-Z
|| ( format === formats . RFC1738 && ( c === 0x28 || c === 0x29 ) ) // ( )
) {
out += string . charAt ( i ) ;
continue ;
}
if ( c < 0x80 ) {
out = out + hexTable [ c ] ;
continue ;
}
if ( c < 0x800 ) {
out = out + ( hexTable [ 0xC0 | ( c >> 6 ) ] + hexTable [ 0x80 | ( c & 0x3F ) ] ) ;
continue ;
}
if ( c < 0xD800 || c >= 0xE000 ) {
out = out + ( hexTable [ 0xE0 | ( c >> 12 ) ] + hexTable [ 0x80 | ( ( c >> 6 ) & 0x3F ) ] + hexTable [ 0x80 | ( c & 0x3F ) ] ) ;
continue ;
}
i += 1 ;
c = 0x10000 + ( ( ( c & 0x3FF ) << 10 ) | ( string . charCodeAt ( i ) & 0x3FF ) ) ;
/* eslint operator-linebreak: [2, "before"] */
out += hexTable [ 0xF0 | ( c >> 18 ) ]
+ hexTable [ 0x80 | ( ( c >> 12 ) & 0x3F ) ]
+ hexTable [ 0x80 | ( ( c >> 6 ) & 0x3F ) ]
+ hexTable [ 0x80 | ( c & 0x3F ) ] ;
}
return out ;
} ;
var compact = function compact ( value ) {
var queue = [ { obj : { o : value } , prop : 'o' } ] ;
var refs = [ ] ;
for ( var i = 0 ; i < queue . length ; ++ i ) {
var item = queue [ i ] ;
var obj = item . obj [ item . prop ] ;
var keys = Object . keys ( obj ) ;
for ( var j = 0 ; j < keys . length ; ++ j ) {
var key = keys [ j ] ;
var val = obj [ key ] ;
if ( typeof val === 'object' && val !== null && refs . indexOf ( val ) === - 1 ) {
queue . push ( { obj : obj , prop : key } ) ;
refs . push ( val ) ;
}
}
}
compactQueue ( queue ) ;
return value ;
} ;
var isRegExp = function isRegExp ( obj ) {
return Object . prototype . toString . call ( obj ) === '[object RegExp]' ;
} ;
var isBuffer = function isBuffer ( obj ) {
if ( ! obj || typeof obj !== 'object' ) {
return false ;
}
return ! ! ( obj . constructor && obj . constructor . isBuffer && obj . constructor . isBuffer ( obj ) ) ;
} ;
var combine = function combine ( a , b ) {
return [ ] . concat ( a , b ) ;
} ;
var maybeMap = function maybeMap ( val , fn ) {
if ( isArray ( val ) ) {
var mapped = [ ] ;
for ( var i = 0 ; i < val . length ; i += 1 ) {
mapped . push ( fn ( val [ i ] ) ) ;
}
return mapped ;
}
return fn ( val ) ;
} ;
module . exports = {
arrayToObject : arrayToObject ,
assign : assign ,
combine : combine ,
compact : compact ,
decode : decode ,
encode : encode ,
isBuffer : isBuffer ,
isRegExp : isRegExp ,
maybeMap : maybeMap ,
merge : merge
} ;
/***/ } ) ,
/***/ 1554 :
/***/ ( ( module , exports ) => {
exports = module . exports = SemVer
var debug
/* istanbul ignore next */
if ( typeof process === 'object' &&
process . env &&
process . env . NODE _DEBUG &&
/\bsemver\b/i . test ( process . env . NODE _DEBUG ) ) {
debug = function ( ) {
var args = Array . prototype . slice . call ( arguments , 0 )
args . unshift ( 'SEMVER' )
console . log . apply ( console , args )
}
} else {
debug = function ( ) { }
}
// Note: this is the semver.org version of the spec that it implements
// Not necessarily the package version of this code.
exports . SEMVER _SPEC _VERSION = '2.0.0'
var MAX _LENGTH = 256
var MAX _SAFE _INTEGER = Number . MAX _SAFE _INTEGER ||
/* istanbul ignore next */ 9007199254740991
// Max safe segment length for coercion.
var MAX _SAFE _COMPONENT _LENGTH = 16
// The actual regexps go on exports.re
var re = exports . re = [ ]
var src = exports . src = [ ]
var t = exports . tokens = { }
var R = 0
function tok ( n ) {
t [ n ] = R ++
}
// The following Regular Expressions can be used for tokenizing,
// validating, and parsing SemVer version strings.
// ## Numeric Identifier
// A single `0`, or a non-zero digit followed by zero or more digits.
tok ( 'NUMERICIDENTIFIER' )
src [ t . NUMERICIDENTIFIER ] = '0|[1-9]\\d*'
tok ( 'NUMERICIDENTIFIERLOOSE' )
src [ t . NUMERICIDENTIFIERLOOSE ] = '[0-9]+'
// ## Non-numeric Identifier
// Zero or more digits, followed by a letter or hyphen, and then zero or
// more letters, digits, or hyphens.
tok ( 'NONNUMERICIDENTIFIER' )
src [ t . NONNUMERICIDENTIFIER ] = '\\d*[a-zA-Z-][a-zA-Z0-9-]*'
// ## Main Version
// Three dot-separated numeric identifiers.
tok ( 'MAINVERSION' )
src [ t . MAINVERSION ] = '(' + src [ t . NUMERICIDENTIFIER ] + ')\\.' +
'(' + src [ t . NUMERICIDENTIFIER ] + ')\\.' +
'(' + src [ t . NUMERICIDENTIFIER ] + ')'
tok ( 'MAINVERSIONLOOSE' )
src [ t . MAINVERSIONLOOSE ] = '(' + src [ t . NUMERICIDENTIFIERLOOSE ] + ')\\.' +
'(' + src [ t . NUMERICIDENTIFIERLOOSE ] + ')\\.' +
'(' + src [ t . NUMERICIDENTIFIERLOOSE ] + ')'
// ## Pre-release Version Identifier
// A numeric identifier, or a non-numeric identifier.
tok ( 'PRERELEASEIDENTIFIER' )
src [ t . PRERELEASEIDENTIFIER ] = '(?:' + src [ t . NUMERICIDENTIFIER ] +
'|' + src [ t . NONNUMERICIDENTIFIER ] + ')'
tok ( 'PRERELEASEIDENTIFIERLOOSE' )
src [ t . PRERELEASEIDENTIFIERLOOSE ] = '(?:' + src [ t . NUMERICIDENTIFIERLOOSE ] +
'|' + src [ t . NONNUMERICIDENTIFIER ] + ')'
// ## Pre-release Version
// Hyphen, followed by one or more dot-separated pre-release version
// identifiers.
tok ( 'PRERELEASE' )
src [ t . PRERELEASE ] = '(?:-(' + src [ t . PRERELEASEIDENTIFIER ] +
'(?:\\.' + src [ t . PRERELEASEIDENTIFIER ] + ')*))'
tok ( 'PRERELEASELOOSE' )
src [ t . PRERELEASELOOSE ] = '(?:-?(' + src [ t . PRERELEASEIDENTIFIERLOOSE ] +
'(?:\\.' + src [ t . PRERELEASEIDENTIFIERLOOSE ] + ')*))'
// ## Build Metadata Identifier
// Any combination of digits, letters, or hyphens.
tok ( 'BUILDIDENTIFIER' )
src [ t . BUILDIDENTIFIER ] = '[0-9A-Za-z-]+'
// ## Build Metadata
// Plus sign, followed by one or more period-separated build metadata
// identifiers.
tok ( 'BUILD' )
src [ t . BUILD ] = '(?:\\+(' + src [ t . BUILDIDENTIFIER ] +
'(?:\\.' + src [ t . BUILDIDENTIFIER ] + ')*))'
// ## Full Version String
// A main version, followed optionally by a pre-release version and
// build metadata.
// Note that the only major, minor, patch, and pre-release sections of
// the version string are capturing groups. The build metadata is not a
// capturing group, because it should not ever be used in version
// comparison.
tok ( 'FULL' )
tok ( 'FULLPLAIN' )
src [ t . FULLPLAIN ] = 'v?' + src [ t . MAINVERSION ] +
src [ t . PRERELEASE ] + '?' +
src [ t . BUILD ] + '?'
src [ t . FULL ] = '^' + src [ t . FULLPLAIN ] + '$'
// like full, but allows v1.2.3 and =1.2.3, which people do sometimes.
// also, 1.0.0alpha1 (prerelease without the hyphen) which is pretty
// common in the npm registry.
tok ( 'LOOSEPLAIN' )
src [ t . LOOSEPLAIN ] = '[v=\\s]*' + src [ t . MAINVERSIONLOOSE ] +
src [ t . PRERELEASELOOSE ] + '?' +
src [ t . BUILD ] + '?'
tok ( 'LOOSE' )
src [ t . LOOSE ] = '^' + src [ t . LOOSEPLAIN ] + '$'
tok ( 'GTLT' )
src [ t . GTLT ] = '((?:<|>)?=?)'
// Something like "2.*" or "1.2.x".
// Note that "x.x" is a valid xRange identifer, meaning "any version"
// Only the first item is strictly required.
tok ( 'XRANGEIDENTIFIERLOOSE' )
src [ t . XRANGEIDENTIFIERLOOSE ] = src [ t . NUMERICIDENTIFIERLOOSE ] + '|x|X|\\*'
tok ( 'XRANGEIDENTIFIER' )
src [ t . XRANGEIDENTIFIER ] = src [ t . NUMERICIDENTIFIER ] + '|x|X|\\*'
tok ( 'XRANGEPLAIN' )
src [ t . XRANGEPLAIN ] = '[v=\\s]*(' + src [ t . XRANGEIDENTIFIER ] + ')' +
'(?:\\.(' + src [ t . XRANGEIDENTIFIER ] + ')' +
'(?:\\.(' + src [ t . XRANGEIDENTIFIER ] + ')' +
'(?:' + src [ t . PRERELEASE ] + ')?' +
src [ t . BUILD ] + '?' +
')?)?'
tok ( 'XRANGEPLAINLOOSE' )
src [ t . XRANGEPLAINLOOSE ] = '[v=\\s]*(' + src [ t . XRANGEIDENTIFIERLOOSE ] + ')' +
'(?:\\.(' + src [ t . XRANGEIDENTIFIERLOOSE ] + ')' +
'(?:\\.(' + src [ t . XRANGEIDENTIFIERLOOSE ] + ')' +
'(?:' + src [ t . PRERELEASELOOSE ] + ')?' +
src [ t . BUILD ] + '?' +
')?)?'
tok ( 'XRANGE' )
src [ t . XRANGE ] = '^' + src [ t . GTLT ] + '\\s*' + src [ t . XRANGEPLAIN ] + '$'
tok ( 'XRANGELOOSE' )
src [ t . XRANGELOOSE ] = '^' + src [ t . GTLT ] + '\\s*' + src [ t . XRANGEPLAINLOOSE ] + '$'
// Coercion.
// Extract anything that could conceivably be a part of a valid semver
tok ( 'COERCE' )
src [ t . COERCE ] = '(^|[^\\d])' +
'(\\d{1,' + MAX _SAFE _COMPONENT _LENGTH + '})' +
'(?:\\.(\\d{1,' + MAX _SAFE _COMPONENT _LENGTH + '}))?' +
'(?:\\.(\\d{1,' + MAX _SAFE _COMPONENT _LENGTH + '}))?' +
'(?:$|[^\\d])'
tok ( 'COERCERTL' )
re [ t . COERCERTL ] = new RegExp ( src [ t . COERCE ] , 'g' )
// Tilde ranges.
// Meaning is "reasonably at or greater than"
tok ( 'LONETILDE' )
src [ t . LONETILDE ] = '(?:~>?)'
tok ( 'TILDETRIM' )
src [ t . TILDETRIM ] = '(\\s*)' + src [ t . LONETILDE ] + '\\s+'
re [ t . TILDETRIM ] = new RegExp ( src [ t . TILDETRIM ] , 'g' )
var tildeTrimReplace = '$1~'
tok ( 'TILDE' )
src [ t . TILDE ] = '^' + src [ t . LONETILDE ] + src [ t . XRANGEPLAIN ] + '$'
tok ( 'TILDELOOSE' )
src [ t . TILDELOOSE ] = '^' + src [ t . LONETILDE ] + src [ t . XRANGEPLAINLOOSE ] + '$'
// Caret ranges.
// Meaning is "at least and backwards compatible with"
tok ( 'LONECARET' )
src [ t . LONECARET ] = '(?:\\^)'
tok ( 'CARETTRIM' )
src [ t . CARETTRIM ] = '(\\s*)' + src [ t . LONECARET ] + '\\s+'
re [ t . CARETTRIM ] = new RegExp ( src [ t . CARETTRIM ] , 'g' )
var caretTrimReplace = '$1^'
tok ( 'CARET' )
src [ t . CARET ] = '^' + src [ t . LONECARET ] + src [ t . XRANGEPLAIN ] + '$'
tok ( 'CARETLOOSE' )
src [ t . CARETLOOSE ] = '^' + src [ t . LONECARET ] + src [ t . XRANGEPLAINLOOSE ] + '$'
// A simple gt/lt/eq thing, or just "" to indicate "any version"
tok ( 'COMPARATORLOOSE' )
src [ t . COMPARATORLOOSE ] = '^' + src [ t . GTLT ] + '\\s*(' + src [ t . LOOSEPLAIN ] + ')$|^$'
tok ( 'COMPARATOR' )
src [ t . COMPARATOR ] = '^' + src [ t . GTLT ] + '\\s*(' + src [ t . FULLPLAIN ] + ')$|^$'
// An expression to strip any whitespace between the gtlt and the thing
// it modifies, so that `> 1.2.3` ==> `>1.2.3`
tok ( 'COMPARATORTRIM' )
src [ t . COMPARATORTRIM ] = '(\\s*)' + src [ t . GTLT ] +
'\\s*(' + src [ t . LOOSEPLAIN ] + '|' + src [ t . XRANGEPLAIN ] + ')'
// this one has to use the /g flag
re [ t . COMPARATORTRIM ] = new RegExp ( src [ t . COMPARATORTRIM ] , 'g' )
var comparatorTrimReplace = '$1$2$3'
// Something like `1.2.3 - 1.2.4`
// Note that these all use the loose form, because they'll be
// checked against either the strict or loose comparator form
// later.
tok ( 'HYPHENRANGE' )
src [ t . HYPHENRANGE ] = '^\\s*(' + src [ t . XRANGEPLAIN ] + ')' +
'\\s+-\\s+' +
'(' + src [ t . XRANGEPLAIN ] + ')' +
'\\s*$'
tok ( 'HYPHENRANGELOOSE' )
src [ t . HYPHENRANGELOOSE ] = '^\\s*(' + src [ t . XRANGEPLAINLOOSE ] + ')' +
'\\s+-\\s+' +
'(' + src [ t . XRANGEPLAINLOOSE ] + ')' +
'\\s*$'
// Star ranges basically just allow anything at all.
tok ( 'STAR' )
src [ t . STAR ] = '(<|>)?=?\\s*\\*'
// Compile to actual regexp objects.
// All are flag-free, unless they were created above with a flag.
for ( var i = 0 ; i < R ; i ++ ) {
debug ( i , src [ i ] )
if ( ! re [ i ] ) {
re [ i ] = new RegExp ( src [ i ] )
}
}
exports . parse = parse
function parse ( version , options ) {
if ( ! options || typeof options !== 'object' ) {
options = {
loose : ! ! options ,
includePrerelease : false
}
}
if ( version instanceof SemVer ) {
return version
}
if ( typeof version !== 'string' ) {
return null
}
if ( version . length > MAX _LENGTH ) {
return null
}
var r = options . loose ? re [ t . LOOSE ] : re [ t . FULL ]
if ( ! r . test ( version ) ) {
return null
}
try {
return new SemVer ( version , options )
} catch ( er ) {
return null
}
}
exports . valid = valid
function valid ( version , options ) {
var v = parse ( version , options )
return v ? v . version : null
}
exports . clean = clean
function clean ( version , options ) {
var s = parse ( version . trim ( ) . replace ( /^[=v]+/ , '' ) , options )
return s ? s . version : null
}
exports . SemVer = SemVer
function SemVer ( version , options ) {
if ( ! options || typeof options !== 'object' ) {
options = {
loose : ! ! options ,
includePrerelease : false
}
}
if ( version instanceof SemVer ) {
if ( version . loose === options . loose ) {
return version
} else {
version = version . version
}
} else if ( typeof version !== 'string' ) {
throw new TypeError ( 'Invalid Version: ' + version )
}
if ( version . length > MAX _LENGTH ) {
throw new TypeError ( 'version is longer than ' + MAX _LENGTH + ' characters' )
}
if ( ! ( this instanceof SemVer ) ) {
return new SemVer ( version , options )
}
debug ( 'SemVer' , version , options )
this . options = options
this . loose = ! ! options . loose
var m = version . trim ( ) . match ( options . loose ? re [ t . LOOSE ] : re [ t . FULL ] )
if ( ! m ) {
throw new TypeError ( 'Invalid Version: ' + version )
}
this . raw = version
// these are actually numbers
this . major = + m [ 1 ]
this . minor = + m [ 2 ]
this . patch = + m [ 3 ]
if ( this . major > MAX _SAFE _INTEGER || this . major < 0 ) {
throw new TypeError ( 'Invalid major version' )
}
if ( this . minor > MAX _SAFE _INTEGER || this . minor < 0 ) {
throw new TypeError ( 'Invalid minor version' )
}
if ( this . patch > MAX _SAFE _INTEGER || this . patch < 0 ) {
throw new TypeError ( 'Invalid patch version' )
}
// numberify any prerelease numeric ids
if ( ! m [ 4 ] ) {
this . prerelease = [ ]
} else {
this . prerelease = m [ 4 ] . split ( '.' ) . map ( function ( id ) {
if ( /^[0-9]+$/ . test ( id ) ) {
var num = + id
if ( num >= 0 && num < MAX _SAFE _INTEGER ) {
return num
}
}
return id
} )
}
this . build = m [ 5 ] ? m [ 5 ] . split ( '.' ) : [ ]
this . format ( )
}
SemVer . prototype . format = function ( ) {
this . version = this . major + '.' + this . minor + '.' + this . patch
if ( this . prerelease . length ) {
this . version += '-' + this . prerelease . join ( '.' )
}
return this . version
}
SemVer . prototype . toString = function ( ) {
return this . version
}
SemVer . prototype . compare = function ( other ) {
debug ( 'SemVer.compare' , this . version , this . options , other )
if ( ! ( other instanceof SemVer ) ) {
other = new SemVer ( other , this . options )
}
return this . compareMain ( other ) || this . comparePre ( other )
}
SemVer . prototype . compareMain = function ( other ) {
if ( ! ( other instanceof SemVer ) ) {
other = new SemVer ( other , this . options )
}
return compareIdentifiers ( this . major , other . major ) ||
compareIdentifiers ( this . minor , other . minor ) ||
compareIdentifiers ( this . patch , other . patch )
}
SemVer . prototype . comparePre = function ( other ) {
if ( ! ( other instanceof SemVer ) ) {
other = new SemVer ( other , this . options )
}
// NOT having a prerelease is > having one
if ( this . prerelease . length && ! other . prerelease . length ) {
return - 1
} else if ( ! this . prerelease . length && other . prerelease . length ) {
return 1
} else if ( ! this . prerelease . length && ! other . prerelease . length ) {
return 0
}
var i = 0
do {
var a = this . prerelease [ i ]
var b = other . prerelease [ i ]
debug ( 'prerelease compare' , i , a , b )
if ( a === undefined && b === undefined ) {
return 0
} else if ( b === undefined ) {
return 1
} else if ( a === undefined ) {
return - 1
} else if ( a === b ) {
continue
} else {
return compareIdentifiers ( a , b )
}
} while ( ++ i )
}
SemVer . prototype . compareBuild = function ( other ) {
if ( ! ( other instanceof SemVer ) ) {
other = new SemVer ( other , this . options )
}
var i = 0
do {
var a = this . build [ i ]
var b = other . build [ i ]
debug ( 'prerelease compare' , i , a , b )
if ( a === undefined && b === undefined ) {
return 0
} else if ( b === undefined ) {
return 1
} else if ( a === undefined ) {
return - 1
} else if ( a === b ) {
continue
} else {
return compareIdentifiers ( a , b )
}
} while ( ++ i )
}
// preminor will bump the version up to the next minor release, and immediately
// down to pre-release. premajor and prepatch work the same way.
SemVer . prototype . inc = function ( release , identifier ) {
switch ( release ) {
case 'premajor' :
this . prerelease . length = 0
this . patch = 0
this . minor = 0
this . major ++
this . inc ( 'pre' , identifier )
break
case 'preminor' :
this . prerelease . length = 0
this . patch = 0
this . minor ++
this . inc ( 'pre' , identifier )
break
case 'prepatch' :
// If this is already a prerelease, it will bump to the next version
// drop any prereleases that might already exist, since they are not
// relevant at this point.
this . prerelease . length = 0
this . inc ( 'patch' , identifier )
this . inc ( 'pre' , identifier )
break
// If the input is a non-prerelease version, this acts the same as
// prepatch.
case 'prerelease' :
if ( this . prerelease . length === 0 ) {
this . inc ( 'patch' , identifier )
}
this . inc ( 'pre' , identifier )
break
case 'major' :
// If this is a pre-major version, bump up to the same major version.
// Otherwise increment major.
// 1.0.0-5 bumps to 1.0.0
// 1.1.0 bumps to 2.0.0
if ( this . minor !== 0 ||
this . patch !== 0 ||
this . prerelease . length === 0 ) {
this . major ++
}
this . minor = 0
this . patch = 0
this . prerelease = [ ]
break
case 'minor' :
// If this is a pre-minor version, bump up to the same minor version.
// Otherwise increment minor.
// 1.2.0-5 bumps to 1.2.0
// 1.2.1 bumps to 1.3.0
if ( this . patch !== 0 || this . prerelease . length === 0 ) {
this . minor ++
}
this . patch = 0
this . prerelease = [ ]
break
case 'patch' :
// If this is not a pre-release version, it will increment the patch.
// If it is a pre-release it will bump up to the same patch version.
// 1.2.0-5 patches to 1.2.0
// 1.2.0 patches to 1.2.1
if ( this . prerelease . length === 0 ) {
this . patch ++
}
this . prerelease = [ ]
break
// This probably shouldn't be used publicly.
// 1.0.0 "pre" would become 1.0.0-0 which is the wrong direction.
case 'pre' :
if ( this . prerelease . length === 0 ) {
this . prerelease = [ 0 ]
} else {
var i = this . prerelease . length
while ( -- i >= 0 ) {
if ( typeof this . prerelease [ i ] === 'number' ) {
this . prerelease [ i ] ++
i = - 2
}
}
if ( i === - 1 ) {
// didn't increment anything
this . prerelease . push ( 0 )
}
}
if ( identifier ) {
// 1.2.0-beta.1 bumps to 1.2.0-beta.2,
// 1.2.0-beta.fooblz or 1.2.0-beta bumps to 1.2.0-beta.0
if ( this . prerelease [ 0 ] === identifier ) {
if ( isNaN ( this . prerelease [ 1 ] ) ) {
this . prerelease = [ identifier , 0 ]
}
} else {
this . prerelease = [ identifier , 0 ]
}
}
break
default :
throw new Error ( 'invalid increment argument: ' + release )
}
this . format ( )
this . raw = this . version
return this
}
exports . inc = inc
function inc ( version , release , loose , identifier ) {
if ( typeof ( loose ) === 'string' ) {
identifier = loose
loose = undefined
}
try {
return new SemVer ( version , loose ) . inc ( release , identifier ) . version
} catch ( er ) {
return null
}
}
exports . diff = diff
function diff ( version1 , version2 ) {
if ( eq ( version1 , version2 ) ) {
return null
} else {
var v1 = parse ( version1 )
var v2 = parse ( version2 )
var prefix = ''
if ( v1 . prerelease . length || v2 . prerelease . length ) {
prefix = 'pre'
var defaultResult = 'prerelease'
}
for ( var key in v1 ) {
if ( key === 'major' || key === 'minor' || key === 'patch' ) {
if ( v1 [ key ] !== v2 [ key ] ) {
return prefix + key
}
}
}
return defaultResult // may be undefined
}
}
exports . compareIdentifiers = compareIdentifiers
var numeric = /^[0-9]+$/
function compareIdentifiers ( a , b ) {
var anum = numeric . test ( a )
var bnum = numeric . test ( b )
if ( anum && bnum ) {
a = + a
b = + b
}
return a === b ? 0
: ( anum && ! bnum ) ? - 1
: ( bnum && ! anum ) ? 1
: a < b ? - 1
: 1
}
exports . rcompareIdentifiers = rcompareIdentifiers
function rcompareIdentifiers ( a , b ) {
return compareIdentifiers ( b , a )
}
exports . major = major
function major ( a , loose ) {
return new SemVer ( a , loose ) . major
}
exports . minor = minor
function minor ( a , loose ) {
return new SemVer ( a , loose ) . minor
}
exports . patch = patch
function patch ( a , loose ) {
return new SemVer ( a , loose ) . patch
}
exports . compare = compare
function compare ( a , b , loose ) {
return new SemVer ( a , loose ) . compare ( new SemVer ( b , loose ) )
}
exports . compareLoose = compareLoose
function compareLoose ( a , b ) {
return compare ( a , b , true )
}
exports . compareBuild = compareBuild
function compareBuild ( a , b , loose ) {
var versionA = new SemVer ( a , loose )
var versionB = new SemVer ( b , loose )
return versionA . compare ( versionB ) || versionA . compareBuild ( versionB )
}
exports . rcompare = rcompare
function rcompare ( a , b , loose ) {
return compare ( b , a , loose )
}
exports . sort = sort
function sort ( list , loose ) {
return list . sort ( function ( a , b ) {
return exports . compareBuild ( a , b , loose )
} )
}
exports . rsort = rsort
function rsort ( list , loose ) {
return list . sort ( function ( a , b ) {
return exports . compareBuild ( b , a , loose )
} )
}
exports . gt = gt
function gt ( a , b , loose ) {
return compare ( a , b , loose ) > 0
}
exports . lt = lt
function lt ( a , b , loose ) {
return compare ( a , b , loose ) < 0
}
exports . eq = eq
function eq ( a , b , loose ) {
return compare ( a , b , loose ) === 0
}
exports . neq = neq
function neq ( a , b , loose ) {
return compare ( a , b , loose ) !== 0
}
exports . gte = gte
function gte ( a , b , loose ) {
return compare ( a , b , loose ) >= 0
}
exports . lte = lte
function lte ( a , b , loose ) {
return compare ( a , b , loose ) <= 0
}
exports . cmp = cmp
function cmp ( a , op , b , loose ) {
switch ( op ) {
case '===' :
if ( typeof a === 'object' )
a = a . version
if ( typeof b === 'object' )
b = b . version
return a === b
case '!==' :
if ( typeof a === 'object' )
a = a . version
if ( typeof b === 'object' )
b = b . version
return a !== b
case '' :
case '=' :
case '==' :
return eq ( a , b , loose )
case '!=' :
return neq ( a , b , loose )
case '>' :
return gt ( a , b , loose )
case '>=' :
return gte ( a , b , loose )
case '<' :
return lt ( a , b , loose )
case '<=' :
return lte ( a , b , loose )
default :
throw new TypeError ( 'Invalid operator: ' + op )
}
}
exports . Comparator = Comparator
function Comparator ( comp , options ) {
if ( ! options || typeof options !== 'object' ) {
options = {
loose : ! ! options ,
includePrerelease : false
}
}
if ( comp instanceof Comparator ) {
if ( comp . loose === ! ! options . loose ) {
return comp
} else {
comp = comp . value
}
}
if ( ! ( this instanceof Comparator ) ) {
return new Comparator ( comp , options )
}
debug ( 'comparator' , comp , options )
this . options = options
this . loose = ! ! options . loose
this . parse ( comp )
if ( this . semver === ANY ) {
this . value = ''
} else {
this . value = this . operator + this . semver . version
}
debug ( 'comp' , this )
}
var ANY = { }
Comparator . prototype . parse = function ( comp ) {
var r = this . options . loose ? re [ t . COMPARATORLOOSE ] : re [ t . COMPARATOR ]
var m = comp . match ( r )
if ( ! m ) {
throw new TypeError ( 'Invalid comparator: ' + comp )
}
this . operator = m [ 1 ] !== undefined ? m [ 1 ] : ''
if ( this . operator === '=' ) {
this . operator = ''
}
// if it literally is just '>' or '' then allow anything.
if ( ! m [ 2 ] ) {
this . semver = ANY
} else {
this . semver = new SemVer ( m [ 2 ] , this . options . loose )
}
}
Comparator . prototype . toString = function ( ) {
return this . value
}
Comparator . prototype . test = function ( version ) {
debug ( 'Comparator.test' , version , this . options . loose )
if ( this . semver === ANY || version === ANY ) {
return true
}
if ( typeof version === 'string' ) {
try {
version = new SemVer ( version , this . options )
} catch ( er ) {
return false
}
}
return cmp ( version , this . operator , this . semver , this . options )
}
Comparator . prototype . intersects = function ( comp , options ) {
if ( ! ( comp instanceof Comparator ) ) {
throw new TypeError ( 'a Comparator is required' )
}
if ( ! options || typeof options !== 'object' ) {
options = {
loose : ! ! options ,
includePrerelease : false
}
}
var rangeTmp
if ( this . operator === '' ) {
if ( this . value === '' ) {
return true
}
rangeTmp = new Range ( comp . value , options )
return satisfies ( this . value , rangeTmp , options )
} else if ( comp . operator === '' ) {
if ( comp . value === '' ) {
return true
}
rangeTmp = new Range ( this . value , options )
return satisfies ( comp . semver , rangeTmp , options )
}
var sameDirectionIncreasing =
( this . operator === '>=' || this . operator === '>' ) &&
( comp . operator === '>=' || comp . operator === '>' )
var sameDirectionDecreasing =
( this . operator === '<=' || this . operator === '<' ) &&
( comp . operator === '<=' || comp . operator === '<' )
var sameSemVer = this . semver . version === comp . semver . version
var differentDirectionsInclusive =
( this . operator === '>=' || this . operator === '<=' ) &&
( comp . operator === '>=' || comp . operator === '<=' )
var oppositeDirectionsLessThan =
cmp ( this . semver , '<' , comp . semver , options ) &&
( ( this . operator === '>=' || this . operator === '>' ) &&
( comp . operator === '<=' || comp . operator === '<' ) )
var oppositeDirectionsGreaterThan =
cmp ( this . semver , '>' , comp . semver , options ) &&
( ( this . operator === '<=' || this . operator === '<' ) &&
( comp . operator === '>=' || comp . operator === '>' ) )
return sameDirectionIncreasing || sameDirectionDecreasing ||
( sameSemVer && differentDirectionsInclusive ) ||
oppositeDirectionsLessThan || oppositeDirectionsGreaterThan
}
exports . Range = Range
function Range ( range , options ) {
if ( ! options || typeof options !== 'object' ) {
options = {
loose : ! ! options ,
includePrerelease : false
}
}
if ( range instanceof Range ) {
if ( range . loose === ! ! options . loose &&
range . includePrerelease === ! ! options . includePrerelease ) {
return range
} else {
return new Range ( range . raw , options )
}
}
if ( range instanceof Comparator ) {
return new Range ( range . value , options )
}
if ( ! ( this instanceof Range ) ) {
return new Range ( range , options )
}
this . options = options
this . loose = ! ! options . loose
this . includePrerelease = ! ! options . includePrerelease
// First, split based on boolean or ||
this . raw = range
this . set = range . split ( /\s*\|\|\s*/ ) . map ( function ( range ) {
return this . parseRange ( range . trim ( ) )
} , this ) . filter ( function ( c ) {
// throw out any that are not relevant for whatever reason
return c . length
} )
if ( ! this . set . length ) {
throw new TypeError ( 'Invalid SemVer Range: ' + range )
}
this . format ( )
}
Range . prototype . format = function ( ) {
this . range = this . set . map ( function ( comps ) {
return comps . join ( ' ' ) . trim ( )
} ) . join ( '||' ) . trim ( )
return this . range
}
Range . prototype . toString = function ( ) {
return this . range
}
Range . prototype . parseRange = function ( range ) {
var loose = this . options . loose
range = range . trim ( )
// `1.2.3 - 1.2.4` => `>=1.2.3 <=1.2.4`
var hr = loose ? re [ t . HYPHENRANGELOOSE ] : re [ t . HYPHENRANGE ]
range = range . replace ( hr , hyphenReplace )
debug ( 'hyphen replace' , range )
// `> 1.2.3 < 1.2.5` => `>1.2.3 <1.2.5`
range = range . replace ( re [ t . COMPARATORTRIM ] , comparatorTrimReplace )
debug ( 'comparator trim' , range , re [ t . COMPARATORTRIM ] )
// `~ 1.2.3` => `~1.2.3`
range = range . replace ( re [ t . TILDETRIM ] , tildeTrimReplace )
// `^ 1.2.3` => `^1.2.3`
range = range . replace ( re [ t . CARETTRIM ] , caretTrimReplace )
// normalize spaces
range = range . split ( /\s+/ ) . join ( ' ' )
// At this point, the range is completely trimmed and
// ready to be split into comparators.
var compRe = loose ? re [ t . COMPARATORLOOSE ] : re [ t . COMPARATOR ]
var set = range . split ( ' ' ) . map ( function ( comp ) {
return parseComparator ( comp , this . options )
} , this ) . join ( ' ' ) . split ( /\s+/ )
if ( this . options . loose ) {
// in loose mode, throw out any that are not valid comparators
set = set . filter ( function ( comp ) {
return ! ! comp . match ( compRe )
} )
}
set = set . map ( function ( comp ) {
return new Comparator ( comp , this . options )
} , this )
return set
}
Range . prototype . intersects = function ( range , options ) {
if ( ! ( range instanceof Range ) ) {
throw new TypeError ( 'a Range is required' )
}
return this . set . some ( function ( thisComparators ) {
return (
isSatisfiable ( thisComparators , options ) &&
range . set . some ( function ( rangeComparators ) {
return (
isSatisfiable ( rangeComparators , options ) &&
thisComparators . every ( function ( thisComparator ) {
return rangeComparators . every ( function ( rangeComparator ) {
return thisComparator . intersects ( rangeComparator , options )
} )
} )
)
} )
)
} )
}
// take a set of comparators and determine whether there
// exists a version which can satisfy it
function isSatisfiable ( comparators , options ) {
var result = true
var remainingComparators = comparators . slice ( )
var testComparator = remainingComparators . pop ( )
while ( result && remainingComparators . length ) {
result = remainingComparators . every ( function ( otherComparator ) {
return testComparator . intersects ( otherComparator , options )
} )
testComparator = remainingComparators . pop ( )
}
return result
}
// Mostly just for testing and legacy API reasons
exports . toComparators = toComparators
function toComparators ( range , options ) {
return new Range ( range , options ) . set . map ( function ( comp ) {
return comp . map ( function ( c ) {
return c . value
} ) . join ( ' ' ) . trim ( ) . split ( ' ' )
} )
}
// comprised of xranges, tildes, stars, and gtlt's at this point.
// already replaced the hyphen ranges
// turn into a set of JUST comparators.
function parseComparator ( comp , options ) {
debug ( 'comp' , comp , options )
comp = replaceCarets ( comp , options )
debug ( 'caret' , comp )
comp = replaceTildes ( comp , options )
debug ( 'tildes' , comp )
comp = replaceXRanges ( comp , options )
debug ( 'xrange' , comp )
comp = replaceStars ( comp , options )
debug ( 'stars' , comp )
return comp
}
function isX ( id ) {
return ! id || id . toLowerCase ( ) === 'x' || id === '*'
}
// ~, ~> --> * (any, kinda silly)
// ~2, ~2.x, ~2.x.x, ~>2, ~>2.x ~>2.x.x --> >=2.0.0 <3.0.0
// ~2.0, ~2.0.x, ~>2.0, ~>2.0.x --> >=2.0.0 <2.1.0
// ~1.2, ~1.2.x, ~>1.2, ~>1.2.x --> >=1.2.0 <1.3.0
// ~1.2.3, ~>1.2.3 --> >=1.2.3 <1.3.0
// ~1.2.0, ~>1.2.0 --> >=1.2.0 <1.3.0
function replaceTildes ( comp , options ) {
return comp . trim ( ) . split ( /\s+/ ) . map ( function ( comp ) {
return replaceTilde ( comp , options )
} ) . join ( ' ' )
}
function replaceTilde ( comp , options ) {
var r = options . loose ? re [ t . TILDELOOSE ] : re [ t . TILDE ]
return comp . replace ( r , function ( _ , M , m , p , pr ) {
debug ( 'tilde' , comp , _ , M , m , p , pr )
var ret
if ( isX ( M ) ) {
ret = ''
} else if ( isX ( m ) ) {
ret = '>=' + M + '.0.0 <' + ( + M + 1 ) + '.0.0'
} else if ( isX ( p ) ) {
// ~1.2 == >=1.2.0 <1.3.0
ret = '>=' + M + '.' + m + '.0 <' + M + '.' + ( + m + 1 ) + '.0'
} else if ( pr ) {
debug ( 'replaceTilde pr' , pr )
ret = '>=' + M + '.' + m + '.' + p + '-' + pr +
' <' + M + '.' + ( + m + 1 ) + '.0'
} else {
// ~1.2.3 == >=1.2.3 <1.3.0
ret = '>=' + M + '.' + m + '.' + p +
' <' + M + '.' + ( + m + 1 ) + '.0'
}
debug ( 'tilde return' , ret )
return ret
} )
}
// ^ --> * (any, kinda silly)
// ^2, ^2.x, ^2.x.x --> >=2.0.0 <3.0.0
// ^2.0, ^2.0.x --> >=2.0.0 <3.0.0
// ^1.2, ^1.2.x --> >=1.2.0 <2.0.0
// ^1.2.3 --> >=1.2.3 <2.0.0
// ^1.2.0 --> >=1.2.0 <2.0.0
function replaceCarets ( comp , options ) {
return comp . trim ( ) . split ( /\s+/ ) . map ( function ( comp ) {
return replaceCaret ( comp , options )
} ) . join ( ' ' )
}
function replaceCaret ( comp , options ) {
debug ( 'caret' , comp , options )
var r = options . loose ? re [ t . CARETLOOSE ] : re [ t . CARET ]
return comp . replace ( r , function ( _ , M , m , p , pr ) {
debug ( 'caret' , comp , _ , M , m , p , pr )
var ret
if ( isX ( M ) ) {
ret = ''
} else if ( isX ( m ) ) {
ret = '>=' + M + '.0.0 <' + ( + M + 1 ) + '.0.0'
} else if ( isX ( p ) ) {
if ( M === '0' ) {
ret = '>=' + M + '.' + m + '.0 <' + M + '.' + ( + m + 1 ) + '.0'
} else {
ret = '>=' + M + '.' + m + '.0 <' + ( + M + 1 ) + '.0.0'
}
} else if ( pr ) {
debug ( 'replaceCaret pr' , pr )
if ( M === '0' ) {
if ( m === '0' ) {
ret = '>=' + M + '.' + m + '.' + p + '-' + pr +
' <' + M + '.' + m + '.' + ( + p + 1 )
} else {
ret = '>=' + M + '.' + m + '.' + p + '-' + pr +
' <' + M + '.' + ( + m + 1 ) + '.0'
}
} else {
ret = '>=' + M + '.' + m + '.' + p + '-' + pr +
' <' + ( + M + 1 ) + '.0.0'
}
} else {
debug ( 'no pr' )
if ( M === '0' ) {
if ( m === '0' ) {
ret = '>=' + M + '.' + m + '.' + p +
' <' + M + '.' + m + '.' + ( + p + 1 )
} else {
ret = '>=' + M + '.' + m + '.' + p +
' <' + M + '.' + ( + m + 1 ) + '.0'
}
} else {
ret = '>=' + M + '.' + m + '.' + p +
' <' + ( + M + 1 ) + '.0.0'
}
}
debug ( 'caret return' , ret )
return ret
} )
}
function replaceXRanges ( comp , options ) {
debug ( 'replaceXRanges' , comp , options )
return comp . split ( /\s+/ ) . map ( function ( comp ) {
return replaceXRange ( comp , options )
} ) . join ( ' ' )
}
function replaceXRange ( comp , options ) {
comp = comp . trim ( )
var r = options . loose ? re [ t . XRANGELOOSE ] : re [ t . XRANGE ]
return comp . replace ( r , function ( ret , gtlt , M , m , p , pr ) {
debug ( 'xRange' , comp , ret , gtlt , M , m , p , pr )
var xM = isX ( M )
var xm = xM || isX ( m )
var xp = xm || isX ( p )
var anyX = xp
if ( gtlt === '=' && anyX ) {
gtlt = ''
}
// if we're including prereleases in the match, then we need
// to fix this to -0, the lowest possible prerelease value
pr = options . includePrerelease ? '-0' : ''
if ( xM ) {
if ( gtlt === '>' || gtlt === '<' ) {
// nothing is allowed
ret = '<0.0.0-0'
} else {
// nothing is forbidden
ret = '*'
}
} else if ( gtlt && anyX ) {
// we know patch is an x, because we have any x at all.
// replace X with 0
if ( xm ) {
m = 0
}
p = 0
if ( gtlt === '>' ) {
// >1 => >=2.0.0
// >1.2 => >=1.3.0
// >1.2.3 => >= 1.2.4
gtlt = '>='
if ( xm ) {
M = + M + 1
m = 0
p = 0
} else {
m = + m + 1
p = 0
}
} else if ( gtlt === '<=' ) {
// <=0.7.x is actually <0.8.0, since any 0.7.x should
// pass. Similarly, <=7.x is actually <8.0.0, etc.
gtlt = '<'
if ( xm ) {
M = + M + 1
} else {
m = + m + 1
}
}
ret = gtlt + M + '.' + m + '.' + p + pr
} else if ( xm ) {
ret = '>=' + M + '.0.0' + pr + ' <' + ( + M + 1 ) + '.0.0' + pr
} else if ( xp ) {
ret = '>=' + M + '.' + m + '.0' + pr +
' <' + M + '.' + ( + m + 1 ) + '.0' + pr
}
debug ( 'xRange return' , ret )
return ret
} )
}
// Because * is AND-ed with everything else in the comparator,
// and '' means "any version", just remove the *s entirely.
function replaceStars ( comp , options ) {
debug ( 'replaceStars' , comp , options )
// Looseness is ignored here. star is always as loose as it gets!
return comp . trim ( ) . replace ( re [ t . STAR ] , '' )
}
// This function is passed to string.replace(re[t.HYPHENRANGE])
// M, m, patch, prerelease, build
// 1.2 - 3.4.5 => >=1.2.0 <=3.4.5
// 1.2.3 - 3.4 => >=1.2.0 <3.5.0 Any 3.4.x will do
// 1.2 - 3.4 => >=1.2.0 <3.5.0
function hyphenReplace ( $0 ,
from , fM , fm , fp , fpr , fb ,
to , tM , tm , tp , tpr , tb ) {
if ( isX ( fM ) ) {
from = ''
} else if ( isX ( fm ) ) {
from = '>=' + fM + '.0.0'
} else if ( isX ( fp ) ) {
from = '>=' + fM + '.' + fm + '.0'
} else {
from = '>=' + from
}
if ( isX ( tM ) ) {
to = ''
} else if ( isX ( tm ) ) {
to = '<' + ( + tM + 1 ) + '.0.0'
} else if ( isX ( tp ) ) {
to = '<' + tM + '.' + ( + tm + 1 ) + '.0'
} else if ( tpr ) {
to = '<=' + tM + '.' + tm + '.' + tp + '-' + tpr
} else {
to = '<=' + to
}
return ( from + ' ' + to ) . trim ( )
}
// if ANY of the sets match ALL of its comparators, then pass
Range . prototype . test = function ( version ) {
if ( ! version ) {
return false
}
if ( typeof version === 'string' ) {
try {
version = new SemVer ( version , this . options )
} catch ( er ) {
return false
}
}
for ( var i = 0 ; i < this . set . length ; i ++ ) {
if ( testSet ( this . set [ i ] , version , this . options ) ) {
return true
}
}
return false
}
function testSet ( set , version , options ) {
for ( var i = 0 ; i < set . length ; i ++ ) {
if ( ! set [ i ] . test ( version ) ) {
return false
}
}
if ( version . prerelease . length && ! options . includePrerelease ) {
// Find the set of versions that are allowed to have prereleases
// For example, ^1.2.3-pr.1 desugars to >=1.2.3-pr.1 <2.0.0
// That should allow `1.2.3-pr.2` to pass.
// However, `1.2.4-alpha.notready` should NOT be allowed,
// even though it's within the range set by the comparators.
for ( i = 0 ; i < set . length ; i ++ ) {
debug ( set [ i ] . semver )
if ( set [ i ] . semver === ANY ) {
continue
}
if ( set [ i ] . semver . prerelease . length > 0 ) {
var allowed = set [ i ] . semver
if ( allowed . major === version . major &&
allowed . minor === version . minor &&
allowed . patch === version . patch ) {
return true
}
}
}
// Version has a -pre, but it's not one of the ones we like.
return false
}
return true
}
exports . satisfies = satisfies
function satisfies ( version , range , options ) {
try {
range = new Range ( range , options )
} catch ( er ) {
return false
}
return range . test ( version )
}
exports . maxSatisfying = maxSatisfying
function maxSatisfying ( versions , range , options ) {
var max = null
var maxSV = null
try {
var rangeObj = new Range ( range , options )
} catch ( er ) {
return null
}
versions . forEach ( function ( v ) {
if ( rangeObj . test ( v ) ) {
// satisfies(v, range, options)
if ( ! max || maxSV . compare ( v ) === - 1 ) {
// compare(max, v, true)
max = v
maxSV = new SemVer ( max , options )
}
}
} )
return max
}
exports . minSatisfying = minSatisfying
function minSatisfying ( versions , range , options ) {
var min = null
var minSV = null
try {
var rangeObj = new Range ( range , options )
} catch ( er ) {
return null
}
versions . forEach ( function ( v ) {
if ( rangeObj . test ( v ) ) {
// satisfies(v, range, options)
if ( ! min || minSV . compare ( v ) === 1 ) {
// compare(min, v, true)
min = v
minSV = new SemVer ( min , options )
}
}
} )
return min
}
exports . minVersion = minVersion
function minVersion ( range , loose ) {
range = new Range ( range , loose )
var minver = new SemVer ( '0.0.0' )
if ( range . test ( minver ) ) {
return minver
}
minver = new SemVer ( '0.0.0-0' )
if ( range . test ( minver ) ) {
return minver
}
minver = null
for ( var i = 0 ; i < range . set . length ; ++ i ) {
var comparators = range . set [ i ]
comparators . forEach ( function ( comparator ) {
// Clone to avoid manipulating the comparator's semver object.
var compver = new SemVer ( comparator . semver . version )
switch ( comparator . operator ) {
case '>' :
if ( compver . prerelease . length === 0 ) {
compver . patch ++
} else {
compver . prerelease . push ( 0 )
}
compver . raw = compver . format ( )
/* fallthrough */
case '' :
case '>=' :
if ( ! minver || gt ( minver , compver ) ) {
minver = compver
}
break
case '<' :
case '<=' :
/* Ignore maximum versions */
break
/* istanbul ignore next */
default :
throw new Error ( 'Unexpected operation: ' + comparator . operator )
}
} )
}
if ( minver && range . test ( minver ) ) {
return minver
}
return null
}
exports . validRange = validRange
function validRange ( range , options ) {
try {
// Return '*' instead of '' so that truthiness works.
// This will throw if it's invalid anyway
return new Range ( range , options ) . range || '*'
} catch ( er ) {
return null
}
}
// Determine if version is less than all the versions possible in the range
exports . ltr = ltr
function ltr ( version , range , options ) {
return outside ( version , range , '<' , options )
}
// Determine if version is greater than all the versions possible in the range.
exports . gtr = gtr
function gtr ( version , range , options ) {
return outside ( version , range , '>' , options )
}
exports . outside = outside
function outside ( version , range , hilo , options ) {
version = new SemVer ( version , options )
range = new Range ( range , options )
var gtfn , ltefn , ltfn , comp , ecomp
switch ( hilo ) {
case '>' :
gtfn = gt
ltefn = lte
ltfn = lt
comp = '>'
ecomp = '>='
break
case '<' :
gtfn = lt
ltefn = gte
ltfn = gt
comp = '<'
ecomp = '<='
break
default :
throw new TypeError ( 'Must provide a hilo val of "<" or ">"' )
}
// If it satisifes the range it is not outside
if ( satisfies ( version , range , options ) ) {
return false
}
// From now on, variable terms are as if we're in "gtr" mode.
// but note that everything is flipped for the "ltr" function.
for ( var i = 0 ; i < range . set . length ; ++ i ) {
var comparators = range . set [ i ]
var high = null
var low = null
comparators . forEach ( function ( comparator ) {
if ( comparator . semver === ANY ) {
comparator = new Comparator ( '>=0.0.0' )
}
high = high || comparator
low = low || comparator
if ( gtfn ( comparator . semver , high . semver , options ) ) {
high = comparator
} else if ( ltfn ( comparator . semver , low . semver , options ) ) {
low = comparator
}
} )
// If the edge version comparator has a operator then our version
// isn't outside it
if ( high . operator === comp || high . operator === ecomp ) {
return false
}
// If the lowest version comparator has an operator and our version
// is less than it then it isn't higher than the range
if ( ( ! low . operator || low . operator === comp ) &&
ltefn ( version , low . semver ) ) {
return false
} else if ( low . operator === ecomp && ltfn ( version , low . semver ) ) {
return false
}
}
return true
}
exports . prerelease = prerelease
function prerelease ( version , options ) {
var parsed = parse ( version , options )
return ( parsed && parsed . prerelease . length ) ? parsed . prerelease : null
}
exports . intersects = intersects
function intersects ( r1 , r2 , options ) {
r1 = new Range ( r1 , options )
r2 = new Range ( r2 , options )
return r1 . intersects ( r2 )
}
exports . coerce = coerce
function coerce ( version , options ) {
if ( version instanceof SemVer ) {
return version
}
if ( typeof version === 'number' ) {
version = String ( version )
}
if ( typeof version !== 'string' ) {
return null
}
options = options || { }
var match = null
if ( ! options . rtl ) {
match = version . match ( re [ t . COERCE ] )
} else {
// Find the right-most coercible string that does not share
// a terminus with a more left-ward coercible string.
// Eg, '1.2.3.4' wants to coerce '2.3.4', not '3.4' or '4'
//
// Walk through the string checking with a /g regexp
// Manually set the index so as to pick up overlapping matches.
// Stop when we get a match that ends at the string end, since no
// coercible string can be more right-ward without the same terminus.
var next
while ( ( next = re [ t . COERCERTL ] . exec ( version ) ) &&
( ! match || match . index + match [ 0 ] . length !== version . length )
) {
if ( ! match ||
next . index + next [ 0 ] . length !== match . index + match [ 0 ] . length ) {
match = next
}
re [ t . COERCERTL ] . lastIndex = next . index + next [ 1 ] . length + next [ 2 ] . length
}
// leave it in a clean state
re [ t . COERCERTL ] . lastIndex = - 1
}
if ( match === null ) {
return null
}
return parse ( match [ 2 ] +
'.' + ( match [ 3 ] || '0' ) +
'.' + ( match [ 4 ] || '0' ) , options )
}
/***/ } ) ,
/***/ 3355 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
var GetIntrinsic = _ _nccwpck _require _ _ ( 4880 ) ;
var callBound = _ _nccwpck _require _ _ ( 4353 ) ;
var inspect = _ _nccwpck _require _ _ ( 3343 ) ;
var $TypeError = GetIntrinsic ( '%TypeError%' ) ;
var $WeakMap = GetIntrinsic ( '%WeakMap%' , true ) ;
var $Map = GetIntrinsic ( '%Map%' , true ) ;
var $weakMapGet = callBound ( 'WeakMap.prototype.get' , true ) ;
var $weakMapSet = callBound ( 'WeakMap.prototype.set' , true ) ;
var $weakMapHas = callBound ( 'WeakMap.prototype.has' , true ) ;
var $mapGet = callBound ( 'Map.prototype.get' , true ) ;
var $mapSet = callBound ( 'Map.prototype.set' , true ) ;
var $mapHas = callBound ( 'Map.prototype.has' , true ) ;
/ *
* This function traverses the list returning the node corresponding to the
* given key .
*
* That node is also moved to the head of the list , so that if it ' s accessed
* again we don ' t need to traverse the whole list . By doing so , all the recently
* used nodes can be accessed relatively quickly .
* /
var listGetNode = function ( list , key ) { // eslint-disable-line consistent-return
for ( var prev = list , curr ; ( curr = prev . next ) !== null ; prev = curr ) {
if ( curr . key === key ) {
prev . next = curr . next ;
curr . next = list . next ;
list . next = curr ; // eslint-disable-line no-param-reassign
return curr ;
}
}
} ;
var listGet = function ( objects , key ) {
var node = listGetNode ( objects , key ) ;
return node && node . value ;
} ;
var listSet = function ( objects , key , value ) {
var node = listGetNode ( objects , key ) ;
if ( node ) {
node . value = value ;
} else {
// Prepend the new node to the beginning of the list
objects . next = { // eslint-disable-line no-param-reassign
key : key ,
next : objects . next ,
value : value
} ;
}
} ;
var listHas = function ( objects , key ) {
return ! ! listGetNode ( objects , key ) ;
} ;
module . exports = function getSideChannel ( ) {
var $wm ;
var $m ;
var $o ;
var channel = {
assert : function ( key ) {
if ( ! channel . has ( key ) ) {
throw new $TypeError ( 'Side channel does not contain ' + inspect ( key ) ) ;
}
} ,
get : function ( key ) { // eslint-disable-line consistent-return
if ( $WeakMap && key && ( typeof key === 'object' || typeof key === 'function' ) ) {
if ( $wm ) {
return $weakMapGet ( $wm , key ) ;
}
} else if ( $Map ) {
if ( $m ) {
return $mapGet ( $m , key ) ;
}
} else {
if ( $o ) { // eslint-disable-line no-lonely-if
return listGet ( $o , key ) ;
}
}
} ,
has : function ( key ) {
if ( $WeakMap && key && ( typeof key === 'object' || typeof key === 'function' ) ) {
if ( $wm ) {
return $weakMapHas ( $wm , key ) ;
}
} else if ( $Map ) {
if ( $m ) {
return $mapHas ( $m , key ) ;
}
} else {
if ( $o ) { // eslint-disable-line no-lonely-if
return listHas ( $o , key ) ;
}
}
return false ;
} ,
set : function ( key , value ) {
if ( $WeakMap && key && ( typeof key === 'object' || typeof key === 'function' ) ) {
if ( ! $wm ) {
$wm = new $WeakMap ( ) ;
}
$weakMapSet ( $wm , key , value ) ;
} else if ( $Map ) {
if ( ! $m ) {
$m = new $Map ( ) ;
}
$mapSet ( $m , key , value ) ;
} else {
if ( ! $o ) {
/ *
* Initialize the linked list as an empty node , so that we don ' t have
* to special - case handling of the first node : we can always refer to
* it as ( previous node ) . next , instead of something like ( list ) . head
* /
$o = { key : { } , next : null } ;
}
listSet ( $o , key , value ) ;
}
}
} ;
return channel ;
} ;
/***/ } ) ,
/***/ 9958 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
module . exports = _ _nccwpck _require _ _ ( 9306 ) ;
/***/ } ) ,
/***/ 9306 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
var net = _ _nccwpck _require _ _ ( 1808 ) ;
var tls = _ _nccwpck _require _ _ ( 4404 ) ;
var http = _ _nccwpck _require _ _ ( 3685 ) ;
var https = _ _nccwpck _require _ _ ( 5687 ) ;
var events = _ _nccwpck _require _ _ ( 2361 ) ;
var assert = _ _nccwpck _require _ _ ( 9491 ) ;
var util = _ _nccwpck _require _ _ ( 3837 ) ;
exports . httpOverHttp = httpOverHttp ;
exports . httpsOverHttp = httpsOverHttp ;
exports . httpOverHttps = httpOverHttps ;
exports . httpsOverHttps = httpsOverHttps ;
function httpOverHttp ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = http . request ;
return agent ;
}
function httpsOverHttp ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = http . request ;
agent . createSocket = createSecureSocket ;
agent . defaultPort = 443 ;
return agent ;
}
function httpOverHttps ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = https . request ;
return agent ;
}
function httpsOverHttps ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = https . request ;
agent . createSocket = createSecureSocket ;
agent . defaultPort = 443 ;
return agent ;
}
function TunnelingAgent ( options ) {
var self = this ;
self . options = options || { } ;
self . proxyOptions = self . options . proxy || { } ;
self . maxSockets = self . options . maxSockets || http . Agent . defaultMaxSockets ;
self . requests = [ ] ;
self . sockets = [ ] ;
self . on ( 'free' , function onFree ( socket , host , port , localAddress ) {
var options = toOptions ( host , port , localAddress ) ;
for ( var i = 0 , len = self . requests . length ; i < len ; ++ i ) {
var pending = self . requests [ i ] ;
if ( pending . host === options . host && pending . port === options . port ) {
// Detect the request to connect same origin server,
// reuse the connection.
self . requests . splice ( i , 1 ) ;
pending . request . onSocket ( socket ) ;
return ;
}
}
socket . destroy ( ) ;
self . removeSocket ( socket ) ;
} ) ;
}
util . inherits ( TunnelingAgent , events . EventEmitter ) ;
TunnelingAgent . prototype . addRequest = function addRequest ( req , host , port , localAddress ) {
var self = this ;
var options = mergeOptions ( { request : req } , self . options , toOptions ( host , port , localAddress ) ) ;
if ( self . sockets . length >= this . maxSockets ) {
// We are over limit so we'll add it to the queue.
self . requests . push ( options ) ;
return ;
}
// If we are under maxSockets create a new one.
self . createSocket ( options , function ( socket ) {
socket . on ( 'free' , onFree ) ;
socket . on ( 'close' , onCloseOrRemove ) ;
socket . on ( 'agentRemove' , onCloseOrRemove ) ;
req . onSocket ( socket ) ;
function onFree ( ) {
self . emit ( 'free' , socket , options ) ;
}
function onCloseOrRemove ( err ) {
self . removeSocket ( socket ) ;
socket . removeListener ( 'free' , onFree ) ;
socket . removeListener ( 'close' , onCloseOrRemove ) ;
socket . removeListener ( 'agentRemove' , onCloseOrRemove ) ;
}
} ) ;
} ;
TunnelingAgent . prototype . createSocket = function createSocket ( options , cb ) {
var self = this ;
var placeholder = { } ;
self . sockets . push ( placeholder ) ;
var connectOptions = mergeOptions ( { } , self . proxyOptions , {
method : 'CONNECT' ,
path : options . host + ':' + options . port ,
agent : false ,
headers : {
host : options . host + ':' + options . port
}
} ) ;
if ( options . localAddress ) {
connectOptions . localAddress = options . localAddress ;
}
if ( connectOptions . proxyAuth ) {
connectOptions . headers = connectOptions . headers || { } ;
connectOptions . headers [ 'Proxy-Authorization' ] = 'Basic ' +
new Buffer ( connectOptions . proxyAuth ) . toString ( 'base64' ) ;
}
debug ( 'making CONNECT request' ) ;
var connectReq = self . request ( connectOptions ) ;
connectReq . useChunkedEncodingByDefault = false ; // for v0.6
connectReq . once ( 'response' , onResponse ) ; // for v0.6
connectReq . once ( 'upgrade' , onUpgrade ) ; // for v0.6
connectReq . once ( 'connect' , onConnect ) ; // for v0.7 or later
connectReq . once ( 'error' , onError ) ;
connectReq . end ( ) ;
function onResponse ( res ) {
// Very hacky. This is necessary to avoid http-parser leaks.
res . upgrade = true ;
}
function onUpgrade ( res , socket , head ) {
// Hacky.
process . nextTick ( function ( ) {
onConnect ( res , socket , head ) ;
} ) ;
}
function onConnect ( res , socket , head ) {
connectReq . removeAllListeners ( ) ;
socket . removeAllListeners ( ) ;
if ( res . statusCode !== 200 ) {
debug ( 'tunneling socket could not be established, statusCode=%d' ,
res . statusCode ) ;
socket . destroy ( ) ;
var error = new Error ( 'tunneling socket could not be established, ' +
'statusCode=' + res . statusCode ) ;
error . code = 'ECONNRESET' ;
options . request . emit ( 'error' , error ) ;
self . removeSocket ( placeholder ) ;
return ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
if ( head . length > 0 ) {
debug ( 'got illegal response body from proxy' ) ;
socket . destroy ( ) ;
var error = new Error ( 'got illegal response body from proxy' ) ;
error . code = 'ECONNRESET' ;
options . request . emit ( 'error' , error ) ;
self . removeSocket ( placeholder ) ;
return ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
debug ( 'tunneling connection has established' ) ;
self . sockets [ self . sockets . indexOf ( placeholder ) ] = socket ;
return cb ( socket ) ;
}
function onError ( cause ) {
connectReq . removeAllListeners ( ) ;
debug ( 'tunneling socket could not be established, cause=%s\n' ,
cause . message , cause . stack ) ;
var error = new Error ( 'tunneling socket could not be established, ' +
'cause=' + cause . message ) ;
error . code = 'ECONNRESET' ;
options . request . emit ( 'error' , error ) ;
self . removeSocket ( placeholder ) ;
}
} ;
TunnelingAgent . prototype . removeSocket = function removeSocket ( socket ) {
var pos = this . sockets . indexOf ( socket )
if ( pos === - 1 ) {
return ;
}
this . sockets . splice ( pos , 1 ) ;
var pending = this . requests . shift ( ) ;
if ( pending ) {
// If we have pending requests and a socket gets closed a new one
// needs to be created to take over in the pool for the one that closed.
this . createSocket ( pending , function ( socket ) {
pending . request . onSocket ( socket ) ;
} ) ;
}
} ;
function createSecureSocket ( options , cb ) {
var self = this ;
TunnelingAgent . prototype . createSocket . call ( self , options , function ( socket ) {
var hostHeader = options . request . getHeader ( 'host' ) ;
var tlsOptions = mergeOptions ( { } , self . options , {
socket : socket ,
servername : hostHeader ? hostHeader . replace ( /:.*$/ , '' ) : options . host
} ) ;
// 0 is dummy port for v0.6
var secureSocket = tls . connect ( 0 , tlsOptions ) ;
self . sockets [ self . sockets . indexOf ( socket ) ] = secureSocket ;
cb ( secureSocket ) ;
} ) ;
}
function toOptions ( host , port , localAddress ) {
if ( typeof host === 'string' ) { // since v0.10
return {
host : host ,
port : port ,
localAddress : localAddress
} ;
}
return host ; // for v0.11 or later
}
function mergeOptions ( target ) {
for ( var i = 1 , len = arguments . length ; i < len ; ++ i ) {
var overrides = arguments [ i ] ;
if ( typeof overrides === 'object' ) {
var keys = Object . keys ( overrides ) ;
for ( var j = 0 , keyLen = keys . length ; j < keyLen ; ++ j ) {
var k = keys [ j ] ;
if ( overrides [ k ] !== undefined ) {
target [ k ] = overrides [ k ] ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
}
return target ;
}
var debug ;
if ( process . env . NODE _DEBUG && /\btunnel\b/ . test ( process . env . NODE _DEBUG ) ) {
debug = function ( ) {
var args = Array . prototype . slice . call ( arguments ) ;
if ( typeof args [ 0 ] === 'string' ) {
args [ 0 ] = 'TUNNEL: ' + args [ 0 ] ;
} else {
args . unshift ( 'TUNNEL:' ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
console . error . apply ( console , args ) ;
}
} else {
debug = function ( ) { } ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
exports . debug = debug ; // for test
/***/ } ) ,
/***/ 6566 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
// Copyright (c) Microsoft. All rights reserved.
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
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 ) : new P ( function ( resolve ) { resolve ( result . value ) ; } ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
const url = _ _nccwpck _require _ _ ( 7310 ) ;
const http = _ _nccwpck _require _ _ ( 3685 ) ;
const https = _ _nccwpck _require _ _ ( 5687 ) ;
const util = _ _nccwpck _require _ _ ( 5235 ) ;
let fs ;
let tunnel ;
var HttpCodes ;
( function ( HttpCodes ) {
HttpCodes [ HttpCodes [ "OK" ] = 200 ] = "OK" ;
HttpCodes [ HttpCodes [ "MultipleChoices" ] = 300 ] = "MultipleChoices" ;
HttpCodes [ HttpCodes [ "MovedPermanently" ] = 301 ] = "MovedPermanently" ;
HttpCodes [ HttpCodes [ "ResourceMoved" ] = 302 ] = "ResourceMoved" ;
HttpCodes [ HttpCodes [ "SeeOther" ] = 303 ] = "SeeOther" ;
HttpCodes [ HttpCodes [ "NotModified" ] = 304 ] = "NotModified" ;
HttpCodes [ HttpCodes [ "UseProxy" ] = 305 ] = "UseProxy" ;
HttpCodes [ HttpCodes [ "SwitchProxy" ] = 306 ] = "SwitchProxy" ;
HttpCodes [ HttpCodes [ "TemporaryRedirect" ] = 307 ] = "TemporaryRedirect" ;
HttpCodes [ HttpCodes [ "PermanentRedirect" ] = 308 ] = "PermanentRedirect" ;
HttpCodes [ HttpCodes [ "BadRequest" ] = 400 ] = "BadRequest" ;
HttpCodes [ HttpCodes [ "Unauthorized" ] = 401 ] = "Unauthorized" ;
HttpCodes [ HttpCodes [ "PaymentRequired" ] = 402 ] = "PaymentRequired" ;
HttpCodes [ HttpCodes [ "Forbidden" ] = 403 ] = "Forbidden" ;
HttpCodes [ HttpCodes [ "NotFound" ] = 404 ] = "NotFound" ;
HttpCodes [ HttpCodes [ "MethodNotAllowed" ] = 405 ] = "MethodNotAllowed" ;
HttpCodes [ HttpCodes [ "NotAcceptable" ] = 406 ] = "NotAcceptable" ;
HttpCodes [ HttpCodes [ "ProxyAuthenticationRequired" ] = 407 ] = "ProxyAuthenticationRequired" ;
HttpCodes [ HttpCodes [ "RequestTimeout" ] = 408 ] = "RequestTimeout" ;
HttpCodes [ HttpCodes [ "Conflict" ] = 409 ] = "Conflict" ;
HttpCodes [ HttpCodes [ "Gone" ] = 410 ] = "Gone" ;
HttpCodes [ HttpCodes [ "TooManyRequests" ] = 429 ] = "TooManyRequests" ;
HttpCodes [ HttpCodes [ "InternalServerError" ] = 500 ] = "InternalServerError" ;
HttpCodes [ HttpCodes [ "NotImplemented" ] = 501 ] = "NotImplemented" ;
HttpCodes [ HttpCodes [ "BadGateway" ] = 502 ] = "BadGateway" ;
HttpCodes [ HttpCodes [ "ServiceUnavailable" ] = 503 ] = "ServiceUnavailable" ;
HttpCodes [ HttpCodes [ "GatewayTimeout" ] = 504 ] = "GatewayTimeout" ;
} ) ( HttpCodes = exports . HttpCodes || ( exports . HttpCodes = { } ) ) ;
const HttpRedirectCodes = [ HttpCodes . MovedPermanently , HttpCodes . ResourceMoved , HttpCodes . SeeOther , HttpCodes . TemporaryRedirect , HttpCodes . PermanentRedirect ] ;
const HttpResponseRetryCodes = [ HttpCodes . BadGateway , HttpCodes . ServiceUnavailable , HttpCodes . GatewayTimeout ] ;
const NetworkRetryErrors = [ 'ECONNRESET' , 'ENOTFOUND' , 'ESOCKETTIMEDOUT' , 'ETIMEDOUT' , 'ECONNREFUSED' ] ;
const RetryableHttpVerbs = [ 'OPTIONS' , 'GET' , 'DELETE' , 'HEAD' ] ;
const ExponentialBackoffCeiling = 10 ;
const ExponentialBackoffTimeSlice = 5 ;
class HttpClientResponse {
constructor ( message ) {
this . message = message ;
}
readBody ( ) {
return new Promise ( ( resolve , reject ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const chunks = [ ] ;
const encodingCharset = util . obtainContentCharset ( this ) ;
// Extract Encoding from header: 'content-encoding'
// Match `gzip`, `gzip, deflate` variations of GZIP encoding
const contentEncoding = this . message . headers [ 'content-encoding' ] || '' ;
const isGzippedEncoded = new RegExp ( '(gzip$)|(gzip, *deflate)' ) . test ( contentEncoding ) ;
this . message . on ( 'data' , function ( data ) {
const chunk = ( typeof data === 'string' ) ? Buffer . from ( data , encodingCharset ) : data ;
chunks . push ( chunk ) ;
} ) . on ( 'end' , function ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const buffer = Buffer . concat ( chunks ) ;
if ( isGzippedEncoded ) { // Process GZipped Response Body HERE
const gunzippedBody = yield util . decompressGzippedContent ( buffer , encodingCharset ) ;
resolve ( gunzippedBody ) ;
}
else {
resolve ( buffer . toString ( encodingCharset ) ) ;
}
} ) ;
} ) . on ( 'error' , function ( err ) {
reject ( err ) ;
} ) ;
} ) ) ;
}
}
exports . HttpClientResponse = HttpClientResponse ;
function isHttps ( requestUrl ) {
let parsedUrl = url . parse ( requestUrl ) ;
return parsedUrl . protocol === 'https:' ;
}
exports . isHttps = isHttps ;
var EnvironmentVariables ;
( function ( EnvironmentVariables ) {
EnvironmentVariables [ "HTTP_PROXY" ] = "HTTP_PROXY" ;
EnvironmentVariables [ "HTTPS_PROXY" ] = "HTTPS_PROXY" ;
EnvironmentVariables [ "NO_PROXY" ] = "NO_PROXY" ;
} ) ( EnvironmentVariables || ( EnvironmentVariables = { } ) ) ;
class HttpClient {
constructor ( userAgent , handlers , requestOptions ) {
this . _ignoreSslError = false ;
this . _allowRedirects = true ;
this . _allowRedirectDowngrade = false ;
this . _maxRedirects = 50 ;
this . _allowRetries = false ;
this . _maxRetries = 1 ;
this . _keepAlive = false ;
this . _disposed = false ;
this . userAgent = userAgent ;
this . handlers = handlers || [ ] ;
let no _proxy = process . env [ EnvironmentVariables . NO _PROXY ] ;
if ( no _proxy ) {
this . _httpProxyBypassHosts = [ ] ;
no _proxy . split ( ',' ) . forEach ( bypass => {
this . _httpProxyBypassHosts . push ( util . buildProxyBypassRegexFromEnv ( bypass ) ) ;
} ) ;
}
this . requestOptions = requestOptions ;
if ( requestOptions ) {
if ( requestOptions . ignoreSslError != null ) {
this . _ignoreSslError = requestOptions . ignoreSslError ;
}
this . _socketTimeout = requestOptions . socketTimeout ;
this . _httpProxy = requestOptions . proxy ;
if ( requestOptions . proxy && requestOptions . proxy . proxyBypassHosts ) {
this . _httpProxyBypassHosts = [ ] ;
requestOptions . proxy . proxyBypassHosts . forEach ( bypass => {
this . _httpProxyBypassHosts . push ( new RegExp ( bypass , 'i' ) ) ;
} ) ;
}
this . _certConfig = requestOptions . cert ;
if ( this . _certConfig ) {
// If using cert, need fs
fs = _ _nccwpck _require _ _ ( 7147 ) ;
// cache the cert content into memory, so we don't have to read it from disk every time
if ( this . _certConfig . caFile && fs . existsSync ( this . _certConfig . caFile ) ) {
this . _ca = fs . readFileSync ( this . _certConfig . caFile , 'utf8' ) ;
}
if ( this . _certConfig . certFile && fs . existsSync ( this . _certConfig . certFile ) ) {
this . _cert = fs . readFileSync ( this . _certConfig . certFile , 'utf8' ) ;
}
if ( this . _certConfig . keyFile && fs . existsSync ( this . _certConfig . keyFile ) ) {
this . _key = fs . readFileSync ( this . _certConfig . keyFile , 'utf8' ) ;
}
}
if ( requestOptions . allowRedirects != null ) {
this . _allowRedirects = requestOptions . allowRedirects ;
}
if ( requestOptions . allowRedirectDowngrade != null ) {
this . _allowRedirectDowngrade = requestOptions . allowRedirectDowngrade ;
}
if ( requestOptions . maxRedirects != null ) {
this . _maxRedirects = Math . max ( requestOptions . maxRedirects , 0 ) ;
}
if ( requestOptions . keepAlive != null ) {
this . _keepAlive = requestOptions . keepAlive ;
}
if ( requestOptions . allowRetries != null ) {
this . _allowRetries = requestOptions . allowRetries ;
}
if ( requestOptions . maxRetries != null ) {
this . _maxRetries = requestOptions . maxRetries ;
}
}
}
options ( requestUrl , additionalHeaders ) {
return this . request ( 'OPTIONS' , requestUrl , null , additionalHeaders || { } ) ;
}
get ( requestUrl , additionalHeaders ) {
return this . request ( 'GET' , requestUrl , null , additionalHeaders || { } ) ;
}
del ( requestUrl , additionalHeaders ) {
return this . request ( 'DELETE' , requestUrl , null , additionalHeaders || { } ) ;
}
post ( requestUrl , data , additionalHeaders ) {
return this . request ( 'POST' , requestUrl , data , additionalHeaders || { } ) ;
}
patch ( requestUrl , data , additionalHeaders ) {
return this . request ( 'PATCH' , requestUrl , data , additionalHeaders || { } ) ;
}
put ( requestUrl , data , additionalHeaders ) {
return this . request ( 'PUT' , requestUrl , data , additionalHeaders || { } ) ;
}
head ( requestUrl , additionalHeaders ) {
return this . request ( 'HEAD' , requestUrl , null , additionalHeaders || { } ) ;
}
sendStream ( verb , requestUrl , stream , additionalHeaders ) {
return this . request ( verb , requestUrl , stream , additionalHeaders ) ;
}
/ * *
* Makes a raw http request .
* All other methods such as get , post , patch , and request ultimately call this .
* Prefer get , del , post and patch
* /
request ( verb , requestUrl , data , headers ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( this . _disposed ) {
throw new Error ( "Client has already been disposed." ) ;
}
let parsedUrl = url . parse ( requestUrl ) ;
let info = this . _prepareRequest ( verb , parsedUrl , headers ) ;
// Only perform retries on reads since writes may not be idempotent.
let maxTries = ( this . _allowRetries && RetryableHttpVerbs . indexOf ( verb ) != - 1 ) ? this . _maxRetries + 1 : 1 ;
let numTries = 0 ;
let response ;
while ( numTries < maxTries ) {
try {
response = yield this . requestRaw ( info , data ) ;
}
catch ( err ) {
numTries ++ ;
if ( err && err . code && NetworkRetryErrors . indexOf ( err . code ) > - 1 && numTries < maxTries ) {
yield this . _performExponentialBackoff ( numTries ) ;
continue ;
}
throw err ;
}
// Check if it's an authentication challenge
if ( response && response . message && response . message . statusCode === HttpCodes . Unauthorized ) {
let authenticationHandler ;
for ( let i = 0 ; i < this . handlers . length ; i ++ ) {
if ( this . handlers [ i ] . canHandleAuthentication ( response ) ) {
authenticationHandler = this . handlers [ i ] ;
break ;
}
}
if ( authenticationHandler ) {
return authenticationHandler . handleAuthentication ( this , info , data ) ;
}
else {
// We have received an unauthorized response but have no handlers to handle it.
// Let the response return to the caller.
return response ;
}
}
let redirectsRemaining = this . _maxRedirects ;
while ( HttpRedirectCodes . indexOf ( response . message . statusCode ) != - 1
&& this . _allowRedirects
&& redirectsRemaining > 0 ) {
const redirectUrl = response . message . headers [ "location" ] ;
if ( ! redirectUrl ) {
// if there's no location to redirect to, we won't
break ;
}
let parsedRedirectUrl = url . parse ( redirectUrl ) ;
if ( parsedUrl . protocol == 'https:' && parsedUrl . protocol != parsedRedirectUrl . protocol && ! this . _allowRedirectDowngrade ) {
throw new Error ( "Redirect from HTTPS to HTTP protocol. This downgrade is not allowed for security reasons. If you want to allow this behavior, set the allowRedirectDowngrade option to true." ) ;
}
// we need to finish reading the response before reassigning response
// which will leak the open socket.
yield response . readBody ( ) ;
// let's make the request with the new redirectUrl
info = this . _prepareRequest ( verb , parsedRedirectUrl , headers ) ;
response = yield this . requestRaw ( info , data ) ;
redirectsRemaining -- ;
}
if ( HttpResponseRetryCodes . indexOf ( response . message . statusCode ) == - 1 ) {
// If not a retry code, return immediately instead of retrying
return response ;
}
numTries += 1 ;
if ( numTries < maxTries ) {
yield response . readBody ( ) ;
yield this . _performExponentialBackoff ( numTries ) ;
}
}
return response ;
} ) ;
}
/ * *
* Needs to be called if keepAlive is set to true in request options .
* /
dispose ( ) {
if ( this . _agent ) {
this . _agent . destroy ( ) ;
}
this . _disposed = true ;
}
/ * *
* Raw request .
* @ param info
* @ param data
* /
requestRaw ( info , data ) {
return new Promise ( ( resolve , reject ) => {
let callbackForResult = function ( err , res ) {
if ( err ) {
reject ( err ) ;
}
resolve ( res ) ;
} ;
this . requestRawWithCallback ( info , data , callbackForResult ) ;
} ) ;
}
/ * *
* Raw request with callback .
* @ param info
* @ param data
* @ param onResult
* /
requestRawWithCallback ( info , data , onResult ) {
let socket ;
if ( typeof ( data ) === 'string' ) {
info . options . headers [ "Content-Length" ] = Buffer . byteLength ( data , 'utf8' ) ;
}
let callbackCalled = false ;
let handleResult = ( err , res ) => {
if ( ! callbackCalled ) {
callbackCalled = true ;
onResult ( err , res ) ;
}
} ;
let req = info . httpModule . request ( info . options , ( msg ) => {
let res = new HttpClientResponse ( msg ) ;
handleResult ( null , res ) ;
} ) ;
req . on ( 'socket' , ( sock ) => {
socket = sock ;
} ) ;
// If we ever get disconnected, we want the socket to timeout eventually
req . setTimeout ( this . _socketTimeout || 3 * 60000 , ( ) => {
if ( socket ) {
socket . destroy ( ) ;
}
handleResult ( new Error ( 'Request timeout: ' + info . options . path ) , null ) ;
} ) ;
req . on ( 'error' , function ( err ) {
// err has statusCode property
// res should have headers
handleResult ( err , null ) ;
} ) ;
if ( data && typeof ( data ) === 'string' ) {
req . write ( data , 'utf8' ) ;
}
if ( data && typeof ( data ) !== 'string' ) {
data . on ( 'close' , function ( ) {
req . end ( ) ;
} ) ;
data . pipe ( req ) ;
}
else {
req . end ( ) ;
}
}
_prepareRequest ( method , requestUrl , headers ) {
const info = { } ;
info . parsedUrl = requestUrl ;
const usingSsl = info . parsedUrl . protocol === 'https:' ;
info . httpModule = usingSsl ? https : http ;
const defaultPort = usingSsl ? 443 : 80 ;
info . options = { } ;
info . options . host = info . parsedUrl . hostname ;
info . options . port = info . parsedUrl . port ? parseInt ( info . parsedUrl . port ) : defaultPort ;
info . options . path = ( info . parsedUrl . pathname || '' ) + ( info . parsedUrl . search || '' ) ;
info . options . method = method ;
info . options . timeout = ( this . requestOptions && this . requestOptions . socketTimeout ) || this . _socketTimeout ;
this . _socketTimeout = info . options . timeout ;
info . options . headers = this . _mergeHeaders ( headers ) ;
if ( this . userAgent != null ) {
info . options . headers [ "user-agent" ] = this . userAgent ;
}
info . options . agent = this . _getAgent ( info . parsedUrl ) ;
// gives handlers an opportunity to participate
if ( this . handlers && ! this . _isPresigned ( url . format ( requestUrl ) ) ) {
this . handlers . forEach ( ( handler ) => {
handler . prepareRequest ( info . options ) ;
} ) ;
}
return info ;
}
_isPresigned ( requestUrl ) {
if ( this . requestOptions && this . requestOptions . presignedUrlPatterns ) {
const patterns = this . requestOptions . presignedUrlPatterns ;
for ( let i = 0 ; i < patterns . length ; i ++ ) {
if ( requestUrl . match ( patterns [ i ] ) ) {
return true ;
}
}
}
return false ;
}
_mergeHeaders ( headers ) {
const lowercaseKeys = obj => Object . keys ( obj ) . reduce ( ( c , k ) => ( c [ k . toLowerCase ( ) ] = obj [ k ] , c ) , { } ) ;
if ( this . requestOptions && this . requestOptions . headers ) {
return Object . assign ( { } , lowercaseKeys ( this . requestOptions . headers ) , lowercaseKeys ( headers ) ) ;
}
return lowercaseKeys ( headers || { } ) ;
}
_getAgent ( parsedUrl ) {
let agent ;
let proxy = this . _getProxy ( parsedUrl ) ;
let useProxy = proxy . proxyUrl && proxy . proxyUrl . hostname && ! this . _isMatchInBypassProxyList ( parsedUrl ) ;
if ( this . _keepAlive && useProxy ) {
agent = this . _proxyAgent ;
}
if ( this . _keepAlive && ! useProxy ) {
agent = this . _agent ;
}
// if agent is already assigned use that agent.
if ( ! ! agent ) {
return agent ;
}
const usingSsl = parsedUrl . protocol === 'https:' ;
let maxSockets = 100 ;
if ( ! ! this . requestOptions ) {
maxSockets = this . requestOptions . maxSockets || http . globalAgent . maxSockets ;
}
if ( useProxy ) {
// If using proxy, need tunnel
if ( ! tunnel ) {
tunnel = _ _nccwpck _require _ _ ( 9958 ) ;
}
const agentOptions = {
maxSockets : maxSockets ,
keepAlive : this . _keepAlive ,
proxy : {
proxyAuth : proxy . proxyAuth ,
host : proxy . proxyUrl . hostname ,
port : proxy . proxyUrl . port
} ,
} ;
let tunnelAgent ;
const overHttps = proxy . proxyUrl . protocol === 'https:' ;
if ( usingSsl ) {
tunnelAgent = overHttps ? tunnel . httpsOverHttps : tunnel . httpsOverHttp ;
}
else {
tunnelAgent = overHttps ? tunnel . httpOverHttps : tunnel . httpOverHttp ;
}
agent = tunnelAgent ( agentOptions ) ;
this . _proxyAgent = agent ;
}
// if reusing agent across request and tunneling agent isn't assigned create a new agent
if ( this . _keepAlive && ! agent ) {
const options = { keepAlive : this . _keepAlive , maxSockets : maxSockets } ;
agent = usingSsl ? new https . Agent ( options ) : new http . Agent ( options ) ;
this . _agent = agent ;
}
// if not using private agent and tunnel agent isn't setup then use global agent
if ( ! agent ) {
agent = usingSsl ? https . globalAgent : http . globalAgent ;
}
if ( usingSsl && this . _ignoreSslError ) {
// we don't want to set NODE_TLS_REJECT_UNAUTHORIZED=0 since that will affect request for entire process
// http.RequestOptions doesn't expose a way to modify RequestOptions.agent.options
// we have to cast it to any and change it directly
agent . options = Object . assign ( agent . options || { } , { rejectUnauthorized : false } ) ;
}
if ( usingSsl && this . _certConfig ) {
agent . options = Object . assign ( agent . options || { } , { ca : this . _ca , cert : this . _cert , key : this . _key , passphrase : this . _certConfig . passphrase } ) ;
}
return agent ;
}
_getProxy ( parsedUrl ) {
let usingSsl = parsedUrl . protocol === 'https:' ;
let proxyConfig = this . _httpProxy ;
// fallback to http_proxy and https_proxy env
let https _proxy = process . env [ EnvironmentVariables . HTTPS _PROXY ] ;
let http _proxy = process . env [ EnvironmentVariables . HTTP _PROXY ] ;
if ( ! proxyConfig ) {
if ( https _proxy && usingSsl ) {
proxyConfig = {
proxyUrl : https _proxy
} ;
}
else if ( http _proxy ) {
proxyConfig = {
proxyUrl : http _proxy
} ;
}
}
let proxyUrl ;
let proxyAuth ;
if ( proxyConfig ) {
if ( proxyConfig . proxyUrl . length > 0 ) {
proxyUrl = url . parse ( proxyConfig . proxyUrl ) ;
}
if ( proxyConfig . proxyUsername || proxyConfig . proxyPassword ) {
proxyAuth = proxyConfig . proxyUsername + ":" + proxyConfig . proxyPassword ;
}
}
return { proxyUrl : proxyUrl , proxyAuth : proxyAuth } ;
}
_isMatchInBypassProxyList ( parsedUrl ) {
if ( ! this . _httpProxyBypassHosts ) {
return false ;
}
let bypass = false ;
this . _httpProxyBypassHosts . forEach ( bypassHost => {
if ( bypassHost . test ( parsedUrl . href ) ) {
bypass = true ;
}
} ) ;
return bypass ;
}
_performExponentialBackoff ( retryNumber ) {
retryNumber = Math . min ( ExponentialBackoffCeiling , retryNumber ) ;
const ms = ExponentialBackoffTimeSlice * Math . pow ( 2 , retryNumber ) ;
return new Promise ( resolve => setTimeout ( ( ) => resolve ( ) , ms ) ) ;
}
}
exports . HttpClient = HttpClient ;
2022-06-27 14:17:15 -04:00
/***/ } ) ,
/***/ 5235 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
2022-07-11 13:48:02 -04:00
// Copyright (c) Microsoft. All rights reserved.
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
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 ) : new P ( function ( resolve ) { resolve ( result . value ) ; } ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
const qs = _ _nccwpck _require _ _ ( 737 ) ;
const url = _ _nccwpck _require _ _ ( 7310 ) ;
const path = _ _nccwpck _require _ _ ( 1017 ) ;
const zlib = _ _nccwpck _require _ _ ( 9796 ) ;
/ * *
* creates an url from a request url and optional base url ( http : //server:8080)
* @ param { string } resource - a fully qualified url or relative path
* @ param { string } baseUrl - an optional baseUrl ( http : //server:8080)
* @ param { IRequestOptions } options - an optional options object , could include QueryParameters e . g .
* @ return { string } - resultant url
* /
function getUrl ( resource , baseUrl , queryParams ) {
const pathApi = path . posix || path ;
let requestUrl = '' ;
if ( ! baseUrl ) {
requestUrl = resource ;
}
else if ( ! resource ) {
requestUrl = baseUrl ;
}
else {
const base = url . parse ( baseUrl ) ;
const resultantUrl = url . parse ( resource ) ;
// resource (specific per request) elements take priority
resultantUrl . protocol = resultantUrl . protocol || base . protocol ;
resultantUrl . auth = resultantUrl . auth || base . auth ;
resultantUrl . host = resultantUrl . host || base . host ;
resultantUrl . pathname = pathApi . resolve ( base . pathname , resultantUrl . pathname ) ;
if ( ! resultantUrl . pathname . endsWith ( '/' ) && resource . endsWith ( '/' ) ) {
resultantUrl . pathname += '/' ;
}
requestUrl = url . format ( resultantUrl ) ;
}
return queryParams ?
getUrlWithParsedQueryParams ( requestUrl , queryParams ) :
requestUrl ;
}
exports . getUrl = getUrl ;
/ * *
*
* @ param { string } requestUrl
* @ param { IRequestQueryParams } queryParams
* @ return { string } - Request ' s URL with Query Parameters appended / parsed .
* /
function getUrlWithParsedQueryParams ( requestUrl , queryParams ) {
const url = requestUrl . replace ( /\?$/g , '' ) ; // Clean any extra end-of-string "?" character
const parsedQueryParams = qs . stringify ( queryParams . params , buildParamsStringifyOptions ( queryParams ) ) ;
return ` ${ url } ${ parsedQueryParams } ` ;
}
/ * *
* Build options for QueryParams Stringifying .
*
* @ param { IRequestQueryParams } queryParams
* @ return { object }
* /
function buildParamsStringifyOptions ( queryParams ) {
let options = {
addQueryPrefix : true ,
delimiter : ( queryParams . options || { } ) . separator || '&' ,
allowDots : ( queryParams . options || { } ) . shouldAllowDots || false ,
arrayFormat : ( queryParams . options || { } ) . arrayFormat || 'repeat' ,
encodeValuesOnly : ( queryParams . options || { } ) . shouldOnlyEncodeValues || true
} ;
return options ;
}
/ * *
* Decompress / Decode gzip encoded JSON
* Using Node . js built - in zlib module
*
* @ param { Buffer } buffer
* @ param { string } charset ? - optional ; defaults to 'utf-8'
* @ return { Promise < string > }
* /
function decompressGzippedContent ( buffer , charset ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return new Promise ( ( resolve , reject ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
zlib . gunzip ( buffer , function ( error , buffer ) {
if ( error ) {
reject ( error ) ;
}
else {
resolve ( buffer . toString ( charset || 'utf-8' ) ) ;
}
} ) ;
} ) ) ;
} ) ;
}
exports . decompressGzippedContent = decompressGzippedContent ;
/ * *
* Builds a RegExp to test urls against for deciding
* wether to bypass proxy from an entry of the
* environment variable setting NO _PROXY
*
* @ param { string } bypass
* @ return { RegExp }
* /
function buildProxyBypassRegexFromEnv ( bypass ) {
try {
// We need to keep this around for back-compat purposes
return new RegExp ( bypass , 'i' ) ;
}
catch ( err ) {
if ( err instanceof SyntaxError && ( bypass || "" ) . startsWith ( "*" ) ) {
let wildcardEscaped = bypass . replace ( '*' , '(.*)' ) ;
return new RegExp ( wildcardEscaped , 'i' ) ;
}
throw err ;
}
}
exports . buildProxyBypassRegexFromEnv = buildProxyBypassRegexFromEnv ;
/ * *
* Obtain Response ' s Content Charset .
* Through inspecting ` content-type ` response header .
* It Returns 'utf-8' if NO charset specified / matched .
*
* @ param { IHttpClientResponse } response
* @ return { string } - Content Encoding Charset ; Default = utf - 8
* /
function obtainContentCharset ( response ) {
// Find the charset, if specified.
// Search for the `charset=CHARSET` string, not including `;,\r\n`
// Example: content-type: 'application/json;charset=utf-8'
// |__ matches would be ['charset=utf-8', 'utf-8', index: 18, input: 'application/json; charset=utf-8']
// |_____ matches[1] would have the charset :tada: , in our example it's utf-8
// However, if the matches Array was empty or no charset found, 'utf-8' would be returned by default.
const nodeSupportedEncodings = [ 'ascii' , 'utf8' , 'utf16le' , 'ucs2' , 'base64' , 'binary' , 'hex' ] ;
const contentType = response . message . headers [ 'content-type' ] || '' ;
const matches = contentType . match ( /charset=([^;,\r\n]+)/i ) ;
return ( matches && matches [ 1 ] && nodeSupportedEncodings . indexOf ( matches [ 1 ] ) != - 1 ) ? matches [ 1 ] : 'utf-8' ;
}
exports . obtainContentCharset = obtainContentCharset ;
/***/ } ) ,
/***/ 7163 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
"use strict" ;
2022-06-27 14:17:15 -04:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-07-11 13:48:02 -04:00
function getUserAgent ( ) {
if ( typeof navigator === "object" && "userAgent" in navigator ) {
return navigator . userAgent ;
}
if ( typeof process === "object" && "version" in process ) {
return ` Node.js/ ${ process . version . substr ( 1 ) } ( ${ process . platform } ; ${ process . arch } ) ` ;
}
return "<environment undetectable>" ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
exports . getUserAgent = getUserAgent ;
//# sourceMappingURL=index.js.map
2022-06-27 14:17:15 -04:00
/***/ } ) ,
/***/ 919 :
/***/ ( ( module ) => {
/ * *
* Convert array of 16 byte values to UUID string format of the form :
* XXXXXXXX - XXXX - XXXX - XXXX - XXXXXXXXXXXX
* /
var byteToHex = [ ] ;
for ( var i = 0 ; i < 256 ; ++ i ) {
byteToHex [ i ] = ( i + 0x100 ) . toString ( 16 ) . substr ( 1 ) ;
}
function bytesToUuid ( buf , offset ) {
var i = offset || 0 ;
var bth = byteToHex ;
// join used to fix memory issue caused by concatenation: https://bugs.chromium.org/p/v8/issues/detail?id=3175#c4
return ( [
bth [ buf [ i ++ ] ] , bth [ buf [ i ++ ] ] ,
bth [ buf [ i ++ ] ] , bth [ buf [ i ++ ] ] , '-' ,
bth [ buf [ i ++ ] ] , bth [ buf [ i ++ ] ] , '-' ,
bth [ buf [ i ++ ] ] , bth [ buf [ i ++ ] ] , '-' ,
bth [ buf [ i ++ ] ] , bth [ buf [ i ++ ] ] , '-' ,
bth [ buf [ i ++ ] ] , bth [ buf [ i ++ ] ] ,
bth [ buf [ i ++ ] ] , bth [ buf [ i ++ ] ] ,
bth [ buf [ i ++ ] ] , bth [ buf [ i ++ ] ]
] ) . join ( '' ) ;
}
module . exports = bytesToUuid ;
/***/ } ) ,
/***/ 7868 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
// Unique ID creation requires a high quality random # generator. In node.js
// this is pretty straight-forward - we use the crypto API.
var crypto = _ _nccwpck _require _ _ ( 6113 ) ;
module . exports = function nodeRNG ( ) {
return crypto . randomBytes ( 16 ) ;
} ;
/***/ } ) ,
/***/ 3902 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
var rng = _ _nccwpck _require _ _ ( 7868 ) ;
var bytesToUuid = _ _nccwpck _require _ _ ( 919 ) ;
function v4 ( options , buf , offset ) {
var i = buf && offset || 0 ;
if ( typeof ( options ) == 'string' ) {
buf = options === 'binary' ? new Array ( 16 ) : null ;
options = null ;
}
options = options || { } ;
var rnds = options . random || ( options . rng || rng ) ( ) ;
// 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 ) {
for ( var ii = 0 ; ii < 16 ; ++ ii ) {
buf [ i + ii ] = rnds [ ii ] ;
}
}
return buf || bytesToUuid ( rnds ) ;
}
module . exports = v4 ;
2022-07-11 13:48:02 -04:00
/***/ } ) ,
/***/ 3985 :
/***/ ( ( 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
}
}
2022-06-27 14:17:15 -04:00
/***/ } ) ,
/***/ 34 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
// Copyright (c) Microsoft Corporation.
// Copyright (c) Microsoft Corporation.
// Licensed under the MIT license.
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 . walkSync = exports . findHelm = exports . downloadHelm = exports . getHelmDownloadURL = exports . getExecutableExtension = exports . getLatestHelmVersion = exports . getValidVersion = exports . run = void 0 ;
const os = _ _nccwpck _require _ _ ( 2037 ) ;
const path = _ _nccwpck _require _ _ ( 1017 ) ;
const util = _ _nccwpck _require _ _ ( 3837 ) ;
const fs = _ _nccwpck _require _ _ ( 7147 ) ;
const toolCache = _ _nccwpck _require _ _ ( 3594 ) ;
const core = _ _nccwpck _require _ _ ( 6024 ) ;
2022-07-11 13:48:02 -04:00
const graphql _1 = _ _nccwpck _require _ _ ( 1660 ) ;
const helmToolName = 'helm' ;
const stableHelmVersion = 'v3.9.0' ;
2022-06-27 14:17:15 -04:00
function run ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
2022-07-11 13:48:02 -04:00
let version = core . getInput ( 'version' , { required : true } ) ;
if ( version !== 'latest' && version [ 0 ] !== 'v' ) {
core . info ( 'Getting latest Helm version' ) ;
2022-06-27 14:17:15 -04:00
version = getValidVersion ( version ) ;
}
2022-07-11 13:48:02 -04:00
if ( version . toLocaleLowerCase ( ) === 'latest' ) {
2022-06-27 14:17:15 -04:00
version = yield getLatestHelmVersion ( ) ;
}
2022-07-11 13:48:02 -04:00
core . startGroup ( ` Downloading ${ version } ` ) ;
const cachedPath = yield downloadHelm ( version ) ;
core . endGroup ( ) ;
2022-06-27 14:17:15 -04:00
try {
2022-07-11 13:48:02 -04:00
if ( ! process . env [ 'PATH' ] . startsWith ( path . dirname ( cachedPath ) ) ) {
2022-06-27 14:17:15 -04:00
core . addPath ( path . dirname ( cachedPath ) ) ;
}
}
catch ( _a ) {
//do nothing, set as output variable
}
2022-07-11 13:48:02 -04:00
core . info ( ` Helm tool version ' ${ version } ' has been cached at ${ cachedPath } ` ) ;
core . setOutput ( 'helm-path' , cachedPath ) ;
2022-06-27 14:17:15 -04:00
} ) ;
}
exports . run = run ;
2022-07-11 13:48:02 -04:00
// Prefixes version with v
2022-06-27 14:17:15 -04:00
function getValidVersion ( version ) {
2022-07-11 13:48:02 -04:00
return 'v' + version ;
2022-06-27 14:17:15 -04:00
}
exports . getValidVersion = getValidVersion ;
2022-07-11 13:48:02 -04:00
// Gets the latest helm version or returns a default stable if getting latest fails
2022-06-27 14:17:15 -04:00
function getLatestHelmVersion ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
try {
2022-07-11 13:48:02 -04:00
const { repository } = yield graphql _1 . graphql ( `
{
repository ( name : "helm" , owner : "helm" ) {
releases ( last : 100 ) {
nodes {
tagName
}
}
}
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
` );
const releases = repository . releases . nodes . reverse ( ) ;
const latestValidRelease = releases . find ( ( release ) => isValidVersion ( release . tagName ) ) ;
if ( latestValidRelease )
return latestValidRelease ;
2022-06-27 14:17:15 -04:00
}
catch ( err ) {
2022-07-11 13:48:02 -04:00
core . warning ( ` Error while fetching latest Helm release: ${ err . toString ( ) } . Using default version ${ stableHelmVersion } ` ) ;
2022-06-27 14:17:15 -04:00
return stableHelmVersion ;
}
2022-07-11 13:48:02 -04:00
core . warning ( ` Could not find valid release. Using default version ${ stableHelmVersion } ` ) ;
2022-06-27 14:17:15 -04:00
return stableHelmVersion ;
} ) ;
}
exports . getLatestHelmVersion = getLatestHelmVersion ;
// isValidVersion checks if verison is a stable release
function isValidVersion ( version ) {
2022-07-11 13:48:02 -04:00
return version . indexOf ( 'rc' ) == - 1 ;
2022-06-27 14:17:15 -04:00
}
function getExecutableExtension ( ) {
if ( os . type ( ) . match ( /^Win/ ) ) {
2022-07-11 13:48:02 -04:00
return '.exe' ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
return '' ;
2022-06-27 14:17:15 -04:00
}
exports . getExecutableExtension = getExecutableExtension ;
2022-07-11 13:48:02 -04:00
const LINUX = 'Linux' ;
const MAC _OS = 'Darwin' ;
const WINDOWS = 'Windows_NT' ;
const ARM64 = 'arm64' ;
2022-06-27 14:17:15 -04:00
function getHelmDownloadURL ( version ) {
const arch = os . arch ( ) ;
const operatingSystem = os . type ( ) ;
switch ( true ) {
case operatingSystem == LINUX && arch == ARM64 :
2022-07-11 13:48:02 -04:00
return util . format ( 'https://get.helm.sh/helm-%s-linux-arm64.zip' , version ) ;
2022-06-27 14:17:15 -04:00
case operatingSystem == LINUX :
2022-07-11 13:48:02 -04:00
return util . format ( 'https://get.helm.sh/helm-%s-linux-amd64.zip' , version ) ;
2022-06-27 14:17:15 -04:00
case operatingSystem == MAC _OS && arch == ARM64 :
2022-07-11 13:48:02 -04:00
return util . format ( 'https://get.helm.sh/helm-%s-darwin-arm64.zip' , version ) ;
2022-06-27 14:17:15 -04:00
case operatingSystem == MAC _OS :
2022-07-11 13:48:02 -04:00
return util . format ( 'https://get.helm.sh/helm-%s-darwin-amd64.zip' , version ) ;
2022-06-27 14:17:15 -04:00
case operatingSystem == WINDOWS :
default :
2022-07-11 13:48:02 -04:00
return util . format ( 'https://get.helm.sh/helm-%s-windows-amd64.zip' , version ) ;
2022-06-27 14:17:15 -04:00
}
}
exports . getHelmDownloadURL = getHelmDownloadURL ;
function downloadHelm ( version ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
let cachedToolpath = toolCache . find ( helmToolName , version ) ;
if ( ! cachedToolpath ) {
let helmDownloadPath ;
try {
helmDownloadPath = yield toolCache . downloadTool ( getHelmDownloadURL ( version ) ) ;
}
catch ( exception ) {
2022-07-11 13:48:02 -04:00
throw new Error ( ` Failed to download Helm from location ${ getHelmDownloadURL ( version ) } ` ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
fs . chmodSync ( helmDownloadPath , '777' ) ;
2022-06-27 14:17:15 -04:00
const unzipedHelmPath = yield toolCache . extractZip ( helmDownloadPath ) ;
cachedToolpath = yield toolCache . cacheDir ( unzipedHelmPath , helmToolName , version ) ;
}
const helmpath = findHelm ( cachedToolpath ) ;
if ( ! helmpath ) {
2022-07-11 13:48:02 -04:00
throw new Error ( util . format ( 'Helm executable not found in path' , cachedToolpath ) ) ;
2022-06-27 14:17:15 -04:00
}
2022-07-11 13:48:02 -04:00
fs . chmodSync ( helmpath , '777' ) ;
2022-06-27 14:17:15 -04:00
return helmpath ;
} ) ;
}
exports . downloadHelm = downloadHelm ;
function findHelm ( rootFolder ) {
2022-07-11 13:48:02 -04:00
fs . chmodSync ( rootFolder , '777' ) ;
2022-06-27 14:17:15 -04:00
var filelist = [ ] ;
exports . walkSync ( rootFolder , filelist , helmToolName + getExecutableExtension ( ) ) ;
if ( ! filelist || filelist . length == 0 ) {
2022-07-11 13:48:02 -04:00
throw new Error ( util . format ( 'Helm executable not found in path' , rootFolder ) ) ;
2022-06-27 14:17:15 -04:00
}
else {
return filelist [ 0 ] ;
}
}
exports . findHelm = findHelm ;
exports . walkSync = function ( dir , filelist , fileToFind ) {
var files = fs . readdirSync ( dir ) ;
filelist = filelist || [ ] ;
files . forEach ( function ( file ) {
if ( fs . statSync ( path . join ( dir , file ) ) . isDirectory ( ) ) {
filelist = exports . walkSync ( path . join ( dir , file ) , filelist , fileToFind ) ;
}
else {
core . debug ( file ) ;
if ( file == fileToFind ) {
filelist . push ( path . join ( dir , file ) ) ;
}
}
} ) ;
return filelist ;
} ;
run ( ) . catch ( core . setFailed ) ;
2022-07-11 13:48:02 -04:00
/***/ } ) ,
/***/ 5347 :
/***/ ( ( module ) => {
module . exports = eval ( "require" ) ( "encoding" ) ;
2022-06-27 14:17:15 -04:00
/***/ } ) ,
/***/ 9491 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "assert" ) ;
/***/ } ) ,
/***/ 2081 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "child_process" ) ;
/***/ } ) ,
/***/ 6113 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "crypto" ) ;
/***/ } ) ,
/***/ 2361 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "events" ) ;
/***/ } ) ,
/***/ 7147 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "fs" ) ;
/***/ } ) ,
/***/ 3685 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "http" ) ;
/***/ } ) ,
/***/ 5687 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "https" ) ;
/***/ } ) ,
/***/ 1808 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "net" ) ;
/***/ } ) ,
/***/ 2037 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "os" ) ;
/***/ } ) ,
/***/ 1017 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "path" ) ;
/***/ } ) ,
2022-07-11 13:48:02 -04:00
/***/ 5477 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "punycode" ) ;
/***/ } ) ,
/***/ 2781 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "stream" ) ;
/***/ } ) ,
2022-06-27 14:17:15 -04:00
/***/ 1576 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "string_decoder" ) ;
/***/ } ) ,
/***/ 9512 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "timers" ) ;
/***/ } ) ,
/***/ 4404 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "tls" ) ;
/***/ } ) ,
/***/ 7310 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "url" ) ;
/***/ } ) ,
/***/ 3837 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "util" ) ;
/***/ } ) ,
/***/ 9796 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "zlib" ) ;
2022-07-11 13:48:02 -04:00
/***/ } ) ,
/***/ 1907 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = JSON . parse ( ' [ [ [ 0 , 44 ] , "disallowed_STD3_valid" ] , [ [ 45 , 46 ] , "valid" ] , [ [ 47 , 47 ] , "disallowed_STD3_valid" ] , [ [ 48 , 57 ] , "valid" ] , [ [ 58 , 64 ] , "disallowed_STD3_valid" ] , [ [ 65 , 65 ] , "mapped" , [ 97 ] ] , [ [ 66 , 66 ] , "mapped" , [ 98 ] ] , [ [ 67 , 67 ] , "mapped" , [ 99 ] ] , [ [ 68 , 68 ] , "mapped" , [ 100 ] ] , [ [ 69 , 69 ] , "mapped" , [ 101 ] ] , [ [ 70 , 70 ] , "mapped" , [ 102 ] ] , [ [ 71 , 71 ] , "mapped" , [ 103 ] ] , [ [ 72 , 72 ] , "mapped" , [ 104 ] ] , [ [ 73 , 73 ] , "mapped" , [ 105 ] ] , [ [ 74 , 74 ] , "mapped" , [ 106 ] ] , [ [ 75 , 75 ] , "mapped" , [ 107 ] ] , [ [ 76 , 76 ] , "mapped" , [ 108 ] ] , [ [ 77 , 77 ] , "mapped" , [ 109 ] ] , [ [ 78 , 78 ] , "mapped" , [ 110 ] ] , [ [ 79 , 79 ] , "mapped" , [ 111 ] ] , [ [ 80 , 80 ] , "mapped" , [ 112 ] ] , [ [ 81 , 81 ] , "mapped" , [ 113 ] ] , [ [ 82 , 82 ] , "mapped" , [ 114 ] ] , [ [ 83 , 83 ] , "mapped" , [ 115 ] ] , [ [ 84 , 84 ] , "mapped" , [ 116 ] ] , [ [ 85 , 85 ] , "mapped" , [ 117 ] ] , [ [ 86 , 86 ] , "mapped" , [ 118 ] ] , [ [ 87 , 87 ] , "mapped" , [ 119 ] ] , [ [ 88 , 88 ] , "mapped" , [ 120 ] ] , [ [ 89 , 89 ] , "mapped" , [ 121 ] ] , [ [ 90 , 90 ] , "mapped" , [ 122 ] ] , [ [ 91 , 96 ] , "disallowed_STD3_valid" ] , [ [ 97 , 122 ] , "valid" ] , [ [ 123 , 127 ] , "disallowed_STD3_valid" ] , [ [ 128 , 159 ] , "disallowed" ] , [ [ 160 , 160 ] , "disallowed_STD3_mapped" , [ 32 ] ] , [ [ 161 , 167 ] , "valid" , [ ] , "NV8" ] , [ [ 168 , 168 ] , "disallowed_STD3_mapped" , [ 32 , 776 ] ] , [ [ 169 , 169 ] , "valid" , [ ] , "NV8" ] , [ [ 170 , 170 ] , "mapped" , [ 97 ] ] , [ [ 171 , 172 ] , "valid" , [ ] , "NV8" ] , [ [ 173 , 173 ] , "ignored" ] , [ [ 174 , 174 ] , "valid" , [ ] , "NV8" ] , [ [ 175 , 175 ] , "disallowed_STD3_mapped" , [ 32 , 772 ] ] , [ [ 176 , 177 ] , "valid" , [ ] , "NV8" ] , [ [ 178 , 178 ] , "mapped" , [ 50 ] ] , [ [ 179 , 179 ] , "mapped" , [ 51 ] ] , [ [ 180 , 180 ] , "disallowed_STD3_mapped" , [ 32 , 769 ] ] , [ [ 181 , 181 ] , "mapped" , [ 956 ] ] , [ [ 182 , 182 ] , "valid" , [ ] , "NV8" ] , [ [ 183 , 183 ] , "valid" ] , [ [ 184 , 184 ] , "disallowed_STD3_mapped" , [ 32 , 807 ] ] , [ [ 185 , 185 ] , "mapped" , [ 49 ] ] , [ [ 186 , 186 ] , "mapped" , [ 111 ] ] , [ [ 187 , 187 ] , "valid" , [ ] , "NV8" ] , [ [ 188 , 188 ] , "mapped" , [ 49 , 8260 , 52 ] ] , [ [ 189 , 189 ] , "mapped" , [ 49 , 8260 , 50 ] ] , [ [ 190 , 190 ] , "mapped" , [ 51 , 8260 , 52 ] ] , [ [ 191 , 191 ] , "valid" , [ ] , "NV8" ] , [ [ 192 , 192 ] , "mapped" , [ 224 ] ] , [ [ 193 , 193 ] , "mapped" , [ 225 ] ] , [ [ 194 , 194 ] , "mapped" , [ 226 ] ] , [ [ 195 , 195 ] , "mapped" , [ 227 ] ] , [ [ 196 , 196 ] , "mapped" , [ 228 ] ] , [ [ 197 , 197 ] , "mapped" , [ 229 ] ] , [ [ 198 , 198 ] , "mapped" , [ 230 ] ] , [ [ 199 , 199 ] , "mapped" , [ 231 ] ] , [ [ 200 , 200 ] , "mapped" , [ 232 ] ] , [ [ 201 , 201 ] , "mapped" , [ 233 ] ] , [ [ 202 , 202 ] , "mapped" , [ 234 ] ] , [ [ 203 , 203 ] , "mapped" , [ 235 ] ] , [ [ 204 , 204 ] , "mapped" , [ 236 ] ] , [ [ 205 , 205 ] , "mapped" , [ 237 ] ] , [ [ 206 , 206 ] , "mapped" , [ 238 ] ] , [ [ 207 , 207 ] , "mapped" , [ 239 ] ] , [ [ 208 , 208 ] , "mapped" , [ 240 ] ] , [ [ 209 , 209 ] , "mapped" , [ 241 ] ] , [ [ 210 , 210 ] , "mapped" , [ 242 ] ] , [ [ 211 , 211 ] , "mapped" , [ 243 ] ] , [ [ 212 , 212 ] , "mapped" , [ 244 ] ] , [ [ 213 , 213 ] , "mapped" , [ 245 ] ] , [ [ 214 , 214 ] , "mapped" , [ 246 ] ] , [ [ 215 , 215 ] , "valid" , [ ] , "NV8" ] , [ [ 216 , 216 ] , "mapped" , [ 248 ] ] , [ [ 217 , 217 ] , "mapped" , [ 249 ] ] , [ [ 218 , 218 ] , "mapped" , [ 250 ] ] , [ [ 219 , 219 ] , "mapped" , [ 251 ] ] , [ [ 220 , 220 ] , "mapped" , [ 252 ] ] , [ [ 221 , 221 ] , "mapped" , [ 253 ] ] , [ [ 222 , 222 ] , "mapped" , [ 254 ] ] , [ [ 223 , 223 ] , "deviation" , [ 115 , 115 ] ] , [ [ 224 , 246 ] , "valid" ] , [ [ 247 , 247 ] , "valid" , [ ] , "NV8" ] , [ [ 248 , 255 ] , "valid" ] , [ [ 256 , 256 ] , "mapped" , [ 257 ] ] , [ [ 257 , 257 ] , "valid" ] , [ [ 258 , 258 ] , "mapped" , [ 259 ] ] , [ [ 259 , 259 ] , "valid" ] , [ [ 260 , 260 ] , "mapped" , [ 261 ] ] , [ [ 261 , 261 ] , "valid" ] , [ [ 262 , 262 ] , "mapped" , [ 263 ] ] , [ [ 263 , 263 ] , "valid" ] , [ [ 264 , 264 ] , "mapped" , [ 265 ] ] , [ [ 265 , 265 ] , "valid" ] , [ [ 266 , 266 ] , "mapped" , [ 267 ] ] , [ [ 267 , 267 ] , "valid" ] , [ [ 268 , 268 ] , "mapped" , [ 269 ] ] , [ [ 269 , 269 ] , "valid" ] , [ [ 270 , 270 ] , "mapped" , [ 271 ] ] , [ [ 271 , 271 ] , "valid" ] , [ [ 272 , 272 ] , "mapped" , [ 273 ] ] , [ [ 273 , 273 ] , "valid" ] , [ [ 274 , 274 ] , "mapped" , [ 275 ] ] , [ [ 275 , 275 ] , "valid" ] , [ [ 276 , 276 ] , "mapped" , [ 277 ] ] , [ [ 277 , 277 ] , "valid" ] , [ [ 278 , 278 ] , "mapped" , [ 279 ] ] , [ [ 279 , 279 ] , "valid" ] , [ [ 280 , 280 ] , "mapped" , [ 281 ] ] , [ [ 281 , 281 ] , "valid" ] , [ [ 282 , 282 ] , "mapped" , [ 283 ] ] , [ [ 283 , 283 ] , "valid" ] , [ [ 284 , 284 ] , "mapped" , [ 285 ] ] , [ [ 285 , 285 ] , "valid" ] , [ [ 286 , 286 ] , "mapped" , [ 287 ] ] , [ [ 287 , 287 ] , "valid" ] , [ [ 288 , 288 ] , "mapped" , [ 289 ] ] , [ [ 289 , 289 ] , "valid" ] , [ [ 290 , 290 ] , "mapped" , [ 291 ] ] , [ [ 291 , 291 ] , "valid" ] , [ [ 292 , 292 ] , "mapped" , [ 293 ] ] , [ [ 293 , 293 ] , "valid" ] , [ [ 294 , 294 ] , "mapped" , [ 295 ] ] , [ [ 295 , 295 ] , "valid" ] , [ [ 296 , 296 ] , "mapped" , [ 297 ] ] , [ [ 297 , 297 ] , "valid" ] , [ [ 298 , 298 ] , "mapped" , [ 299 ] ] , [ [ 299 , 299 ] , "valid" ] , [ [ 300 , 300 ] , "mapped" , [ 301 ] ] , [ [ 301 , 301 ] , "valid" ] , [ [ 302 , 302 ] , "mapped" , [ 303 ] ] , [ [ 303 , 303 ] , "valid" ] , [ [ 304 , 304 ] , "mapped" , [ 105 , 775 ] ] , [ [ 305 , 305 ] , "valid" ] , [ [ 306 , 307 ] , "mapped" , [ 105 , 106 ] ] , [ [ 308 , 308 ] , "mapped" , [ 309 ] ] , [ [ 309 , 309 ] , "valid" ] , [ [ 310 , 310 ] , "mapped" , [ 311 ] ] , [ [ 311 , 312 ] , "valid" ] , [ [ 313 , 313 ] , "mapped" , [ 314 ] ] , [ [ 314 , 314 ] , "valid" ] , [ [ 315 , 315 ] , "mapped" , [ 316 ] ] , [ [ 316 , 316 ] , "valid" ] , [ [ 317 , 317 ] , "mapped" , [ 318 ] ] , [ [ 318 , 318 ] , "valid" ] , [ [ 319 , 320 ] , "mapped" ,
2022-06-27 14:17:15 -04:00
/***/ } )
/******/ } ) ;
/************************************************************************/
/******/ // The module cache
/******/ var _ _webpack _module _cache _ _ = { } ;
/******/
/******/ // The require function
/******/ function _ _nccwpck _require _ _ ( moduleId ) {
/******/ // Check if module is in cache
/******/ var cachedModule = _ _webpack _module _cache _ _ [ moduleId ] ;
/******/ if ( cachedModule !== undefined ) {
/******/ return cachedModule . exports ;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = _ _webpack _module _cache _ _ [ moduleId ] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports : { }
/******/ } ;
/******/
/******/ // Execute the module function
/******/ var threw = true ;
/******/ try {
/******/ _ _webpack _modules _ _ [ moduleId ] . call ( module . exports , module , module . exports , _ _nccwpck _require _ _ ) ;
/******/ threw = false ;
/******/ } finally {
/******/ if ( threw ) delete _ _webpack _module _cache _ _ [ moduleId ] ;
/******/ }
/******/
/******/ // Return the exports of the module
/******/ return module . exports ;
/******/ }
/******/
/************************************************************************/
/******/ /* webpack/runtime/compat */
/******/
/******/ if ( typeof _ _nccwpck _require _ _ !== 'undefined' ) _ _nccwpck _require _ _ . ab = _ _dirname + "/" ;
/******/
/************************************************************************/
/******/
/******/ // startup
/******/ // Load entry module and return exports
/******/ // This entry module is referenced by other modules so it can't be inlined
/******/ var _ _webpack _exports _ _ = _ _nccwpck _require _ _ ( 34 ) ;
/******/ module . exports = _ _webpack _exports _ _ ;
/******/
/******/ } ) ( )
;