2021-02-22 17:27:16 +07:00
/******/ ( ( ) => { // webpackBootstrap
/******/ var _ _webpack _modules _ _ = ( {
2021-04-26 16:42:09 +07:00
/***/ 88 :
2021-02-22 17:27:16 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-02-22 17:27:16 +07:00
2021-04-26 16:42:09 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2022-03-22 21:00:07 +07:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2021-04-26 16:42:09 +07:00
} ) : ( 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 ;
} ) ;
2021-02-22 17:27:16 +07:00
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
2021-04-26 16:42:09 +07:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
2021-02-22 17:27:16 +07:00
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-04-26 16:42:09 +07:00
exports . addINIValues = exports . addINIValuesWindows = exports . addINIValuesUnix = void 0 ;
const utils = _ _importStar ( _ _nccwpck _require _ _ ( 918 ) ) ;
async function addINIValuesUnix ( ini _values _csv ) {
const ini _values = await utils . CSVArray ( ini _values _csv ) ;
let script = '' ;
await utils . asyncForEach ( ini _values , async function ( line ) {
script +=
'\n' + ( await utils . addLog ( '$tick' , line , 'Added to php.ini' , 'linux' ) ) ;
} ) ;
return ( 'echo "' +
ini _values . join ( '\n' ) +
'" | sudo tee -a "${pecl_file:-${ini_file[@]}}" >/dev/null 2>&1' +
script ) ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
exports . addINIValuesUnix = addINIValuesUnix ;
async function addINIValuesWindows ( ini _values _csv ) {
const ini _values = await utils . CSVArray ( ini _values _csv ) ;
let script = '\n' ;
await utils . asyncForEach ( ini _values , async function ( line ) {
script +=
( await utils . addLog ( '$tick' , line , 'Added to php.ini' , 'win32' ) ) + '\n' ;
} ) ;
return ( 'Add-Content "$php_dir\\php.ini" "' + ini _values . join ( '\n' ) + '"' + script ) ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
exports . addINIValuesWindows = addINIValuesWindows ;
2022-01-29 06:59:58 +07:00
async function addINIValues ( ini _values _csv , os , no _step = false ) {
2021-04-26 16:42:09 +07:00
let script = '\n' ;
switch ( no _step ) {
case true :
script +=
2022-01-29 06:59:58 +07:00
( await utils . stepLog ( 'Add php.ini values' , os ) ) +
( await utils . suppressOutput ( os ) ) +
2021-04-26 16:42:09 +07:00
'\n' ;
break ;
case false :
default :
2022-01-29 06:59:58 +07:00
script += ( await utils . stepLog ( 'Add php.ini values' , os ) ) + '\n' ;
2021-04-26 16:42:09 +07:00
break ;
2021-02-22 17:27:16 +07:00
}
2022-01-29 06:59:58 +07:00
switch ( os ) {
2021-04-26 16:42:09 +07:00
case 'win32' :
return script + ( await addINIValuesWindows ( ini _values _csv ) ) ;
case 'darwin' :
case 'linux' :
return script + ( await addINIValuesUnix ( ini _values _csv ) ) ;
default :
2022-01-29 06:59:58 +07:00
return await utils . log ( 'Platform ' + os + ' is not supported' , os , 'error' ) ;
2021-02-22 17:27:16 +07:00
}
}
2021-04-26 16:42:09 +07:00
exports . addINIValues = addINIValues ;
2021-05-31 06:51:18 +07:00
//# sourceMappingURL=config.js.map
2021-02-22 17:27:16 +07:00
/***/ } ) ,
2019-11-24 06:44:53 +07:00
2022-08-17 18:35:01 +07:00
/***/ 5730 :
2021-02-22 17:27:16 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2019-12-10 06:52:33 +07:00
2021-11-26 01:45:10 +07:00
"use strict" ;
2019-12-10 06:52:33 +07:00
2021-04-26 16:42:09 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2022-03-22 21:00:07 +07:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2021-04-26 16:42:09 +07:00
} ) : ( 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 ;
} ) ;
2021-02-22 17:27:16 +07:00
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
2021-04-26 16:42:09 +07:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
2021-02-22 17:27:16 +07:00
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-11-26 01:37:28 +07:00
exports . addCoverage = exports . disableCoverage = exports . addCoveragePCOV = exports . addCoverageXdebug = exports . checkXdebugError = void 0 ;
2021-04-26 16:42:09 +07:00
const utils = _ _importStar ( _ _nccwpck _require _ _ ( 918 ) ) ;
2022-08-17 18:35:01 +07:00
const extensions = _ _importStar ( _ _nccwpck _require _ _ ( 3390 ) ) ;
2021-04-26 16:42:09 +07:00
const config = _ _importStar ( _ _nccwpck _require _ _ ( 88 ) ) ;
2021-11-26 01:37:28 +07:00
async function checkXdebugError ( extension , version ) {
if ( ( /^5\.[3-6]$|^7\.[0-1]$/ . test ( version ) && extension == 'xdebug3' ) ||
( /^8\.[0-9]$/ . test ( version ) && extension == 'xdebug2' ) ) {
return extension + ' is not supported on PHP ' + version ;
}
return '' ;
}
exports . checkXdebugError = checkXdebugError ;
2022-01-29 06:59:58 +07:00
async function addCoverageXdebug ( extension , version , os , pipe ) {
2021-04-26 16:42:09 +07:00
let script = '\n' ;
2023-01-18 10:30:28 +07:00
const error = await checkXdebugError ( extension , version ) ;
if ( ! error ) {
2021-11-26 01:37:28 +07:00
script +=
2022-01-29 06:59:58 +07:00
( await extensions . addExtension ( ':pcov:false' , version , os , true ) ) + pipe ;
2021-11-26 01:37:28 +07:00
extension = extension == 'xdebug3' ? 'xdebug' : extension ;
script +=
2022-01-29 06:59:58 +07:00
( await extensions . addExtension ( extension , version , os , true ) ) + pipe ;
2022-06-30 19:06:40 +07:00
script += await utils . setVariable ( 'xdebug_version' , 'php -r "echo phpversion(\'xdebug\');"' , os ) ;
2023-01-18 10:30:28 +07:00
script +=
( await utils . getCommand ( os , 'extension_log' ) ) +
'xdebug "Xdebug $xdebug_version enabled as coverage driver"' ;
}
else {
script += await utils . addLog ( '$cross' , extension , error , os ) ;
2021-11-26 01:37:28 +07:00
}
2021-04-26 16:42:09 +07:00
return script ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
exports . addCoverageXdebug = addCoverageXdebug ;
2022-01-29 06:59:58 +07:00
async function addCoveragePCOV ( version , os , pipe ) {
2021-04-26 16:42:09 +07:00
let script = '\n' ;
switch ( true ) {
default :
script +=
2022-01-29 06:59:58 +07:00
( await extensions . addExtension ( ':xdebug:false' , version , os , true ) ) +
2021-04-26 16:42:09 +07:00
pipe ;
script +=
2022-01-29 06:59:58 +07:00
( await extensions . addExtension ( 'pcov' , version , os , true ) ) + pipe ;
script += ( await config . addINIValues ( 'pcov.enabled=1' , os , true ) ) + '\n' ;
2022-06-30 19:06:40 +07:00
script += await utils . setVariable ( 'pcov_version' , 'php -r "echo phpversion(\'pcov\');"' , os ) ;
2023-01-18 10:30:28 +07:00
script +=
( await utils . getCommand ( os , 'extension_log' ) ) +
'pcov "PCOV $pcov_version enabled as coverage driver"' ;
2021-04-26 16:42:09 +07:00
break ;
case /5\.[3-6]|7\.0/ . test ( version ) :
2022-01-29 06:59:58 +07:00
script += await utils . addLog ( '$cross' , 'pcov' , 'PHP 7.1 or newer is required' , os ) ;
2021-04-26 16:42:09 +07:00
break ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
return script ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
exports . addCoveragePCOV = addCoveragePCOV ;
2022-01-29 06:59:58 +07:00
async function disableCoverage ( version , os , pipe ) {
2021-04-26 16:42:09 +07:00
let script = '\n' ;
script +=
2022-01-29 06:59:58 +07:00
( await extensions . addExtension ( ':pcov:false' , version , os , true ) ) + pipe ;
2021-08-25 21:06:40 +07:00
script +=
2022-01-29 06:59:58 +07:00
( await extensions . addExtension ( ':xdebug:false' , version , os , true ) ) + pipe ;
script += await utils . addLog ( '$tick' , 'none' , 'Disabled Xdebug and PCOV' , os ) ;
2021-04-26 16:42:09 +07:00
return script ;
2019-12-10 06:52:33 +07:00
}
2021-04-26 16:42:09 +07:00
exports . disableCoverage = disableCoverage ;
2022-01-29 06:59:58 +07:00
async function addCoverage ( coverage _driver , version , os ) {
2021-04-26 16:42:09 +07:00
coverage _driver = coverage _driver . toLowerCase ( ) ;
2022-01-29 06:59:58 +07:00
const script = '\n' + ( await utils . stepLog ( 'Setup Coverage' , os ) ) ;
const pipe = ( await utils . suppressOutput ( os ) ) + '\n' ;
2021-04-26 16:42:09 +07:00
switch ( coverage _driver ) {
case 'pcov' :
2022-01-29 06:59:58 +07:00
return script + ( await addCoveragePCOV ( version , os , pipe ) ) ;
2021-04-26 16:42:09 +07:00
case 'xdebug' :
case 'xdebug2' :
2021-11-26 01:37:28 +07:00
case 'xdebug3' :
2022-01-29 06:59:58 +07:00
return ( script + ( await addCoverageXdebug ( coverage _driver , version , os , pipe ) ) ) ;
2021-04-26 16:42:09 +07:00
case 'none' :
2022-01-29 06:59:58 +07:00
return script + ( await disableCoverage ( version , os , pipe ) ) ;
2021-04-26 16:42:09 +07:00
default :
return '' ;
2021-02-22 17:27:16 +07:00
}
}
2021-04-26 16:42:09 +07:00
exports . addCoverage = addCoverage ;
2021-05-31 06:51:18 +07:00
//# sourceMappingURL=coverage.js.map
2021-02-22 17:27:16 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 3390 :
2021-02-22 17:27:16 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-02-22 17:27:16 +07:00
2021-04-26 16:42:09 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2022-03-22 21:00:07 +07:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2021-04-26 16:42:09 +07:00
} ) : ( 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 ;
} ) ;
2021-02-22 17:27:16 +07:00
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
2021-04-26 16:42:09 +07:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
2021-02-22 17:27:16 +07:00
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-04-26 16:42:09 +07:00
exports . addExtension = exports . addExtensionLinux = exports . addExtensionWindows = exports . addExtensionDarwin = void 0 ;
const utils = _ _importStar ( _ _nccwpck _require _ _ ( 918 ) ) ;
async function addExtensionDarwin ( extension _csv , version ) {
const extensions = await utils . extensionArray ( extension _csv ) ;
let add _script = '\n' ;
let remove _script = '' ;
await utils . asyncForEach ( extensions , async function ( extension ) {
const version _extension = version + extension ;
const [ ext _name , ext _version ] = extension . split ( '-' ) ;
const ext _prefix = await utils . getExtensionPrefix ( ext _name ) ;
switch ( true ) {
case /^:/ . test ( ext _name ) :
2021-08-25 21:06:40 +07:00
remove _script += '\ndisable_extension' + ext _name . replace ( /:/g , ' ' ) ;
2021-04-26 16:42:09 +07:00
return ;
2021-08-26 22:59:38 +07:00
case /^none$/ . test ( ext _name ) :
add _script += '\ndisable_all_shared' ;
return ;
2021-04-26 16:42:09 +07:00
case /.+-.+\/.+@.+/ . test ( extension ) :
add _script += await utils . parseExtensionSource ( extension , ext _prefix ) ;
return ;
2023-03-31 02:53:49 +07:00
case /^(7\.4|8\.[0-3])relay(-v?\d+\.\d+\.\d+)?$/ . test ( version _extension ) :
2022-12-08 21:28:40 +07:00
case /^(5\.[3-6]|7\.[0-4]|8\.[0-2])blackfire(-\d+\.\d+\.\d+)?$/ . test ( version _extension ) :
2022-11-14 16:47:12 +07:00
case /^couchbase|^event|^gearman$|^geos$|^pdo_oci$|^oci8$|^(pecl_)?http|^pdo_firebird$/ . test ( extension ) :
2021-04-26 16:42:09 +07:00
case /^(5\.[3-6]|7\.[0-4])ioncube$/ . test ( version _extension ) :
2022-07-16 02:16:28 +07:00
case /(5\.6|7\.[0-3])phalcon3|7\.[2-4]phalcon4|(7\.4|8\.[0-2])phalcon5/ . test ( version _extension ) :
2022-01-31 19:07:26 +07:00
case /(?<!5\.[3-6])(pdo_)?sqlsrv$/ . test ( version _extension ) :
2023-01-22 03:34:12 +07:00
case /^(7\.[0-4]|8\.[0-2])zephir_parser(-v?\d+\.\d+\.\d+)?$/ . test ( version _extension ) :
2022-01-02 18:51:14 +07:00
add _script += await utils . customPackage ( ext _name , 'extensions' , extension , 'darwin' ) ;
2021-04-26 16:42:09 +07:00
return ;
case /.+-(stable|beta|alpha|devel|snapshot|rc|preview)/ . test ( extension ) :
add _script += await utils . joins ( '\nadd_unstable_extension' , ext _name , ext _version , ext _prefix ) ;
return ;
2023-05-24 17:26:18 +07:00
case /.+-\d+(\.\d+\.\d+.*)?/ . test ( extension ) :
2021-04-26 16:42:09 +07:00
add _script += await utils . joins ( '\nadd_pecl_extension' , ext _name , ext _version , ext _prefix ) ;
return ;
case /(5\.[3-6]|7\.0)pcov/ . test ( version _extension ) :
add _script += await utils . getUnsupportedLog ( 'pcov' , version , 'darwin' ) ;
return ;
2023-02-08 22:14:10 +07:00
case /(?<!5\.[3-5])(amqp|apcu|expect|gnupg|grpc|igbinary|imagick|imap|mailparse|mcrypt|memcache|memcached|mongodb|msgpack|protobuf|psr|raphf|rdkafka|redis|snmp|ssh2|swoole|uuid|xdebug|xdebug2|yaml|zmq)/ . test ( version _extension ) :
2022-11-14 16:47:12 +07:00
case /(?<!5\.[3-6])(ds|v8js)/ . test ( version _extension ) :
case /(5\.6|7\.[0-4])(propro|lua)/ . test ( version _extension ) :
2021-04-26 16:42:09 +07:00
case /(?<!5\.[3-6]|7\.0)pcov/ . test ( version _extension ) :
2022-08-10 14:49:47 +07:00
case /(?<!5\.[3-6])(ast|vips|xlswriter)/ . test ( version _extension ) :
2021-04-26 16:42:09 +07:00
add _script += await utils . joins ( '\nadd_brew_extension' , ext _name , ext _prefix ) ;
return ;
case /^sqlite$/ . test ( extension ) :
extension = 'sqlite3' ;
break ;
default :
break ;
2019-12-10 06:52:33 +07:00
}
2021-04-26 16:42:09 +07:00
add _script += await utils . joins ( '\nadd_extension' , extension , ext _prefix ) ;
2019-12-10 06:52:33 +07:00
} ) ;
2021-04-26 16:42:09 +07:00
return add _script + remove _script ;
2019-12-10 06:52:33 +07:00
}
2021-04-26 16:42:09 +07:00
exports . addExtensionDarwin = addExtensionDarwin ;
async function addExtensionWindows ( extension _csv , version ) {
const extensions = await utils . extensionArray ( extension _csv ) ;
let add _script = '\n' ;
let remove _script = '' ;
await utils . asyncForEach ( extensions , async function ( extension ) {
const [ ext _name , ext _version ] = extension . split ( '-' ) ;
const version _extension = version + extension ;
let matches ;
switch ( true ) {
case /^:/ . test ( ext _name ) :
2021-08-25 21:06:40 +07:00
remove _script += '\nDisable-Extension' + ext _name . replace ( /:/g , ' ' ) ;
2021-04-26 16:42:09 +07:00
break ;
2021-08-26 22:59:38 +07:00
case /^none$/ . test ( ext _name ) :
add _script += '\nDisable-AllShared' ;
break ;
2022-12-25 22:44:03 +07:00
case /^(5\.[3-6]|7\.[0-4]|8\.[0-2])blackfire(-\d+\.\d+\.\d+)?$/ . test ( version _extension ) :
2021-04-26 16:42:09 +07:00
case /^pdo_oci$|^oci8$|^pdo_firebird$/ . test ( extension ) :
case /^(5\.[3-6]|7\.[0-4])ioncube$/ . test ( version _extension ) :
2022-07-19 15:56:08 +07:00
case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$|^(7\.4|8\.[0-2])phalcon5$/ . test ( version _extension ) :
2022-03-15 13:43:17 +07:00
case /^(7\.[1-4]|8\.1)(pecl_)?http/ . test ( version _extension ) :
2023-01-22 03:34:12 +07:00
case /^(7\.[0-4]|8\.[0-2])zephir_parser(-v?\d+\.\d+\.\d+)?$/ . test ( version _extension ) :
2022-01-02 18:51:14 +07:00
add _script += await utils . customPackage ( ext _name , 'extensions' , extension , 'win32' ) ;
2021-04-26 16:42:09 +07:00
return ;
case /.+-(stable|beta|alpha|devel|snapshot)/ . test ( extension ) :
add _script += await utils . joins ( '\nAdd-Extension' , ext _name , ext _version . replace ( 'stable' , '' ) ) ;
break ;
case /.+-.+\/.+@.+/ . test ( extension ) :
add _script += await utils . getUnsupportedLog ( extension , version , 'win32' ) ;
break ;
case /.+-\d+\.\d+\.\d+[a-zA-Z]+\d*/ . test ( extension ) :
matches = /.+-(\d+\.\d+\.\d+)([a-zA-Z]+)\d*/ . exec ( version _extension ) ;
add _script += await utils . joins ( '\nAdd-Extension' , ext _name , matches [ 2 ] . replace ( 'preview' , 'devel' ) , matches [ 1 ] ) ;
break ;
2023-05-24 17:26:18 +07:00
case /.+-\d+(\.\d+\.\d+.*)?/ . test ( extension ) :
add _script += await utils . joins ( '\nAdd-Extension' , ext _name , 'stable' , ext _version ) ;
break ;
2021-04-26 16:42:09 +07:00
case /7\.[2-4]xdebug2/ . test ( version _extension ) :
add _script += '\nAdd-Extension xdebug stable 2.9.8' ;
break ;
case /(5\.[3-6]|7\.0)pcov/ . test ( version _extension ) :
add _script += await utils . getUnsupportedLog ( 'pcov' , version , 'win32' ) ;
break ;
2021-04-27 16:47:29 +07:00
case /^5\.[3-6](?<!pdo_)(mysql|mysqli|mysqlnd)$/ . test ( version _extension ) :
2021-04-26 16:42:09 +07:00
add _script +=
'\nAdd-Extension mysql\nAdd-Extension mysqli\nAdd-Extension mysqlnd' ;
break ;
2021-04-27 16:47:29 +07:00
case /(?<!5\.[3-6])(?<!pdo_)(mysql|mysqli|mysqlnd)$/ . test ( version _extension ) :
2021-04-26 16:42:09 +07:00
add _script += '\nAdd-Extension mysqli\nAdd-Extension mysqlnd' ;
break ;
case /^sqlite$/ . test ( extension ) :
extension = 'sqlite3' ;
add _script += await utils . joins ( '\nAdd-Extension' , extension ) ;
break ;
default :
add _script += '\nAdd-Extension ' + extension ;
break ;
}
} ) ;
return add _script + remove _script ;
}
exports . addExtensionWindows = addExtensionWindows ;
async function addExtensionLinux ( extension _csv , version ) {
const extensions = await utils . extensionArray ( extension _csv ) ;
let add _script = '\n' ;
let remove _script = '' ;
await utils . asyncForEach ( extensions , async function ( extension ) {
const version _extension = version + extension ;
2021-12-08 06:26:29 +07:00
const [ ext _name , ext _version ] = extension
. split ( /-(.+)/ )
. filter ( Boolean ) ;
2021-04-26 16:42:09 +07:00
const ext _prefix = await utils . getExtensionPrefix ( ext _name ) ;
switch ( true ) {
case /^:/ . test ( ext _name ) :
2021-08-25 21:06:40 +07:00
remove _script += '\ndisable_extension' + ext _name . replace ( /:/g , ' ' ) ;
2021-04-26 16:42:09 +07:00
return ;
2021-08-26 22:59:38 +07:00
case /^none$/ . test ( ext _name ) :
add _script += '\ndisable_all_shared' ;
return ;
2021-04-26 16:42:09 +07:00
case /.+-.+\/.+@.+/ . test ( extension ) :
add _script += await utils . parseExtensionSource ( extension , ext _prefix ) ;
return ;
2023-03-31 02:53:49 +07:00
case /^(7\.4|8\.[0-3])relay(-v?\d+\.\d+\.\d+)?$/ . test ( version _extension ) :
2022-12-08 21:28:40 +07:00
case /^(5\.[3-6]|7\.[0-4]|8\.[0-2])blackfire(-\d+\.\d+\.\d+)?$/ . test ( version _extension ) :
2021-04-26 16:42:09 +07:00
case /^((5\.[3-6])|(7\.[0-2]))pdo_cubrid$|^((5\.[3-6])|(7\.[0-4]))cubrid$/ . test ( version _extension ) :
2022-07-05 17:52:07 +07:00
case /^couchbase|^event|^gearman$|^geos$|^pdo_oci$|^oci8$|^(pecl_)?http|^pdo_firebird$/ . test ( extension ) :
2022-11-14 16:47:12 +07:00
case /(?<!5\.[3-5])intl-\d+\.\d+$/ . test ( version _extension ) :
2021-04-26 16:42:09 +07:00
case /^(5\.[3-6]|7\.[0-4])ioncube$/ . test ( version _extension ) :
2022-07-16 02:16:28 +07:00
case /^7\.[0-3]phalcon3$|^7\.[2-4]phalcon4$|^(7\.4|8\.[0-2])phalcon5$/ . test ( version _extension ) :
2022-01-31 19:07:26 +07:00
case /(?<!5\.[3-6])(pdo_)?sqlsrv$/ . test ( version _extension ) :
2023-01-22 03:34:12 +07:00
case /^(7\.[0-4]|8\.[0-2])zephir_parser(-v?\d+\.\d+\.\d+)?$/ . test ( version _extension ) :
2022-01-02 18:51:14 +07:00
add _script += await utils . customPackage ( ext _name , 'extensions' , extension , 'linux' ) ;
2021-04-26 16:42:09 +07:00
return ;
case /.+-(stable|beta|alpha|devel|snapshot|rc|preview)/ . test ( extension ) :
add _script += await utils . joins ( '\nadd_unstable_extension' , ext _name , ext _version , ext _prefix ) ;
return ;
2023-05-24 17:26:18 +07:00
case /.+-\d+(\.\d+\.\d+.*)?/ . test ( extension ) :
2021-04-26 16:42:09 +07:00
add _script += await utils . joins ( '\nadd_pecl_extension' , ext _name , ext _version , ext _prefix ) ;
return ;
case /(5\.[3-6]|7\.0)pcov/ . test ( version _extension ) :
add _script += await utils . getUnsupportedLog ( 'pcov' , version , 'linux' ) ;
return ;
case /^7\.[2-4]xdebug2$/ . test ( version _extension ) :
add _script += await utils . joins ( '\nadd_pecl_extension' , 'xdebug' , '2.9.8' , ext _prefix ) ;
return ;
case /^pdo[_-].+/ . test ( extension ) :
extension = extension . replace ( /pdo[_-]|3/ , '' ) ;
add _script += '\nadd_pdo_extension ' + extension ;
return ;
case /^sqlite$/ . test ( extension ) :
extension = 'sqlite3' ;
break ;
default :
break ;
}
add _script += await utils . joins ( '\nadd_extension' , extension , ext _prefix ) ;
} ) ;
return add _script + remove _script ;
}
exports . addExtensionLinux = addExtensionLinux ;
2022-01-29 06:59:58 +07:00
async function addExtension ( extension _csv , version , os , no _step = false ) {
const log = await utils . stepLog ( 'Setup Extensions' , os ) ;
2021-04-26 16:42:09 +07:00
let script = '\n' ;
switch ( no _step ) {
case true :
2022-01-29 06:59:58 +07:00
script += log + ( await utils . suppressOutput ( os ) ) ;
2021-04-26 16:42:09 +07:00
break ;
case false :
default :
script += log ;
break ;
}
2022-01-29 06:59:58 +07:00
switch ( os ) {
2021-04-26 16:42:09 +07:00
case 'win32' :
return script + ( await addExtensionWindows ( extension _csv , version ) ) ;
case 'darwin' :
return script + ( await addExtensionDarwin ( extension _csv , version ) ) ;
case 'linux' :
return script + ( await addExtensionLinux ( extension _csv , version ) ) ;
default :
2022-01-29 06:59:58 +07:00
return await utils . log ( 'Platform ' + os + ' is not supported' , os , 'error' ) ;
2021-04-26 16:42:09 +07:00
}
}
exports . addExtension = addExtension ;
2021-05-31 06:51:18 +07:00
//# sourceMappingURL=extensions.js.map
2019-12-10 06:52:33 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 2387 :
2022-02-05 13:11:01 +07:00
/***/ ( 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 ;
2022-03-22 21:00:07 +07:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2022-02-05 13:11:01 +07:00
} ) : ( 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 . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . fetch = void 0 ;
2022-08-17 18:35:01 +07:00
const https = _ _importStar ( _ _nccwpck _require _ _ ( 5687 ) ) ;
const url = _ _importStar ( _ _nccwpck _require _ _ ( 7310 ) ) ;
2022-02-05 13:11:01 +07:00
async function fetch ( input _url , auth _token , redirect _count = 5 ) {
const fetch _promise = new Promise ( resolve => {
const url _object = new url . URL ( input _url ) ;
const headers = {
'User-Agent' : ` Mozilla/5.0 ( ${ process . platform } ${ process . arch } ) setup-php `
} ;
if ( auth _token ) {
headers . authorization = 'Bearer ' + auth _token ;
}
const options = {
hostname : url _object . hostname ,
path : url _object . pathname ,
headers : headers
} ;
const req = https . get ( options , ( res ) => {
if ( res . statusCode === 200 ) {
let body = '' ;
res . setEncoding ( 'utf8' ) ;
res . on ( 'data' , chunk => ( body += chunk ) ) ;
res . on ( 'end' , ( ) => resolve ( { data : ` ${ body } ` } ) ) ;
}
else if ( [ 301 , 302 , 303 , 307 , 308 ] . includes ( res . statusCode ) ) {
if ( redirect _count > 0 && res . headers . location ) {
fetch ( res . headers . location , auth _token , redirect _count -- ) . then ( resolve ) ;
}
else {
resolve ( { error : ` ${ res . statusCode } : Redirect error ` } ) ;
}
}
else {
resolve ( { error : ` ${ res . statusCode } : ${ res . statusMessage } ` } ) ;
}
} ) ;
req . end ( ) ;
} ) ;
return await fetch _promise ;
}
exports . fetch = fetch ;
//# sourceMappingURL=fetch.js.map
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 9039 :
2021-02-22 17:27:16 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2019-11-24 06:44:53 +07:00
2021-11-26 01:45:10 +07:00
"use strict" ;
2019-11-24 06:44:53 +07:00
2021-04-26 16:42:09 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2022-03-22 21:00:07 +07:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2021-04-26 16:42:09 +07:00
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
2020-05-07 04:57:00 +07:00
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
2021-04-26 16:42:09 +07:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
2020-05-07 04:57:00 +07:00
return result ;
} ;
2022-01-29 06:10:49 +07:00
var _ _importDefault = ( this && this . _ _importDefault ) || function ( mod ) {
return ( mod && mod . _ _esModule ) ? mod : { "default" : mod } ;
} ;
2021-02-22 17:27:16 +07:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-04-26 16:42:09 +07:00
exports . run = exports . getScript = void 0 ;
2022-08-17 18:35:01 +07:00
const path _1 = _ _importDefault ( _ _nccwpck _require _ _ ( 1017 ) ) ;
const fs _1 = _ _importDefault ( _ _nccwpck _require _ _ ( 7147 ) ) ;
const exec _1 = _ _nccwpck _require _ _ ( 1514 ) ;
const core = _ _importStar ( _ _nccwpck _require _ _ ( 2186 ) ) ;
2021-04-26 16:42:09 +07:00
const config = _ _importStar ( _ _nccwpck _require _ _ ( 88 ) ) ;
2022-08-17 18:35:01 +07:00
const coverage = _ _importStar ( _ _nccwpck _require _ _ ( 5730 ) ) ;
const extensions = _ _importStar ( _ _nccwpck _require _ _ ( 3390 ) ) ;
const tools = _ _importStar ( _ _nccwpck _require _ _ ( 7740 ) ) ;
2021-04-26 16:42:09 +07:00
const utils = _ _importStar ( _ _nccwpck _require _ _ ( 918 ) ) ;
2022-01-30 10:15:11 +07:00
async function getScript ( os ) {
2022-03-22 19:03:49 +07:00
const url = 'https://setup-php.com/support-ukraine' ;
2022-01-30 10:15:11 +07:00
const filename = os + ( await utils . scriptExtension ( os ) ) ;
const script _path = path _1 . default . join ( _ _dirname , '../src/scripts' , filename ) ;
const run _path = script _path . replace ( os , 'run' ) ;
2021-04-26 16:42:09 +07:00
process . env [ 'fail_fast' ] = await utils . getInput ( 'fail-fast' , false ) ;
const extension _csv = await utils . getInput ( 'extensions' , false ) ;
const ini _values _csv = await utils . getInput ( 'ini-values' , false ) ;
const coverage _driver = await utils . getInput ( 'coverage' , false ) ;
const tools _csv = await utils . getInput ( 'tools' , false ) ;
2023-04-02 22:00:40 +07:00
const version = await utils . parseVersion ( await utils . readPHPVersion ( ) ) ;
2022-01-30 10:15:11 +07:00
const ini _file = await utils . parseIniFile ( await utils . getInput ( 'ini-file' , false ) ) ;
let script = await utils . joins ( '.' , script _path , version , ini _file ) ;
2021-04-26 16:42:09 +07:00
if ( extension _csv ) {
2022-01-29 06:59:58 +07:00
script += await extensions . addExtension ( extension _csv , version , os ) ;
2021-04-26 16:42:09 +07:00
}
2022-01-29 06:59:58 +07:00
script += await tools . addTools ( tools _csv , version , os ) ;
2021-04-26 16:42:09 +07:00
if ( coverage _driver ) {
2022-01-29 06:59:58 +07:00
script += await coverage . addCoverage ( coverage _driver , version , os ) ;
2021-04-26 16:42:09 +07:00
}
if ( ini _values _csv ) {
2022-01-29 06:59:58 +07:00
script += await config . addINIValues ( ini _values _csv , os ) ;
2021-04-26 16:42:09 +07:00
}
2022-03-22 19:03:49 +07:00
script += '\n' + ( await utils . stepLog ( ` #StandWithUkraine ` , os ) ) ;
script += '\n' + ( await utils . addLog ( '$tick' , 'read-more' , url , os ) ) ;
2022-01-30 10:15:11 +07:00
fs _1 . default . writeFileSync ( run _path , script , { mode : 0o755 } ) ;
return run _path ;
2021-04-26 16:42:09 +07:00
}
exports . getScript = getScript ;
async function run ( ) {
2022-01-30 10:15:11 +07:00
const os = process . platform ;
const tool = await utils . scriptTool ( os ) ;
const run _path = await getScript ( os ) ;
await ( 0 , exec _1 . exec ) ( tool + run _path ) ;
2021-04-26 16:42:09 +07:00
}
exports . run = run ;
( async ( ) => {
await run ( ) ;
} ) ( ) . catch ( error => {
core . setFailed ( error . message ) ;
} ) ;
2021-05-31 06:51:18 +07:00
//# sourceMappingURL=install.js.map
2021-04-26 16:42:09 +07:00
/***/ } ) ,
2023-06-12 12:25:01 +07:00
/***/ 5151 :
/***/ ( 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 ;
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
} ) : ( 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 . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . search = void 0 ;
const cv = _ _importStar ( _ _nccwpck _require _ _ ( 4773 ) ) ;
const fetch = _ _importStar ( _ _nccwpck _require _ _ ( 2387 ) ) ;
async function search ( package _name , php _version ) {
const response = await fetch . fetch ( ` https://repo.packagist.org/p2/ ${ package _name } .json ` ) ;
if ( response . error || response . data === '[]' ) {
return null ;
}
const data = JSON . parse ( response [ 'data' ] ) ;
if ( data && data . packages ) {
const versions = data . packages [ package _name ] ;
versions . sort ( ( a , b ) => cv . compareVersions ( b . version , a . version ) ) ;
const result = versions . find ( ( versionData ) => {
if ( versionData ? . require ? . php ) {
return versionData ? . require ? . php
. split ( '|' )
. some ( require => require && cv . satisfies ( php _version + '.0' , require ) ) ;
}
return false ;
} ) ;
return result ? result . version : null ;
}
return null ;
}
exports . search = search ;
//# sourceMappingURL=packagist.js.map
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 7740 :
2021-04-26 16:42:09 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-04-26 16:42:09 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2022-03-22 21:00:07 +07:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2021-04-26 16:42:09 +07:00
} ) : ( 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 . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
2022-01-29 06:10:49 +07:00
var _ _importDefault = ( this && this . _ _importDefault ) || function ( mod ) {
return ( mod && mod . _ _esModule ) ? mod : { "default" : mod } ;
} ;
2021-04-26 16:42:09 +07:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2023-06-23 21:13:17 +07:00
exports . addTools = exports . functionRecord = exports . getData = exports . addWPCLI = exports . addPHPUnitTools = exports . addPhive = exports . addPhing = exports . addPECL = exports . addDevTools = exports . addDeployer = exports . addComposer = exports . addCastor = exports . addBlackfirePlayer = exports . addPackage = exports . addArchive = exports . getPharUrl = exports . getUrl = exports . filterList = exports . getRelease = exports . getVersion = exports . getLatestVersion = exports . getSemverVersion = void 0 ;
2022-08-17 18:35:01 +07:00
const path _1 = _ _importDefault ( _ _nccwpck _require _ _ ( 1017 ) ) ;
const fs _1 = _ _importDefault ( _ _nccwpck _require _ _ ( 7147 ) ) ;
const fetch = _ _importStar ( _ _nccwpck _require _ _ ( 2387 ) ) ;
2023-06-12 12:25:01 +07:00
const packagist = _ _importStar ( _ _nccwpck _require _ _ ( 5151 ) ) ;
2022-02-05 13:11:01 +07:00
const utils = _ _importStar ( _ _nccwpck _require _ _ ( 918 ) ) ;
2021-07-12 18:30:40 +07:00
async function getSemverVersion ( data ) {
const search = data [ 'version_prefix' ] + data [ 'version' ] ;
const url = ` https://api.github.com/repos/ ${ data [ 'repository' ] } /git/matching-refs/tags%2F ${ search } . ` ;
2022-07-06 13:49:55 +07:00
let github _token = await utils . readEnv ( 'GITHUB_TOKEN' ) ;
const composer _token = await utils . readEnv ( 'COMPOSER_TOKEN' ) ;
if ( composer _token && ! github _token ) {
github _token = composer _token ;
}
const response = await fetch . fetch ( url , github _token ) ;
2021-07-09 12:56:38 +07:00
if ( response . error || response . data === '[]' ) {
2022-05-30 08:57:29 +07:00
data [ 'error' ] = response . error ? ? ` No version found with prefix ${ search } . ` ;
2021-07-09 12:56:38 +07:00
return data [ 'version' ] ;
}
else {
2021-07-12 18:30:40 +07:00
const refs = JSON . parse ( response [ 'data' ] ) . reverse ( ) ;
const ref = refs . find ( ( i ) => / . * \ d + . \ d + . \ d + $ / . test ( i [ 'ref' ] ) ) ;
const tag = ( ref || refs [ 0 ] ) [ 'ref' ] . split ( '/' ) . pop ( ) ;
2021-07-10 03:40:33 +07:00
return tag . replace ( /^v(\d)/ , '$1' ) ;
2021-07-09 12:56:38 +07:00
}
2021-07-05 17:42:58 +07:00
}
2021-07-12 18:30:40 +07:00
exports . getSemverVersion = getSemverVersion ;
2021-08-20 10:44:39 +07:00
async function getLatestVersion ( data ) {
if ( ! data [ 'version' ] && data [ 'fetch_latest' ] === 'false' ) {
return 'latest' ;
}
2022-02-05 13:11:01 +07:00
const resp = await fetch . fetch ( ` ${ data [ 'github' ] } / ${ data [ 'repository' ] } /releases.atom ` ) ;
2022-01-27 10:14:53 +07:00
if ( resp [ 'data' ] ) {
const releases = [
... resp [ 'data' ] . matchAll ( /releases\/tag\/([a-zA-Z]*)?(\d+.\d+.\d+)"/g )
] . map ( match => match [ 2 ] ) ;
return ( releases
. sort ( ( a , b ) => a . localeCompare ( b , undefined , { numeric : true } ) )
. pop ( ) || 'latest' ) ;
}
return 'latest' ;
2021-08-20 10:44:39 +07:00
}
exports . getLatestVersion = getLatestVersion ;
2021-07-12 18:30:40 +07:00
async function getVersion ( version , data ) {
2021-04-26 16:42:09 +07:00
const semver _regex = /^(0|[1-9]\d*)\.(0|[1-9]\d*)\.(0|[1-9]\d*)(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$/ ;
2021-07-12 18:30:40 +07:00
const composer _regex = /^composer:(stable|preview|snapshot|[1|2])$/ ;
const constraint _regex = /[><=^~]+.*/ ;
const major _minor _regex = /^\d+(\.\d+)?$/ ;
data [ 'version' ] = version . replace ( /v?(\d)/ , '$1' ) . replace ( /\.x/ , '' ) ;
2021-04-26 16:42:09 +07:00
switch ( true ) {
2021-07-12 18:30:40 +07:00
case composer _regex . test ( data [ 'release' ] ) :
case semver _regex . test ( data [ 'version' ] ) :
case constraint _regex . test ( data [ 'version' ] ) && data [ 'type' ] === 'composer' :
return data [ 'version' ] ;
case major _minor _regex . test ( data [ 'version' ] ) && data [ 'type' ] === 'composer' :
data [ 'release' ] = ` ${ data [ 'tool' ] } : ${ data [ 'version' ] } .* ` ;
return ` ${ data [ 'version' ] } .* ` ;
case data [ 'repository' ] && major _minor _regex . test ( data [ 'version' ] ) :
return await getSemverVersion ( data ) ;
2021-04-26 16:42:09 +07:00
default :
2021-07-12 18:30:40 +07:00
return data [ 'version' ] . replace ( /[><=^~]*/ , '' ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
}
2021-07-12 18:30:40 +07:00
exports . getVersion = getVersion ;
async function getRelease ( release , data ) {
release = release . includes ( '/' ) ? release . split ( '/' ) [ 1 ] : release ;
return release . includes ( ':' )
2021-07-05 17:33:10 +07:00
? [ data [ 'tool' ] , release . split ( ':' ) [ 1 ] ] . join ( ':' )
: data [ 'tool' ] ;
2021-04-26 16:42:09 +07:00
}
2021-07-12 18:30:40 +07:00
exports . getRelease = getRelease ;
2021-07-05 17:33:10 +07:00
async function filterList ( tools _list ) {
const regex _any = /^composer($|:.*)/ ;
2021-07-12 18:30:40 +07:00
const regex _valid = /^composer:?($|preview$|snapshot$|v?\d+(\.\d+)?$|v?\d+\.\d+\.\d+[\w-]*$)/ ;
2021-07-05 17:33:10 +07:00
const matches = tools _list . filter ( tool => regex _valid . test ( tool ) ) ;
let composer = 'composer' ;
tools _list = tools _list . filter ( tool => ! regex _any . test ( tool ) ) ;
2021-04-26 16:42:09 +07:00
switch ( true ) {
2021-07-05 17:33:10 +07:00
case matches [ 0 ] == undefined :
2021-04-26 16:42:09 +07:00
break ;
default :
2021-07-05 17:33:10 +07:00
composer = matches [ matches . length - 1 ] . replace ( /v(\d\S*)/ , '$1' ) ;
break ;
2019-11-24 06:44:53 +07:00
}
2021-07-05 17:33:10 +07:00
tools _list . unshift ( composer ) ;
return tools _list ;
2021-04-26 16:42:09 +07:00
}
2021-07-05 17:33:10 +07:00
exports . filterList = filterList ;
async function getUrl ( data ) {
if ( data [ 'version' ] === 'latest' ) {
return [
data [ 'domain' ] ,
data [ 'repository' ] ,
data [ 'prefix' ] ,
data [ 'version' ] ,
data [ 'verb' ] ,
data [ 'tool' ] + data [ 'extension' ]
]
. filter ( Boolean )
. join ( '/' ) ;
}
else {
return [
data [ 'domain' ] ,
data [ 'repository' ] ,
data [ 'prefix' ] ,
data [ 'verb' ] ,
data [ 'version_prefix' ] + data [ 'version' ] ,
data [ 'tool' ] + data [ 'extension' ]
]
. filter ( Boolean )
. join ( '/' ) ;
}
}
exports . getUrl = getUrl ;
async function getPharUrl ( data ) {
if ( data [ 'version' ] === 'latest' ) {
return data [ 'domain' ] + '/' + data [ 'tool' ] + '.phar' ;
}
else {
return ( data [ 'domain' ] +
'/' +
data [ 'tool' ] +
'-' +
data [ 'version_prefix' ] +
data [ 'version' ] +
'.phar' ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
}
exports . getPharUrl = getPharUrl ;
2021-07-05 17:33:10 +07:00
async function addArchive ( data ) {
2022-01-29 06:59:58 +07:00
return ( ( await utils . getCommand ( data [ 'os' ] , 'tool' ) ) +
2021-07-05 17:33:10 +07:00
( await utils . joins ( data [ 'url' ] , data [ 'tool' ] , data [ 'version_parameter' ] ) ) ) ;
}
exports . addArchive = addArchive ;
async function addPackage ( data ) {
2023-01-18 10:30:28 +07:00
const command = await utils . getCommand ( data [ 'os' ] , 'composer_tool' ) ;
2021-07-05 17:33:10 +07:00
const parts = data [ 'repository' ] . split ( '/' ) ;
2021-12-31 01:33:15 +07:00
const args = await utils . joins ( parts [ 1 ] , data [ 'release' ] , parts [ 0 ] + '/' , data [ 'scope' ] ) ;
return command + args ;
2021-07-05 17:33:10 +07:00
}
exports . addPackage = addPackage ;
async function addBlackfirePlayer ( data ) {
2023-01-17 06:41:26 +07:00
if ( data [ 'version' ] == 'latest' ) {
if ( /5\.[5-6]|7\.0/ . test ( data [ 'php_version' ] ) ) {
data [ 'version' ] = '1.9.3' ;
}
else if ( /7\.[1-4]|8\.0/ . test ( data [ 'php_version' ] ) ) {
data [ 'version' ] = '1.22.0' ;
}
2021-07-05 17:33:10 +07:00
}
data [ 'url' ] = await getPharUrl ( data ) ;
return addArchive ( data ) ;
}
exports . addBlackfirePlayer = addBlackfirePlayer ;
2023-06-23 21:13:17 +07:00
async function addCastor ( data ) {
2023-06-24 00:58:05 +07:00
data [ 'tool' ] = 'castor.' + data [ 'os' ] . replace ( 'win32' , 'windows' ) + '-amd64' ;
data [ 'url' ] = await getUrl ( data ) ;
data [ 'tool' ] = 'castor' ;
2023-06-24 03:55:43 +07:00
data [ 'version_parameter' ] = fs _1 . default . existsSync ( 'castor.php' )
? data [ 'version_parameter' ]
: '' ;
2023-06-23 21:13:17 +07:00
return await addArchive ( data ) ;
}
exports . addCastor = addCastor ;
2021-07-05 17:33:10 +07:00
async function addComposer ( data ) {
2022-04-23 13:25:11 +07:00
const channel = data [ 'version' ] . replace ( 'latest' , 'stable' ) ;
2021-07-05 17:33:10 +07:00
const github = data [ 'github' ] ;
const getcomposer = data [ 'domain' ] ;
2022-04-23 13:25:11 +07:00
const cds = 'https://dl.cloudsmith.io' ;
const filename = ` composer- ${ data [ 'php_version' ] } - ${ channel } .phar ` ;
const releases _url = ` ${ github } /shivammathur/composer-cache/releases/latest/download/ ${ filename } ` ;
const cds _url = ` ${ cds } /public/shivammathur/composer-cache/raw/files/ ${ filename } ` ;
const lts _url = ` ${ getcomposer } /download/latest-2.2.x/composer.phar ` ;
const is _lts = /^5\.[3-6]$|^7\.[0-1]$/ . test ( data [ 'php_version' ] ) ;
const version _source _url = ` ${ getcomposer } /composer- ${ channel } .phar ` ;
let cache _url = ` ${ releases _url } , ${ cds _url } ` ;
2021-07-05 17:33:10 +07:00
let source _url = ` ${ getcomposer } /composer.phar ` ;
2021-04-26 16:42:09 +07:00
switch ( true ) {
2022-04-23 13:25:11 +07:00
case /^snapshot$/ . test ( channel ) :
source _url = is _lts ? lts _url : source _url ;
2021-04-26 16:42:09 +07:00
break ;
2022-04-23 13:25:11 +07:00
case /^preview$|^2$/ . test ( channel ) :
source _url = is _lts ? lts _url : version _source _url ;
break ;
case /^1$/ . test ( channel ) :
source _url = version _source _url ;
2021-07-05 17:33:10 +07:00
break ;
case /^\d+\.\d+\.\d+[\w-]*$/ . test ( data [ 'version' ] ) :
cache _url = ` ${ github } / ${ data [ 'repository' ] } /releases/download/ ${ data [ 'version' ] } /composer.phar ` ;
2022-04-23 13:25:11 +07:00
source _url = version _source _url ;
2021-04-26 16:42:09 +07:00
break ;
2021-07-05 17:33:10 +07:00
default :
2022-04-23 13:25:11 +07:00
source _url = is _lts ? lts _url : version _source _url ;
2019-11-24 06:44:53 +07:00
}
2021-07-23 15:29:16 +07:00
const use _cache = ( await utils . readEnv ( 'NO_TOOLS_CACHE' ) ) !== 'true' ;
data [ 'url' ] = use _cache ? ` ${ cache _url } , ${ source _url } ` : source _url ;
2021-07-05 17:33:10 +07:00
data [ 'version_parameter' ] = data [ 'version' ] ;
return await addArchive ( data ) ;
2021-04-26 16:42:09 +07:00
}
2021-07-05 17:33:10 +07:00
exports . addComposer = addComposer ;
async function addDeployer ( data ) {
if ( data [ 'version' ] === 'latest' ) {
data [ 'url' ] = data [ 'domain' ] + '/deployer.phar' ;
}
else {
2022-05-31 11:42:38 +07:00
const manifest = await fetch . fetch ( 'https://deployer.org/manifest.json' ) ;
const version _data = JSON . parse ( manifest . data ) ;
const version _key = Object . keys ( version _data ) . find ( ( key ) => {
return version _data [ key ] [ 'version' ] === data [ 'version' ] ;
} ) ;
if ( version _key ) {
data [ 'url' ] = version _data [ version _key ] [ 'url' ] ;
}
else {
return await utils . addLog ( '$cross' , 'deployer' , 'Version missing in deployer manifest' , data [ 'os' ] ) ;
}
2019-11-24 06:44:53 +07:00
}
2021-07-05 17:33:10 +07:00
return await addArchive ( data ) ;
2021-04-26 16:42:09 +07:00
}
2021-07-05 17:33:10 +07:00
exports . addDeployer = addDeployer ;
async function addDevTools ( data ) {
2022-01-29 06:59:58 +07:00
switch ( data [ 'os' ] ) {
2021-04-26 16:42:09 +07:00
case 'linux' :
case 'darwin' :
2021-07-05 17:33:10 +07:00
return 'add_devtools ' + data [ 'tool' ] ;
2021-04-26 16:42:09 +07:00
case 'win32' :
2021-07-05 17:33:10 +07:00
return await utils . addLog ( '$tick' , data [ 'tool' ] , data [ 'tool' ] + ' is not a windows tool' , 'win32' ) ;
2021-04-26 16:42:09 +07:00
default :
2022-01-29 06:59:58 +07:00
return await utils . log ( 'Platform ' + data [ 'os' ] + ' is not supported' , data [ 'os' ] , 'error' ) ;
2019-11-24 06:44:53 +07:00
}
}
2021-07-05 17:33:10 +07:00
exports . addDevTools = addDevTools ;
async function addPECL ( data ) {
2022-01-29 06:59:58 +07:00
return await utils . getCommand ( data [ 'os' ] , 'pecl' ) ;
2021-04-26 16:42:09 +07:00
}
2021-07-05 17:33:10 +07:00
exports . addPECL = addPECL ;
async function addPhing ( data ) {
data [ 'url' ] =
data [ 'domain' ] + '/get/phing-' + data [ 'version' ] + data [ 'extension' ] ;
2022-03-01 03:01:58 +07:00
if ( data [ 'version' ] != 'latest' ) {
[ data [ 'prefix' ] , data [ 'verb' ] ] = [ 'releases' , 'download' ] ;
data [ 'domain' ] = data [ 'github' ] ;
data [ 'extension' ] = '-' + data [ 'version' ] + data [ 'extension' ] ;
data [ 'url' ] += ',' + ( await getUrl ( data ) ) ;
}
2021-07-05 17:33:10 +07:00
return await addArchive ( data ) ;
}
exports . addPhing = addPhing ;
async function addPhive ( data ) {
2021-04-26 16:42:09 +07:00
switch ( true ) {
2021-07-05 17:33:10 +07:00
case /5\.[3-5]/ . test ( data [ 'php_version' ] ) :
2022-01-29 06:59:58 +07:00
return await utils . addLog ( '$cross' , 'phive' , 'Phive is not supported on PHP ' + data [ 'php_version' ] , data [ 'os' ] ) ;
2021-07-05 17:33:10 +07:00
case /5\.6|7\.0/ . test ( data [ 'php_version' ] ) :
2021-12-13 09:17:57 +07:00
data [ 'version' ] = '0.12.1' ;
2021-04-26 16:42:09 +07:00
break ;
2021-07-05 17:33:10 +07:00
case /7\.1/ . test ( data [ 'php_version' ] ) :
2021-12-13 09:17:57 +07:00
data [ 'version' ] = '0.13.5' ;
2021-04-26 16:42:09 +07:00
break ;
2021-08-02 00:13:11 +07:00
case /7\.2/ . test ( data [ 'php_version' ] ) :
2021-12-13 09:17:57 +07:00
data [ 'version' ] = '0.14.5' ;
2021-08-02 00:13:11 +07:00
break ;
2021-12-13 09:41:59 +07:00
case /^latest$/ . test ( data [ 'version' ] ) :
data [ 'version' ] = await getLatestVersion ( data ) ;
break ;
2019-11-24 06:44:53 +07:00
}
2021-12-13 09:41:59 +07:00
data [ 'extension' ] = '-' + data [ 'version' ] + data [ 'extension' ] ;
data [ 'url' ] = await getUrl ( data ) ;
2021-07-05 17:33:10 +07:00
return await addArchive ( data ) ;
2019-11-24 06:44:53 +07:00
}
2021-07-05 17:33:10 +07:00
exports . addPhive = addPhive ;
async function addPHPUnitTools ( data ) {
2023-06-12 12:25:01 +07:00
if ( data [ 'version' ] === 'latest' ) {
data [ 'version' ] =
2023-06-13 04:46:19 +07:00
( await packagist . search ( data [ 'packagist' ] , data [ 'php_version' ] ) ) ? ?
2023-06-12 12:25:01 +07:00
'latest' ;
2023-05-24 19:49:09 +07:00
}
2021-07-05 17:33:10 +07:00
data [ 'url' ] = await getPharUrl ( data ) ;
return await addArchive ( data ) ;
}
exports . addPHPUnitTools = addPHPUnitTools ;
async function addWPCLI ( data ) {
if ( data [ 'version' ] === 'latest' ) {
data [ 'uri' ] = 'wp-cli/builds/blob/gh-pages/phar/wp-cli.phar?raw=true' ;
data [ 'url' ] = [ data [ 'domain' ] , data [ 'uri' ] ] . join ( '/' ) ;
}
else {
data [ 'extension' ] = '-' + data [ 'version' ] + data [ 'extension' ] ;
data [ 'url' ] = await getUrl ( data ) ;
}
return await addArchive ( data ) ;
}
exports . addWPCLI = addWPCLI ;
2022-01-29 06:59:58 +07:00
async function getData ( release , php _version , os ) {
2022-01-29 06:10:49 +07:00
const json _file _path = path _1 . default . join ( _ _dirname , '../src/configs/tools.json' ) ;
const json _file = fs _1 . default . readFileSync ( json _file _path , 'utf8' ) ;
2021-07-12 18:30:40 +07:00
const json _objects = JSON . parse ( json _file ) ;
release = release . replace ( /\s+/g , '' ) ;
const parts = release . split ( ':' ) ;
const tool = parts [ 0 ] ;
const version = parts [ 1 ] ;
let data ;
if ( Object . keys ( json _objects ) . includes ( tool ) ) {
data = json _objects [ tool ] ;
data [ 'tool' ] = tool ;
}
else {
const key = Object . keys ( json _objects ) . find ( ( key ) => {
return json _objects [ key ] [ 'alias' ] == tool ;
} ) ;
if ( key ) {
data = json _objects [ key ] ;
data [ 'tool' ] = key ;
}
else {
data = {
tool : tool . split ( '/' ) [ 1 ] ,
repository : tool ,
type : 'composer'
} ;
data = ! tool . includes ( '/' ) ? { tool : tool } : data ;
}
}
data [ 'github' ] = 'https://github.com' ;
2022-05-30 08:57:29 +07:00
data [ 'domain' ] ? ? = data [ 'github' ] ;
data [ 'extension' ] ? ? = '.phar' ;
2022-01-29 06:59:58 +07:00
data [ 'os' ] = os ;
2021-07-12 18:30:40 +07:00
data [ 'php_version' ] = php _version ;
2023-06-13 04:46:19 +07:00
data [ 'packagist' ] ? ? = data [ 'repository' ] ;
2021-07-12 18:30:40 +07:00
data [ 'prefix' ] = data [ 'github' ] === data [ 'domain' ] ? 'releases' : '' ;
data [ 'verb' ] = data [ 'github' ] === data [ 'domain' ] ? 'download' : '' ;
2022-05-30 08:57:29 +07:00
data [ 'fetch_latest' ] ? ? = 'false' ;
data [ 'scope' ] ? ? = 'global' ;
2021-07-12 18:30:40 +07:00
data [ 'version_parameter' ] = JSON . stringify ( data [ 'version_parameter' ] ) || '' ;
2022-05-30 08:57:29 +07:00
data [ 'version_prefix' ] ? ? = '' ;
2021-07-12 18:30:40 +07:00
data [ 'release' ] = await getRelease ( release , data ) ;
2021-08-20 10:44:39 +07:00
data [ 'version' ] = version
? await getVersion ( version , data )
: await getLatestVersion ( data ) ;
2021-07-12 18:30:40 +07:00
return data ;
}
exports . getData = getData ;
2021-07-05 17:33:10 +07:00
exports . functionRecord = {
2023-06-23 21:13:17 +07:00
castor : addCastor ,
2021-07-05 17:33:10 +07:00
composer : addComposer ,
deployer : addDeployer ,
dev _tools : addDevTools ,
phive : addPhive ,
blackfire _player : addBlackfirePlayer ,
pecl : addPECL ,
phing : addPhing ,
phpunit : addPHPUnitTools ,
phpcpd : addPHPUnitTools ,
wp _cli : addWPCLI
} ;
2022-01-29 06:59:58 +07:00
async function addTools ( tools _csv , php _version , os ) {
2021-04-26 16:42:09 +07:00
let script = '\n' ;
if ( tools _csv === 'none' ) {
return '' ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
else {
2022-01-29 06:59:58 +07:00
script += await utils . stepLog ( 'Setup Tools' , os ) ;
2019-11-24 06:44:53 +07:00
}
2021-07-05 17:33:10 +07:00
const tools _list = await filterList ( await utils . CSVArray ( tools _csv ) ) ;
2021-04-26 16:42:09 +07:00
await utils . asyncForEach ( tools _list , async function ( release ) {
2022-01-29 06:59:58 +07:00
const data = await getData ( release , php _version , os ) ;
2021-04-26 16:42:09 +07:00
script += '\n' ;
switch ( true ) {
2021-07-09 12:56:38 +07:00
case data [ 'error' ] !== undefined :
2022-01-29 06:59:58 +07:00
script += await utils . addLog ( '$cross' , data [ 'tool' ] , data [ 'error' ] , data [ 'os' ] ) ;
2021-07-09 12:56:38 +07:00
break ;
2021-07-05 17:33:10 +07:00
case 'phar' === data [ 'type' ] :
data [ 'url' ] = await getUrl ( data ) ;
script += await addArchive ( data ) ;
2021-04-26 16:42:09 +07:00
break ;
2021-07-05 17:33:10 +07:00
case 'composer' === data [ 'type' ] :
script += await addPackage ( data ) ;
2021-04-26 16:42:09 +07:00
break ;
2021-07-05 17:33:10 +07:00
case 'custom-package' === data [ 'type' ] :
2022-01-29 06:59:58 +07:00
script += await utils . customPackage ( data [ 'tool' ] . split ( '-' ) [ 0 ] , 'tools' , data [ 'version' ] , data [ 'os' ] ) ;
2021-04-26 16:42:09 +07:00
break ;
2021-07-05 17:33:10 +07:00
case 'custom-function' === data [ 'type' ] :
script += await exports . functionRecord [ data [ 'function' ] ] ( data ) ;
2021-04-26 16:42:09 +07:00
break ;
2021-07-05 17:33:10 +07:00
case /^none$/ . test ( data [ 'tool' ] ) :
2021-04-26 16:42:09 +07:00
break ;
default :
2022-01-29 06:59:58 +07:00
script += await utils . addLog ( '$cross' , data [ 'tool' ] , 'Tool ' + data [ 'tool' ] + ' is not supported' , data [ 'os' ] ) ;
2021-04-26 16:42:09 +07:00
break ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
} ) ;
return script ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . addTools = addTools ;
2021-05-31 06:51:18 +07:00
//# sourceMappingURL=tools.js.map
2019-11-24 06:44:53 +07:00
2019-12-19 04:08:12 +07:00
/***/ } ) ,
2021-04-26 16:42:09 +07:00
/***/ 918 :
2021-02-22 17:27:16 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2020-10-02 05:56:51 +07:00
2021-11-26 01:45:10 +07:00
"use strict" ;
2020-10-02 05:56:51 +07:00
2021-04-26 16:42:09 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2022-03-22 21:00:07 +07:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2021-04-26 16:42:09 +07:00
} ) : ( 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 . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
2020-10-02 05:56:51 +07:00
} ;
2023-01-29 12:26:49 +07:00
var _ _importDefault = ( this && this . _ _importDefault ) || function ( mod ) {
return ( mod && mod . _ _esModule ) ? mod : { "default" : mod } ;
} ;
2021-02-22 17:27:16 +07:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2023-04-02 22:00:40 +07:00
exports . setVariable = exports . readPHPVersion = exports . parseExtensionSource = exports . customPackage = exports . scriptTool = exports . scriptExtension = exports . joins = exports . getCommand = exports . getUnsupportedLog = exports . suppressOutput = exports . getExtensionPrefix = exports . CSVArray = exports . extensionArray = exports . addLog = exports . stepLog = exports . log = exports . color = exports . asyncForEach = exports . parseIniFile = exports . parseVersion = exports . getManifestURL = exports . getInput = exports . readEnv = void 0 ;
2023-01-29 12:26:49 +07:00
const fs _1 = _ _importDefault ( _ _nccwpck _require _ _ ( 7147 ) ) ;
2022-08-17 18:35:01 +07:00
const path = _ _importStar ( _ _nccwpck _require _ _ ( 1017 ) ) ;
const core = _ _importStar ( _ _nccwpck _require _ _ ( 2186 ) ) ;
const fetch = _ _importStar ( _ _nccwpck _require _ _ ( 2387 ) ) ;
2021-04-26 16:42:09 +07:00
async function readEnv ( property ) {
2021-07-23 17:49:00 +07:00
const property _lc = property . toLowerCase ( ) ;
const property _uc = property . toUpperCase ( ) ;
return ( process . env [ property ] ||
process . env [ property _lc ] ||
process . env [ property _uc ] ||
process . env [ property _lc . replace ( '_' , '-' ) ] ||
process . env [ property _uc . replace ( '_' , '-' ) ] ||
'' ) ;
2020-10-02 05:56:51 +07:00
}
2021-04-26 16:42:09 +07:00
exports . readEnv = readEnv ;
async function getInput ( name , mandatory ) {
const input = core . getInput ( name ) ;
const env _input = await readEnv ( name ) ;
switch ( true ) {
case input != '' :
return input ;
case input == '' && env _input != '' :
return env _input ;
case input == '' && env _input == '' && mandatory :
throw new Error ( ` Input required and not supplied: ${ name } ` ) ;
default :
return '' ;
}
}
exports . getInput = getInput ;
2021-07-09 12:56:38 +07:00
async function getManifestURL ( ) {
return 'https://raw.githubusercontent.com/shivammathur/setup-php/develop/src/configs/php-versions.json' ;
}
exports . getManifestURL = getManifestURL ;
2021-04-26 16:42:09 +07:00
async function parseVersion ( version ) {
switch ( true ) {
2021-09-06 13:28:31 +07:00
case /^(latest|nightly|\d+\.x)$/ . test ( version ) :
2023-01-29 23:20:51 +07:00
return JSON . parse ( ( await fetch . fetch ( await getManifestURL ( ) ) ) [ 'data' ] ) [ version ] ;
2021-04-26 16:42:09 +07:00
default :
switch ( true ) {
case version . length > 1 :
return version . slice ( 0 , 3 ) ;
default :
return version + '.0' ;
}
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
}
exports . parseVersion = parseVersion ;
2022-01-25 15:13:49 +07:00
async function parseIniFile ( ini _file ) {
switch ( true ) {
case /^(production|development|none)$/ . test ( ini _file ) :
return ini _file ;
case /php\.ini-(production|development)$/ . test ( ini _file ) :
return ini _file . split ( '-' ) [ 1 ] ;
default :
return 'production' ;
}
}
exports . parseIniFile = parseIniFile ;
2021-04-26 16:42:09 +07:00
async function asyncForEach ( array , callback ) {
for ( let index = 0 ; index < array . length ; index ++ ) {
await callback ( array [ index ] , index , array ) ;
2020-10-03 03:09:43 +07:00
}
}
2021-04-26 16:42:09 +07:00
exports . asyncForEach = asyncForEach ;
async function color ( type ) {
switch ( type ) {
case 'error' :
return '31' ;
default :
case 'success' :
return '32' ;
case 'warning' :
return '33' ;
}
2021-01-16 12:46:13 +07:00
}
2021-04-26 16:42:09 +07:00
exports . color = color ;
2022-01-29 06:59:58 +07:00
async function log ( message , os , log _type ) {
switch ( os ) {
2021-04-26 16:42:09 +07:00
case 'win32' :
return ( 'printf "\\033[' +
( await color ( log _type ) ) +
';1m' +
message +
' \\033[0m"' ) ;
case 'linux' :
case 'darwin' :
default :
return ( 'echo "\\033[' + ( await color ( log _type ) ) + ';1m' + message + '\\033[0m"' ) ;
}
2020-10-02 16:21:40 +07:00
}
2021-04-26 16:42:09 +07:00
exports . log = log ;
2022-01-29 06:59:58 +07:00
async function stepLog ( message , os ) {
switch ( os ) {
2021-04-26 16:42:09 +07:00
case 'win32' :
return 'Step-Log "' + message + '"' ;
case 'linux' :
case 'darwin' :
return 'step_log "' + message + '"' ;
default :
2022-01-29 06:59:58 +07:00
return await log ( 'Platform ' + os + ' is not supported' , os , 'error' ) ;
2020-03-12 09:27:40 +07:00
}
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . stepLog = stepLog ;
2022-01-29 06:59:58 +07:00
async function addLog ( mark , subject , message , os ) {
switch ( os ) {
2021-04-26 16:42:09 +07:00
case 'win32' :
return 'Add-Log "' + mark + '" "' + subject + '" "' + message + '"' ;
case 'linux' :
case 'darwin' :
return 'add_log "' + mark + '" "' + subject + '" "' + message + '"' ;
default :
2022-01-29 06:59:58 +07:00
return await log ( 'Platform ' + os + ' is not supported' , os , 'error' ) ;
2021-04-26 16:42:09 +07:00
}
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
exports . addLog = addLog ;
async function extensionArray ( extension _csv ) {
switch ( extension _csv ) {
case '' :
case ' ' :
return [ ] ;
default :
2021-08-26 22:59:38 +07:00
return [
extension _csv . match ( /(^|,\s?)none(\s?,|$)/ ) ? 'none' : '' ,
... extension _csv
. split ( ',' )
. map ( function ( extension ) {
if ( /.+-.+\/.+@.+/ . test ( extension ) ) {
return extension ;
}
return extension
. trim ( )
. toLowerCase ( )
2021-12-08 06:26:29 +07:00
. replace ( /^(:)?(php[-_]|none|zend )|(-[^-]*)-/ , '$1$3' ) ;
2021-08-26 22:59:38 +07:00
} )
] . filter ( Boolean ) ;
2021-04-26 16:42:09 +07:00
}
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . extensionArray = extensionArray ;
async function CSVArray ( values _csv ) {
switch ( values _csv ) {
case '' :
case ' ' :
return [ ] ;
default :
return values _csv
. split ( /,(?=(?:(?:[^"']*["']){2})*[^"']*$)/ )
. map ( function ( value ) {
return value
. trim ( )
. replace ( /^["']|["']$|(?<==)["']/g , '' )
2022-12-15 06:57:13 +07:00
. replace ( /=(((?!E_).)*[?{}|&~![()^]+((?!E_).)+)/ , "='$1'" )
2023-06-12 07:10:08 +07:00
. replace ( /=(.*?)(=.*)/ , "='$1$2'" )
. replace ( /:\s*["'](.*?)/g , ':$1' ) ;
2021-04-26 16:42:09 +07:00
} )
. filter ( Boolean ) ;
}
}
exports . CSVArray = CSVArray ;
async function getExtensionPrefix ( extension ) {
switch ( true ) {
default :
return 'extension' ;
case /xdebug([2-3])?$|opcache|ioncube|eaccelerator/ . test ( extension ) :
return 'zend_extension' ;
}
}
exports . getExtensionPrefix = getExtensionPrefix ;
2022-01-29 06:59:58 +07:00
async function suppressOutput ( os ) {
switch ( os ) {
2021-04-26 16:42:09 +07:00
case 'win32' :
return ' >$null 2>&1' ;
case 'linux' :
case 'darwin' :
return ' >/dev/null 2>&1' ;
default :
2022-01-29 06:59:58 +07:00
return await log ( 'Platform ' + os + ' is not supported' , os , 'error' ) ;
2021-04-26 16:42:09 +07:00
}
}
exports . suppressOutput = suppressOutput ;
2022-01-29 06:59:58 +07:00
async function getUnsupportedLog ( extension , version , os ) {
2021-04-26 16:42:09 +07:00
return ( '\n' +
2022-01-29 06:59:58 +07:00
( await addLog ( '$cross' , extension , [ extension , 'is not supported on PHP' , version ] . join ( ' ' ) , os ) ) +
2021-04-26 16:42:09 +07:00
'\n' ) ;
}
exports . getUnsupportedLog = getUnsupportedLog ;
2022-01-29 06:59:58 +07:00
async function getCommand ( os , suffix ) {
switch ( os ) {
2021-04-26 16:42:09 +07:00
case 'linux' :
case 'darwin' :
return 'add_' + suffix + ' ' ;
case 'win32' :
2023-01-18 10:30:28 +07:00
return ( 'Add-' +
suffix
. split ( '_' )
. map ( ( part ) => part . charAt ( 0 ) . toUpperCase ( ) + part . slice ( 1 ) )
. join ( '' ) +
' ' ) ;
2021-04-26 16:42:09 +07:00
default :
2022-01-29 06:59:58 +07:00
return await log ( 'Platform ' + os + ' is not supported' , os , 'error' ) ;
2021-04-26 16:42:09 +07:00
}
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . getCommand = getCommand ;
async function joins ( ... str ) {
return [ ... str ] . join ( ' ' ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . joins = joins ;
2022-01-29 06:59:58 +07:00
async function scriptExtension ( os ) {
switch ( os ) {
2021-04-26 16:42:09 +07:00
case 'win32' :
return '.ps1' ;
case 'linux' :
case 'darwin' :
return '.sh' ;
default :
2022-01-29 06:59:58 +07:00
return await log ( 'Platform ' + os + ' is not supported' , os , 'error' ) ;
2021-04-26 16:42:09 +07:00
}
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . scriptExtension = scriptExtension ;
2022-01-29 06:59:58 +07:00
async function scriptTool ( os ) {
switch ( os ) {
2021-04-26 16:42:09 +07:00
case 'win32' :
2022-01-30 10:15:11 +07:00
return 'pwsh ' ;
2021-04-26 16:42:09 +07:00
case 'linux' :
case 'darwin' :
2022-01-30 10:15:11 +07:00
return 'bash ' ;
2021-04-26 16:42:09 +07:00
default :
2022-01-29 06:59:58 +07:00
return await log ( 'Platform ' + os + ' is not supported' , os , 'error' ) ;
2021-04-26 16:42:09 +07:00
}
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . scriptTool = scriptTool ;
2022-01-29 06:59:58 +07:00
async function customPackage ( pkg , type , version , os ) {
2021-04-26 16:42:09 +07:00
const pkg _name = pkg . replace ( /\d+|(pdo|pecl)[_-]/ , '' ) ;
2022-01-29 06:59:58 +07:00
const script _extension = await scriptExtension ( os ) ;
2021-04-26 16:42:09 +07:00
const script = path . join ( _ _dirname , '../src/scripts/' + type + '/' + pkg _name + script _extension ) ;
2022-01-29 06:59:58 +07:00
const command = await getCommand ( os , pkg _name ) ;
2021-04-26 16:42:09 +07:00
return '\n. ' + script + '\n' + command + version ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . customPackage = customPackage ;
async function parseExtensionSource ( extension , prefix ) {
2022-01-22 03:55:58 +07:00
const regex = /(\w+)-(\w+:\/\/.{1,253}(?:[.:][^:/\s]{2,63})+\/)?([\w.-]+)\/([\w.-]+)@(.+)/ ;
2021-04-26 16:42:09 +07:00
const matches = regex . exec ( extension ) ;
matches [ 2 ] = matches [ 2 ] ? matches [ 2 ] . slice ( 0 , - 1 ) : 'https://github.com' ;
return await joins ( '\nadd_extension_from_source' , ... matches . splice ( 1 , matches . length ) , prefix ) ;
}
exports . parseExtensionSource = parseExtensionSource ;
2023-04-02 22:00:40 +07:00
async function readPHPVersion ( ) {
2023-01-29 21:47:23 +07:00
const version = await getInput ( 'php-version' , false ) ;
2023-01-29 12:26:49 +07:00
if ( version ) {
return version ;
}
2023-01-29 21:47:23 +07:00
const versionFile = ( await getInput ( 'php-version-file' , false ) ) || '.php-version' ;
2023-01-29 12:26:49 +07:00
if ( fs _1 . default . existsSync ( versionFile ) ) {
2023-04-02 21:55:49 +07:00
return fs _1 . default . readFileSync ( versionFile , 'utf8' ) . replace ( /[\r\n]/g , '' ) ;
2023-01-29 12:26:49 +07:00
}
2023-01-29 21:47:23 +07:00
else if ( versionFile !== '.php-version' ) {
throw new Error ( ` Could not find ' ${ versionFile } ' file. ` ) ;
2023-01-29 12:26:49 +07:00
}
2023-01-29 21:47:23 +07:00
return 'latest' ;
2023-01-29 12:26:49 +07:00
}
2023-04-02 22:00:40 +07:00
exports . readPHPVersion = readPHPVersion ;
2022-06-30 19:06:40 +07:00
async function setVariable ( variable , command , os ) {
switch ( os ) {
case 'win32' :
return '\n$' + variable + ' = ' + command + '\n' ;
case 'linux' :
case 'darwin' :
default :
return '\n' + variable + '="$(' + command + ')"\n' ;
}
}
exports . setVariable = setVariable ;
2021-05-31 06:51:18 +07:00
//# sourceMappingURL=utils.js.map
2021-02-22 17:27:16 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 5241 :
2021-02-22 17:27:16 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-02-22 17:27:16 +07:00
2021-05-31 06:51:18 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
2021-02-22 17:27:16 +07:00
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
2021-05-31 06:51:18 +07:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
2021-02-22 17:27:16 +07:00
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-05-31 06:51:18 +07:00
exports . issue = exports . issueCommand = void 0 ;
2022-08-17 18:35:01 +07:00
const os = _ _importStar ( _ _nccwpck _require _ _ ( 2037 ) ) ;
const utils _1 = _ _nccwpck _require _ _ ( 5278 ) ;
2019-11-24 06:44:53 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* Commands
2019-11-24 06:44:53 +07:00
*
2021-04-26 16:42:09 +07:00
* Command Format :
* : : name key = value , key = value : : message
2020-07-24 11:58:48 +07:00
*
2021-04-26 16:42:09 +07:00
* Examples :
* : : warning : : This is the message
* : : set - env name = MY _VAR : : some value
2020-07-24 11:58:48 +07:00
* /
2021-04-26 16:42:09 +07:00
function issueCommand ( command , properties , message ) {
const cmd = new Command ( command , properties , message ) ;
process . stdout . write ( cmd . toString ( ) + os . EOL ) ;
2020-07-24 11:58:48 +07:00
}
2021-04-26 16:42:09 +07:00
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 ;
2020-08-06 17:03:58 +07:00
}
2021-04-26 16:42:09 +07:00
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 ;
2020-10-04 18:33:02 +07:00
}
}
2021-04-26 16:42:09 +07:00
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
2019-12-10 06:52:33 +07:00
2019-11-24 06:44:53 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 2186 :
2021-02-22 17:27:16 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2019-11-24 06:44:53 +07:00
2021-11-26 01:45:10 +07:00
"use strict" ;
2019-11-24 06:44:53 +07:00
2021-05-31 06:51:18 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
2021-04-26 16:42:09 +07: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 ( ) ) ;
} ) ;
} ;
2021-02-22 17:27:16 +07:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-11-26 01:45:10 +07:00
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 ;
2022-08-17 18:35:01 +07:00
const command _1 = _ _nccwpck _require _ _ ( 5241 ) ;
2021-04-26 16:42:09 +07:00
const file _command _1 = _ _nccwpck _require _ _ ( 717 ) ;
2022-08-17 18:35:01 +07:00
const utils _1 = _ _nccwpck _require _ _ ( 5278 ) ;
const os = _ _importStar ( _ _nccwpck _require _ _ ( 2037 ) ) ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 1017 ) ) ;
const oidc _utils _1 = _ _nccwpck _require _ _ ( 8041 ) ;
2019-11-24 06:44:53 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* The code to exit an action
2019-11-24 06:44:53 +07:00
* /
2021-04-26 16:42:09 +07:00
var ExitCode ;
( function ( ExitCode ) {
/ * *
* A code indicating that the action was successful
* /
ExitCode [ ExitCode [ "Success" ] = 0 ] = "Success" ;
/ * *
* A code indicating that the action was a failure
* /
ExitCode [ ExitCode [ "Failure" ] = 1 ] = "Failure" ;
} ) ( ExitCode = exports . ExitCode || ( exports . ExitCode = { } ) ) ;
//-----------------------------------------------------------------------
// Variables
//-----------------------------------------------------------------------
/ * *
* Sets env variable for this action and future actions in the job
* @ param name the name of the variable to set
* @ param val the value of the variable . Non - string values will be converted to a string via JSON . stringify
* /
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function exportVariable ( name , val ) {
const convertedVal = utils _1 . toCommandValue ( val ) ;
process . env [ name ] = convertedVal ;
const filePath = process . env [ 'GITHUB_ENV' ] || '' ;
if ( filePath ) {
2022-10-12 18:01:05 +07:00
return file _command _1 . issueFileCommand ( 'ENV' , file _command _1 . prepareKeyValueMessage ( name , val ) ) ;
2021-04-26 16:42:09 +07:00
}
2022-10-12 18:01:05 +07:00
command _1 . issueCommand ( 'set-env' , { name } , convertedVal ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
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 ) {
2022-10-12 18:01:05 +07:00
file _command _1 . issueFileCommand ( 'PATH' , inputPath ) ;
2021-04-26 16:42:09 +07:00
}
else {
command _1 . issueCommand ( 'add-path' , { } , inputPath ) ;
}
process . env [ 'PATH' ] = ` ${ inputPath } ${ path . delimiter } ${ process . env [ 'PATH' ] } ` ;
}
exports . addPath = addPath ;
2021-02-22 17:27:16 +07:00
/ * *
2021-05-31 06:51:18 +07:00
* 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 .
2021-02-22 17:27:16 +07:00
*
2021-04-26 16:42:09 +07:00
* @ param name name of the input to get
* @ param options optional . See InputOptions .
* @ returns string
2021-02-22 17:27:16 +07:00
* /
2021-04-26 16:42:09 +07:00
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 } ` ) ;
2019-11-24 06:44:53 +07:00
}
2021-05-31 06:51:18 +07:00
if ( options && options . trimWhitespace === false ) {
return val ;
}
2021-04-26 16:42:09 +07:00
return val . trim ( ) ;
}
exports . getInput = getInput ;
2021-07-14 16:08:18 +07:00
/ * *
* 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 !== '' ) ;
2022-10-12 18:01:05 +07:00
if ( options && options . trimWhitespace === false ) {
return inputs ;
}
return inputs . map ( input => input . trim ( ) ) ;
2021-07-14 16:08:18 +07:00
}
exports . getMultilineInput = getMultilineInput ;
2021-05-31 06:51:18 +07:00
/ * *
* 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 ;
2021-04-26 16:42:09 +07:00
/ * *
* 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 ) {
2022-10-12 18:01:05 +07:00
const filePath = process . env [ 'GITHUB_OUTPUT' ] || '' ;
if ( filePath ) {
return file _command _1 . issueFileCommand ( 'OUTPUT' , file _command _1 . prepareKeyValueMessage ( name , value ) ) ;
}
2021-04-26 16:42:09 +07:00
process . stdout . write ( os . EOL ) ;
2022-10-12 18:01:05 +07:00
command _1 . issueCommand ( 'set-output' , { name } , utils _1 . toCommandValue ( value ) ) ;
2021-04-26 16:42:09 +07:00
}
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 ( )
2021-08-23 14:50:03 +07:00
* @ param properties optional properties to add to the annotation .
2021-04-26 16:42:09 +07:00
* /
2021-08-23 14:50:03 +07:00
function error ( message , properties = { } ) {
command _1 . issueCommand ( 'error' , utils _1 . toCommandProperties ( properties ) , message instanceof Error ? message . toString ( ) : message ) ;
2021-04-26 16:42:09 +07:00
}
exports . error = error ;
/ * *
2021-08-23 14:50:03 +07:00
* Adds a warning issue
2021-04-26 16:42:09 +07:00
* @ param message warning issue message . Errors will be converted to string via toString ( )
2021-08-23 14:50:03 +07:00
* @ param properties optional properties to add to the annotation .
2021-04-26 16:42:09 +07:00
* /
2021-08-23 14:50:03 +07:00
function warning ( message , properties = { } ) {
command _1 . issueCommand ( 'warning' , utils _1 . toCommandProperties ( properties ) , message instanceof Error ? message . toString ( ) : message ) ;
2021-04-26 16:42:09 +07:00
}
exports . warning = warning ;
2021-08-23 14:50:03 +07:00
/ * *
* 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 ;
2021-04-26 16:42:09 +07:00
/ * *
* 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 ;
} ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . group = group ;
//-----------------------------------------------------------------------
// Wrapper action state
//-----------------------------------------------------------------------
2021-02-22 17:27:16 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* Saves state for current action , the state can only be retrieved by this action ' s post job execution .
2021-02-22 17:27:16 +07:00
*
2021-04-26 16:42:09 +07:00
* @ 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
2021-02-22 17:27:16 +07:00
* /
2021-04-26 16:42:09 +07:00
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function saveState ( name , value ) {
2022-10-12 18:01:05 +07:00
const filePath = process . env [ 'GITHUB_STATE' ] || '' ;
if ( filePath ) {
return file _command _1 . issueFileCommand ( 'STATE' , file _command _1 . prepareKeyValueMessage ( name , value ) ) ;
}
command _1 . issueCommand ( 'save-state' , { name } , utils _1 . toCommandValue ( value ) ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . saveState = saveState ;
2021-02-22 17:27:16 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* Gets the value of an state set by this action ' s main execution .
2021-02-22 17:27:16 +07:00
*
2021-04-26 16:42:09 +07:00
* @ param name name of the state to get
* @ returns string
2021-02-22 17:27:16 +07:00
* /
2021-04-26 16:42:09 +07:00
function getState ( name ) {
return process . env [ ` STATE_ ${ name } ` ] || '' ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . getState = getState ;
2021-11-26 01:45:10 +07:00
function getIDToken ( aud ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return yield oidc _utils _1 . OidcClient . getIDToken ( aud ) ;
} ) ;
}
exports . getIDToken = getIDToken ;
2022-05-30 09:04:27 +07:00
/ * *
* Summary exports
* /
2022-08-17 18:35:01 +07:00
var summary _1 = _ _nccwpck _require _ _ ( 1327 ) ;
2022-05-30 09:04:27 +07:00
Object . defineProperty ( exports , "summary" , ( { enumerable : true , get : function ( ) { return summary _1 . summary ; } } ) ) ;
/ * *
* @ deprecated use core . summary
* /
2022-08-17 18:35:01 +07:00
var summary _2 = _ _nccwpck _require _ _ ( 1327 ) ;
2022-05-30 09:04:27 +07:00
Object . defineProperty ( exports , "markdownSummary" , ( { enumerable : true , get : function ( ) { return summary _2 . markdownSummary ; } } ) ) ;
2022-07-06 01:25:52 +07:00
/ * *
* Path exports
* /
2022-08-17 18:35:01 +07:00
var path _utils _1 = _ _nccwpck _require _ _ ( 2981 ) ;
2022-07-06 01:25:52 +07:00
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 ; } } ) ) ;
2021-04-26 16:42:09 +07:00
//# sourceMappingURL=core.js.map
2019-11-24 06:44:53 +07:00
/***/ } ) ,
2021-04-26 16:42:09 +07:00
/***/ 717 :
2021-02-22 17:27:16 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2019-11-24 06:44:53 +07:00
2021-11-26 01:45:10 +07:00
"use strict" ;
2019-11-24 06:44:53 +07:00
2021-04-26 16:42:09 +07:00
// For internal use, subject to change.
2021-05-31 06:51:18 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
2020-01-26 17:55:58 +07:00
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
2021-05-31 06:51:18 +07:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
2020-01-26 17:55:58 +07:00
return result ;
} ;
2021-02-22 17:27:16 +07:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-10-12 18:01:05 +07:00
exports . prepareKeyValueMessage = exports . issueFileCommand = void 0 ;
2021-04-26 16:42:09 +07:00
// We use any as a valid input type
/* eslint-disable @typescript-eslint/no-explicit-any */
2022-08-17 18:35:01 +07:00
const fs = _ _importStar ( _ _nccwpck _require _ _ ( 7147 ) ) ;
const os = _ _importStar ( _ _nccwpck _require _ _ ( 2037 ) ) ;
2022-10-12 18:01:05 +07:00
const uuid _1 = _ _nccwpck _require _ _ ( 5840 ) ;
2022-08-17 18:35:01 +07:00
const utils _1 = _ _nccwpck _require _ _ ( 5278 ) ;
2022-10-12 18:01:05 +07:00
function issueFileCommand ( command , message ) {
2021-04-26 16:42:09 +07:00
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'
2021-02-22 17:27:16 +07:00
} ) ;
2019-11-24 06:44:53 +07:00
}
2022-10-12 18:01:05 +07:00
exports . issueFileCommand = issueFileCommand ;
function prepareKeyValueMessage ( key , value ) {
const delimiter = ` ghadelimiter_ ${ uuid _1 . v4 ( ) } ` ;
const convertedValue = utils _1 . toCommandValue ( value ) ;
// These should realistically never happen, but just in case someone finds a
// way to exploit uuid generation let's not allow keys or values that contain
// the delimiter.
if ( key . includes ( delimiter ) ) {
throw new Error ( ` Unexpected input: name should not contain the delimiter " ${ delimiter } " ` ) ;
}
if ( convertedValue . includes ( delimiter ) ) {
throw new Error ( ` Unexpected input: value should not contain the delimiter " ${ delimiter } " ` ) ;
}
return ` ${ key } << ${ delimiter } ${ os . EOL } ${ convertedValue } ${ os . EOL } ${ delimiter } ` ;
}
exports . prepareKeyValueMessage = prepareKeyValueMessage ;
2021-04-26 16:42:09 +07:00
//# sourceMappingURL=file-command.js.map
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 8041 :
2021-11-26 01:45:10 +07:00
/***/ ( 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-08-17 18:35:01 +07:00
const http _client _1 = _ _nccwpck _require _ _ ( 6255 ) ;
const auth _1 = _ _nccwpck _require _ _ ( 5526 ) ;
const core _1 = _ _nccwpck _require _ _ ( 2186 ) ;
2021-11-26 01:45:10 +07:00
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-08-17 18:35:01 +07:00
/***/ 2981 :
2022-07-06 01:25:52 +07:00
/***/ ( 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 ;
2022-08-17 18:35:01 +07:00
const path = _ _importStar ( _ _nccwpck _require _ _ ( 1017 ) ) ;
2022-07-06 01:25:52 +07:00
/ * *
* 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
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 1327 :
2022-05-30 09:04:27 +07:00
/***/ ( 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 ;
2022-08-17 18:35:01 +07:00
const os _1 = _ _nccwpck _require _ _ ( 2037 ) ;
const fs _1 = _ _nccwpck _require _ _ ( 7147 ) ;
2022-05-30 09:04:27 +07:00
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-08-17 18:35:01 +07:00
/***/ 5278 :
2021-04-26 16:42:09 +07:00
/***/ ( ( _ _unused _webpack _module , exports ) => {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-04-26 16:42:09 +07:00
// We use any as a valid input type
/* eslint-disable @typescript-eslint/no-explicit-any */
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-08-23 14:50:03 +07:00
exports . toCommandProperties = exports . toCommandValue = void 0 ;
2019-11-24 06:44:53 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* Sanitizes an input into a string so it can be passed into issueCommand safely
* @ param input input to sanitize into a string
2019-11-24 06:44:53 +07:00
* /
2021-04-26 16:42:09 +07:00
function toCommandValue ( input ) {
if ( input === null || input === undefined ) {
return '' ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
else if ( typeof input === 'string' || input instanceof String ) {
return input ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
return JSON . stringify ( input ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . toCommandValue = toCommandValue ;
2021-08-23 14:50:03 +07:00
/ * *
*
* @ 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 ,
2021-11-26 01:45:10 +07:00
file : annotationProperties . file ,
2021-08-23 14:50:03 +07:00
line : annotationProperties . startLine ,
endLine : annotationProperties . endLine ,
col : annotationProperties . startColumn ,
endColumn : annotationProperties . endColumn
} ;
}
exports . toCommandProperties = toCommandProperties ;
2021-04-26 16:42:09 +07:00
//# sourceMappingURL=utils.js.map
2021-02-22 17:27:16 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 1514 :
2021-02-22 17:27:16 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-02-22 17:27:16 +07:00
2021-07-14 16:08:18 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
2021-04-26 16:42:09 +07: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 ( ) ) ;
} ) ;
} ;
2021-02-22 17:27:16 +07:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-07-14 16:08:18 +07:00
exports . getExecOutput = exports . exec = void 0 ;
2022-08-17 18:35:01 +07:00
const string _decoder _1 = _ _nccwpck _require _ _ ( 1576 ) ;
const tr = _ _importStar ( _ _nccwpck _require _ _ ( 8159 ) ) ;
2019-11-24 06:44:53 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* Exec a command .
* Output will be streamed to the live console .
* Returns promise with return code
2019-11-24 06:44:53 +07:00
*
2021-04-26 16:42:09 +07:00
* @ 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
2019-11-24 06:44:53 +07:00
* /
2021-04-26 16:42:09 +07:00
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. ` ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
// 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 ( ) ;
} ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . exec = exec ;
2021-07-14 16:08:18 +07:00
/ * *
* 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 ;
2021-04-26 16:42:09 +07:00
//# sourceMappingURL=exec.js.map
2019-11-24 06:44:53 +07:00
2019-12-27 08:26:49 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 8159 :
2021-02-22 17:27:16 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2019-12-27 08:26:49 +07:00
2021-11-26 01:45:10 +07:00
"use strict" ;
2019-12-27 08:26:49 +07:00
2021-07-14 16:08:18 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
2021-04-26 16:42:09 +07: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 ( ) ) ;
} ) ;
} ;
2021-02-22 17:27:16 +07:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-07-14 16:08:18 +07:00
exports . argStringToArray = exports . ToolRunner = void 0 ;
2022-08-17 18:35:01 +07:00
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 _ _ ( 7351 ) ) ;
const ioUtil = _ _importStar ( _ _nccwpck _require _ _ ( 1962 ) ) ;
const timers _1 = _ _nccwpck _require _ _ ( 9512 ) ;
2021-04-26 16:42:09 +07:00
/* 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 .
2020-01-07 09:36:14 +07:00
* /
2021-04-26 16:42:09 +07:00
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 || { } ;
2020-03-12 09:27:40 +07:00
}
2021-04-26 16:42:09 +07:00
_debug ( message ) {
if ( this . options . listeners && this . options . listeners . debug ) {
this . options . listeners . debug ( message ) ;
}
2020-03-12 09:27:40 +07:00
}
2021-04-26 16:42:09 +07:00
_getCommandString ( options , noPrefix ) {
const toolPath = this . _getSpawnFileName ( ) ;
const args = this . _getSpawnArgs ( options ) ;
let cmd = noPrefix ? '' : '[command]' ; // omit prefix when piped to a second tool
if ( IS _WINDOWS ) {
// Windows + cmd file
if ( this . _isCmdFile ( ) ) {
cmd += toolPath ;
for ( const a of args ) {
cmd += ` ${ a } ` ;
}
}
// Windows + verbatim
else if ( options . windowsVerbatimArguments ) {
cmd += ` " ${ toolPath } " ` ;
for ( const a of args ) {
cmd += ` ${ a } ` ;
}
}
// Windows (regular)
else {
cmd += this . _windowsQuoteCmdArg ( toolPath ) ;
for ( const a of args ) {
cmd += ` ${ this . _windowsQuoteCmdArg ( a ) } ` ;
}
}
}
else {
// OSX/Linux - this can likely be improved with some form of quoting.
// creating processes on Unix is fundamentally different than Windows.
// on Unix, execvp() takes an arg array.
cmd += toolPath ;
for ( const a of args ) {
cmd += ` ${ a } ` ;
}
}
return cmd ;
2020-03-12 09:27:40 +07:00
}
2021-04-26 16:42:09 +07:00
_processLineBuffer ( data , strBuffer , onLine ) {
try {
let s = strBuffer + data . toString ( ) ;
let n = s . indexOf ( os . EOL ) ;
while ( n > - 1 ) {
const line = s . substring ( 0 , n ) ;
onLine ( line ) ;
// the rest of the string ...
s = s . substring ( n + os . EOL . length ) ;
n = s . indexOf ( os . EOL ) ;
}
2021-07-14 16:08:18 +07:00
return s ;
2021-04-26 16:42:09 +07:00
}
catch ( err ) {
// streaming lines to console is best effort. Don't fail a build.
this . _debug ( ` error processing line. Failed with error ${ err } ` ) ;
2021-07-14 16:08:18 +07:00
return '' ;
2021-04-26 16:42:09 +07:00
}
2020-12-14 16:07:12 +07:00
}
2021-04-26 16:42:09 +07:00
_getSpawnFileName ( ) {
if ( IS _WINDOWS ) {
if ( this . _isCmdFile ( ) ) {
return process . env [ 'COMSPEC' ] || 'cmd.exe' ;
}
}
return this . toolPath ;
2020-03-12 09:27:40 +07:00
}
2021-04-26 16:42:09 +07:00
_getSpawnArgs ( options ) {
if ( IS _WINDOWS ) {
if ( this . _isCmdFile ( ) ) {
let argline = ` /D /S /C " ${ this . _windowsQuoteCmdArg ( this . toolPath ) } ` ;
for ( const a of this . args ) {
argline += ' ' ;
argline += options . windowsVerbatimArguments
? a
: this . _windowsQuoteCmdArg ( a ) ;
}
argline += '"' ;
return [ argline ] ;
}
}
return this . args ;
2020-03-12 09:27:40 +07:00
}
2021-04-26 16:42:09 +07:00
_endsWith ( str , end ) {
return str . endsWith ( end ) ;
2020-10-30 12:05:13 +07:00
}
2021-04-26 16:42:09 +07:00
_isCmdFile ( ) {
const upperToolPath = this . toolPath . toUpperCase ( ) ;
return ( this . _endsWith ( upperToolPath , '.CMD' ) ||
this . _endsWith ( upperToolPath , '.BAT' ) ) ;
2020-03-12 09:27:40 +07:00
}
2021-04-26 16:42:09 +07:00
_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 ( '' ) ;
2020-03-12 09:27:40 +07:00
}
2021-04-26 16:42:09 +07:00
_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 ( '' ) ;
2020-03-12 09:27:40 +07:00
}
2021-04-26 16:42:09 +07:00
_cloneExecOptions ( options ) {
options = options || { } ;
const result = {
cwd : options . cwd || process . cwd ( ) ,
env : options . env || process . env ,
silent : options . silent || false ,
windowsVerbatimArguments : options . windowsVerbatimArguments || false ,
failOnStdErr : options . failOnStdErr || false ,
ignoreReturnCode : options . ignoreReturnCode || false ,
delay : options . delay || 10000
} ;
result . outStream = options . outStream || process . stdout ;
result . errStream = options . errStream || process . stderr ;
return result ;
2020-03-12 09:27:40 +07:00
}
2021-04-26 16:42:09 +07:00
_getSpawnOptions ( options , toolPath ) {
options = options || { } ;
const result = { } ;
result . cwd = options . cwd ;
result . env = options . env ;
result [ 'windowsVerbatimArguments' ] =
options . windowsVerbatimArguments || this . _isCmdFile ( ) ;
if ( options . windowsVerbatimArguments ) {
result . argv0 = ` " ${ toolPath } " ` ;
}
return result ;
2020-03-12 09:27:40 +07:00
}
2021-04-26 16:42:09 +07:00
/ * *
* Exec a tool .
* Output will be streamed to the live console .
* Returns promise with return code
*
* @ param tool path to tool to exec
* @ param options optional exec options . See ExecOptions
* @ returns number
* /
exec ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
// root the tool path if it is unrooted and contains relative pathing
if ( ! ioUtil . isRooted ( this . toolPath ) &&
( this . toolPath . includes ( '/' ) ||
( IS _WINDOWS && this . toolPath . includes ( '\\' ) ) ) ) {
// prefer options.cwd if it is specified, however options.cwd may also need to be rooted
this . toolPath = path . resolve ( process . cwd ( ) , this . options . cwd || process . cwd ( ) , this . toolPath ) ;
}
// if the tool is only a file name, then resolve it from the PATH
// otherwise verify it exists (add extension on Windows if necessary)
this . toolPath = yield io . which ( this . toolPath , true ) ;
2021-07-14 16:08:18 +07:00
return new Promise ( ( resolve , reject ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
2021-04-26 16:42:09 +07:00
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 ) ;
} ) ;
2021-07-14 16:08:18 +07:00
if ( this . options . cwd && ! ( yield ioUtil . exists ( this . options . cwd ) ) ) {
return reject ( new Error ( ` The cwd: ${ this . options . cwd } does not exist! ` ) ) ;
}
2021-04-26 16:42:09 +07:00
const fileName = this . _getSpawnFileName ( ) ;
const cp = child . spawn ( fileName , this . _getSpawnArgs ( optionsNonNull ) , this . _getSpawnOptions ( this . options , fileName ) ) ;
2021-07-14 16:08:18 +07:00
let stdbuffer = '' ;
2021-04-26 16:42:09 +07:00
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 ) ;
}
2021-07-14 16:08:18 +07:00
stdbuffer = this . _processLineBuffer ( data , stdbuffer , ( line ) => {
2021-04-26 16:42:09 +07:00
if ( this . options . listeners && this . options . listeners . stdline ) {
this . options . listeners . stdline ( line ) ;
}
} ) ;
} ) ;
}
2021-07-14 16:08:18 +07:00
let errbuffer = '' ;
2021-04-26 16:42:09 +07:00
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 ) ;
}
2021-07-14 16:08:18 +07:00
errbuffer = this . _processLineBuffer ( data , errbuffer , ( line ) => {
2021-04-26 16:42:09 +07:00
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 ) ;
}
2021-07-14 16:08:18 +07:00
} ) ) ;
2021-04-26 16:42:09 +07:00
} ) ;
2020-06-03 16:21:22 +07:00
}
}
2021-04-26 16:42:09 +07:00
exports . ToolRunner = ToolRunner ;
2020-01-17 14:28:28 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* Convert an arg string to an array of args . Handles escaping
2020-01-17 14:28:28 +07:00
*
2021-04-26 16:42:09 +07:00
* @ param argString string of arguments
* @ returns string [ ] array of arguments
2020-01-17 14:28:28 +07:00
* /
2021-04-26 16:42:09 +07:00
function argStringToArray ( argString ) {
const args = [ ] ;
let inQuotes = false ;
let escaped = false ;
let arg = '' ;
function append ( c ) {
// we only escape double quotes.
if ( escaped && c !== '"' ) {
arg += '\\' ;
}
arg += c ;
escaped = false ;
2020-03-12 09:27:40 +07:00
}
2021-04-26 16:42:09 +07:00
for ( let i = 0 ; i < argString . length ; i ++ ) {
const c = argString . charAt ( i ) ;
if ( c === '"' ) {
if ( ! escaped ) {
inQuotes = ! inQuotes ;
}
else {
append ( c ) ;
}
continue ;
}
if ( c === '\\' && escaped ) {
append ( c ) ;
continue ;
}
if ( c === '\\' && inQuotes ) {
escaped = true ;
continue ;
}
if ( c === ' ' && ! inQuotes ) {
if ( arg . length > 0 ) {
args . push ( arg ) ;
arg = '' ;
}
continue ;
}
append ( c ) ;
2021-04-21 18:41:24 +07:00
}
2021-04-26 16:42:09 +07:00
if ( arg . length > 0 ) {
args . push ( arg . trim ( ) ) ;
2021-04-21 18:41:24 +07:00
}
2021-04-26 16:42:09 +07:00
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 ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
if ( this . processClosed ) {
this . _setResult ( ) ;
}
else if ( this . processExited ) {
2021-07-14 16:08:18 +07:00
this . timeout = timers _1 . setTimeout ( ExecState . HandleTimeout , this . delay , this ) ;
2021-04-26 16:42:09 +07:00
}
}
_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 ( ) ;
}
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
//# sourceMappingURL=toolrunner.js.map
2019-11-24 06:44:53 +07:00
2021-11-26 01:45:10 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 5526 :
2022-05-30 09:04:27 +07:00
/***/ ( function ( _ _unused _webpack _module , exports ) {
2021-11-26 01:45:10 +07:00
"use strict" ;
2022-05-30 09:04:27 +07: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 ( ) ) ;
} ) ;
} ;
2021-11-26 01:45:10 +07:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-05-30 09:04:27 +07:00
exports . PersonalAccessTokenCredentialHandler = exports . BearerCredentialHandler = exports . BasicCredentialHandler = void 0 ;
2021-11-26 01:45:10 +07:00
class BasicCredentialHandler {
constructor ( username , password ) {
this . username = username ;
this . password = password ;
}
prepareRequest ( options ) {
2022-05-30 09:04:27 +07:00
if ( ! options . headers ) {
throw Error ( 'The request has no headers' ) ;
}
options . headers [ 'Authorization' ] = ` Basic ${ Buffer . from ( ` ${ this . username } : ${ this . password } ` ) . toString ( 'base64' ) } ` ;
2021-11-26 01:45:10 +07:00
}
// This handler cannot handle 401
2022-05-30 09:04:27 +07:00
canHandleAuthentication ( ) {
2021-11-26 01:45:10 +07:00
return false ;
}
2022-05-30 09:04:27 +07:00
handleAuthentication ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
throw new Error ( 'not implemented' ) ;
} ) ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07:00
if ( ! options . headers ) {
throw Error ( 'The request has no headers' ) ;
}
options . headers [ 'Authorization' ] = ` Bearer ${ this . token } ` ;
2021-11-26 01:45:10 +07:00
}
// This handler cannot handle 401
2022-05-30 09:04:27 +07:00
canHandleAuthentication ( ) {
2021-11-26 01:45:10 +07:00
return false ;
}
2022-05-30 09:04:27 +07:00
handleAuthentication ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
throw new Error ( 'not implemented' ) ;
} ) ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07:00
if ( ! options . headers ) {
throw Error ( 'The request has no headers' ) ;
}
options . headers [ 'Authorization' ] = ` Basic ${ Buffer . from ( ` PAT: ${ this . token } ` ) . toString ( 'base64' ) } ` ;
2021-11-26 01:45:10 +07:00
}
// This handler cannot handle 401
2022-05-30 09:04:27 +07:00
canHandleAuthentication ( ) {
2021-11-26 01:45:10 +07:00
return false ;
}
2022-05-30 09:04:27 +07:00
handleAuthentication ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
throw new Error ( 'not implemented' ) ;
} ) ;
2021-11-26 01:45:10 +07:00
}
}
exports . PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHandler ;
2022-05-30 09:04:27 +07:00
//# sourceMappingURL=auth.js.map
2021-11-26 01:45:10 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 6255 :
2022-05-30 09:04:27 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-11-26 01:45:10 +07:00
"use strict" ;
2022-05-30 09:04:27 +07: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 ( ) ) ;
} ) ;
} ;
2021-11-26 01:45:10 +07:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-05-30 09:04:27 +07:00
exports . HttpClient = exports . isHttps = exports . HttpClientResponse = exports . HttpClientError = exports . getProxyUrl = exports . MediaTypes = exports . Headers = exports . HttpCodes = void 0 ;
2022-08-17 18:35:01 +07:00
const http = _ _importStar ( _ _nccwpck _require _ _ ( 3685 ) ) ;
const https = _ _importStar ( _ _nccwpck _require _ _ ( 5687 ) ) ;
const pm = _ _importStar ( _ _nccwpck _require _ _ ( 9835 ) ) ;
const tunnel = _ _importStar ( _ _nccwpck _require _ _ ( 4294 ) ) ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07:00
const proxyUrl = pm . getProxyUrl ( new URL ( serverUrl ) ) ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07: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 ( ) ) ;
} ) ;
} ) ) ;
2021-11-26 01:45:10 +07:00
} ) ;
}
}
exports . HttpClientResponse = HttpClientResponse ;
function isHttps ( requestUrl ) {
2022-05-30 09:04:27 +07:00
const parsedUrl = new URL ( requestUrl ) ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'OPTIONS' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
2021-11-26 01:45:10 +07:00
}
get ( requestUrl , additionalHeaders ) {
2022-05-30 09:04:27 +07:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'GET' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
2021-11-26 01:45:10 +07:00
}
del ( requestUrl , additionalHeaders ) {
2022-05-30 09:04:27 +07:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'DELETE' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
2021-11-26 01:45:10 +07:00
}
post ( requestUrl , data , additionalHeaders ) {
2022-05-30 09:04:27 +07:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'POST' , requestUrl , data , additionalHeaders || { } ) ;
} ) ;
2021-11-26 01:45:10 +07:00
}
patch ( requestUrl , data , additionalHeaders ) {
2022-05-30 09:04:27 +07:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'PATCH' , requestUrl , data , additionalHeaders || { } ) ;
} ) ;
2021-11-26 01:45:10 +07:00
}
put ( requestUrl , data , additionalHeaders ) {
2022-05-30 09:04:27 +07:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'PUT' , requestUrl , data , additionalHeaders || { } ) ;
} ) ;
2021-11-26 01:45:10 +07:00
}
head ( requestUrl , additionalHeaders ) {
2022-05-30 09:04:27 +07:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'HEAD' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
2021-11-26 01:45:10 +07:00
}
sendStream ( verb , requestUrl , stream , additionalHeaders ) {
2022-05-30 09:04:27 +07:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( verb , requestUrl , stream , additionalHeaders ) ;
} ) ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07: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 ) ;
} ) ;
}
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 ) ;
} ) ;
2021-11-26 01:45:10 +07:00
}
/ * *
* Makes a raw http request .
* All other methods such as get , post , patch , and request ultimately call this .
* Prefer get , del , post and patch
* /
2022-05-30 09:04:27 +07:00
request ( verb , requestUrl , data , headers ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( this . _disposed ) {
throw new Error ( 'Client has already been disposed.' ) ;
}
const parsedUrl = new URL ( requestUrl ) ;
let info = this . _prepareRequest ( verb , parsedUrl , headers ) ;
// Only perform retries on reads since writes may not be idempotent.
const maxTries = this . _allowRetries && RetryableHttpVerbs . includes ( verb )
? this . _maxRetries + 1
: 1 ;
let numTries = 0 ;
let response ;
do {
response = yield this . requestRaw ( info , data ) ;
// Check if it's an authentication challenge
if ( response &&
response . message &&
response . message . statusCode === HttpCodes . Unauthorized ) {
let authenticationHandler ;
for ( const handler of this . handlers ) {
if ( handler . canHandleAuthentication ( response ) ) {
authenticationHandler = handler ;
break ;
}
}
if ( authenticationHandler ) {
return authenticationHandler . handleAuthentication ( this , info , data ) ;
}
else {
// We have received an unauthorized response but have no handlers to handle it.
// Let the response return to the caller.
return response ;
2021-11-26 01:45:10 +07:00
}
}
2022-05-30 09:04:27 +07: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 ] ;
}
}
}
// let's make the request with the new redirectUrl
info = this . _prepareRequest ( verb , parsedRedirectUrl , headers ) ;
response = yield this . requestRaw ( info , data ) ;
redirectsRemaining -- ;
2021-11-26 01:45:10 +07:00
}
2022-05-30 09:04:27 +07:00
if ( ! response . message . statusCode ||
! HttpResponseRetryCodes . includes ( response . message . statusCode ) ) {
// If not a retry code, return immediately instead of retrying
2021-11-26 01:45:10 +07:00
return response ;
}
2022-05-30 09:04:27 +07:00
numTries += 1 ;
if ( numTries < maxTries ) {
yield response . readBody ( ) ;
yield this . _performExponentialBackoff ( numTries ) ;
2021-11-26 01:45:10 +07:00
}
2022-05-30 09:04:27 +07:00
} while ( numTries < maxTries ) ;
return response ;
} ) ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07: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 ) ;
}
2021-11-26 01:45:10 +07:00
}
2022-05-30 09:04:27 +07:00
this . requestRawWithCallback ( info , data , callbackForResult ) ;
} ) ;
2021-11-26 01:45:10 +07:00
} ) ;
}
/ * *
* Raw request with callback .
* @ param info
* @ param data
* @ param onResult
* /
requestRawWithCallback ( info , data , onResult ) {
if ( typeof data === 'string' ) {
2022-05-30 09:04:27 +07:00
if ( ! info . options . headers ) {
info . options . headers = { } ;
}
2021-11-26 01:45:10 +07:00
info . options . headers [ 'Content-Length' ] = Buffer . byteLength ( data , 'utf8' ) ;
}
let callbackCalled = false ;
2022-05-30 09:04:27 +07:00
function handleResult ( err , res ) {
2021-11-26 01:45:10 +07:00
if ( ! callbackCalled ) {
callbackCalled = true ;
onResult ( err , res ) ;
}
2022-05-30 09:04:27 +07:00
}
const req = info . httpModule . request ( info . options , ( msg ) => {
const res = new HttpClientResponse ( msg ) ;
handleResult ( undefined , res ) ;
2021-11-26 01:45:10 +07:00
} ) ;
2022-05-30 09:04:27 +07:00
let socket ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07:00
handleResult ( new Error ( ` Request timeout: ${ info . options . path } ` ) ) ;
2021-11-26 01:45:10 +07:00
} ) ;
req . on ( 'error' , function ( err ) {
// err has statusCode property
// res should have headers
2022-05-30 09:04:27 +07:00
handleResult ( err ) ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07:00
const parsedUrl = new URL ( serverUrl ) ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07:00
for ( const handler of this . handlers ) {
2021-11-26 01:45:10 +07:00
handler . prepareRequest ( info . options ) ;
2022-05-30 09:04:27 +07:00
}
2021-11-26 01:45:10 +07:00
}
return info ;
}
_mergeHeaders ( headers ) {
if ( this . requestOptions && this . requestOptions . headers ) {
2022-05-30 09:04:27 +07:00
return Object . assign ( { } , lowercaseKeys ( this . requestOptions . headers ) , lowercaseKeys ( headers || { } ) ) ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07:00
const proxyUrl = pm . getProxyUrl ( parsedUrl ) ;
const useProxy = proxyUrl && proxyUrl . hostname ;
2021-11-26 01:45:10 +07:00
if ( this . _keepAlive && useProxy ) {
agent = this . _proxyAgent ;
}
if ( this . _keepAlive && ! useProxy ) {
agent = this . _agent ;
}
// if agent is already assigned use that agent.
2022-05-30 09:04:27 +07:00
if ( agent ) {
2021-11-26 01:45:10 +07:00
return agent ;
}
const usingSsl = parsedUrl . protocol === 'https:' ;
let maxSockets = 100 ;
2022-05-30 09:04:27 +07:00
if ( this . requestOptions ) {
2021-11-26 01:45:10 +07:00
maxSockets = this . requestOptions . maxSockets || http . globalAgent . maxSockets ;
}
2022-05-30 09:04:27 +07:00
// This is `useProxy` again, but we need to check `proxyURl` directly for TypeScripts's flow analysis.
if ( proxyUrl && proxyUrl . hostname ) {
2021-11-26 01:45:10 +07:00
const agentOptions = {
2022-05-30 09:04:27 +07:00
maxSockets ,
2021-11-26 01:45:10 +07:00
keepAlive : this . _keepAlive ,
2022-05-30 09:04:27 +07:00
proxy : Object . assign ( Object . assign ( { } , ( ( proxyUrl . username || proxyUrl . password ) && {
proxyAuth : ` ${ proxyUrl . username } : ${ proxyUrl . password } `
} ) ) , { host : proxyUrl . hostname , port : proxyUrl . port } )
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07:00
const options = { keepAlive : this . _keepAlive , maxSockets } ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07: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 ) ) ;
} ) ;
2021-11-26 01:45:10 +07:00
}
2022-05-30 09:04:27 +07: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 ;
}
2021-11-26 01:45:10 +07:00
}
2022-05-30 09:04:27 +07: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 ;
2021-11-26 01:45:10 +07:00
}
2022-05-30 09:04:27 +07:00
response . headers = res . message . headers ;
2021-11-26 01:45:10 +07:00
}
2022-05-30 09:04:27 +07:00
catch ( err ) {
// Invalid resource (contents not json); leaving result obj null
2021-11-26 01:45:10 +07:00
}
2022-05-30 09:04:27 +07: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 ) ;
2021-11-26 01:45:10 +07:00
}
else {
2022-05-30 09:04:27 +07:00
resolve ( response ) ;
2021-11-26 01:45:10 +07:00
}
2022-05-30 09:04:27 +07:00
} ) ) ;
2021-11-26 01:45:10 +07:00
} ) ;
}
}
exports . HttpClient = HttpClient ;
2022-05-30 09:04:27 +07:00
const lowercaseKeys = ( obj ) => Object . keys ( obj ) . reduce ( ( c , k ) => ( ( c [ k . toLowerCase ( ) ] = obj [ k ] ) , c ) , { } ) ;
//# sourceMappingURL=index.js.map
2021-11-26 01:45:10 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 9835 :
2021-11-26 01:45:10 +07:00
/***/ ( ( _ _unused _webpack _module , exports ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-05-30 09:04:27 +07:00
exports . checkBypass = exports . getProxyUrl = void 0 ;
2021-11-26 01:45:10 +07:00
function getProxyUrl ( reqUrl ) {
2022-05-30 09:04:27 +07:00
const usingSsl = reqUrl . protocol === 'https:' ;
2021-11-26 01:45:10 +07:00
if ( checkBypass ( reqUrl ) ) {
2022-05-30 09:04:27 +07:00
return undefined ;
2021-11-26 01:45:10 +07:00
}
2022-05-30 09:04:27 +07: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 ) ;
2021-11-26 01:45:10 +07:00
}
else {
2022-05-30 09:04:27 +07:00
return undefined ;
2021-11-26 01:45:10 +07:00
}
}
exports . getProxyUrl = getProxyUrl ;
function checkBypass ( reqUrl ) {
if ( ! reqUrl . hostname ) {
return false ;
}
2022-05-30 09:04:27 +07:00
const noProxy = process . env [ 'no_proxy' ] || process . env [ 'NO_PROXY' ] || '' ;
2021-11-26 01:45:10 +07: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-05-30 09:04:27 +07:00
const upperReqHosts = [ reqUrl . hostname . toUpperCase ( ) ] ;
2021-11-26 01:45:10 +07:00
if ( typeof reqPort === 'number' ) {
upperReqHosts . push ( ` ${ upperReqHosts [ 0 ] } : ${ reqPort } ` ) ;
}
// Compare request host against noproxy
2022-05-30 09:04:27 +07:00
for ( const upperNoProxyItem of noProxy
2021-11-26 01:45:10 +07:00
. split ( ',' )
. map ( x => x . trim ( ) . toUpperCase ( ) )
. filter ( x => x ) ) {
if ( upperReqHosts . some ( x => x === upperNoProxyItem ) ) {
return true ;
}
}
return false ;
}
exports . checkBypass = checkBypass ;
2022-05-30 09:04:27 +07:00
//# sourceMappingURL=proxy.js.map
2021-11-26 01:45:10 +07:00
2019-11-24 06:44:53 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 1962 :
2021-02-22 17:27:16 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2019-11-24 06:44:53 +07:00
2021-11-26 01:45:10 +07:00
"use strict" ;
2019-11-24 06:44:53 +07:00
2021-07-14 16:08:18 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
2021-04-26 16:42:09 +07: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 ( ) ) ;
} ) ;
} ;
var _a ;
2021-02-22 17:27:16 +07:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2023-04-03 11:34:23 +07:00
exports . getCmdPath = exports . tryGetExecutablePath = exports . isRooted = exports . isDirectory = exports . exists = exports . READONLY = exports . UV _FS _O _EXLOCK = exports . IS _WINDOWS = exports . unlink = exports . symlink = exports . stat = exports . rmdir = exports . rm = exports . rename = exports . readlink = exports . readdir = exports . open = exports . mkdir = exports . lstat = exports . copyFile = exports . chmod = void 0 ;
2022-08-17 18:35:01 +07:00
const fs = _ _importStar ( _ _nccwpck _require _ _ ( 7147 ) ) ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 1017 ) ) ;
2023-04-03 11:34:23 +07:00
_a = fs . promises
// export const {open} = 'fs'
, exports . chmod = _a . chmod , exports . copyFile = _a . copyFile , exports . lstat = _a . lstat , exports . mkdir = _a . mkdir , exports . open = _a . open , exports . readdir = _a . readdir , exports . readlink = _a . readlink , exports . rename = _a . rename , exports . rm = _a . rm , exports . rmdir = _a . rmdir , exports . stat = _a . stat , exports . symlink = _a . symlink , exports . unlink = _a . unlink ;
// export const {open} = 'fs'
2021-04-26 16:42:09 +07:00
exports . IS _WINDOWS = process . platform === 'win32' ;
2023-04-03 11:34:23 +07:00
// See https://github.com/nodejs/node/blob/d0153aee367422d0858105abec186da4dff0a0c5/deps/uv/include/uv/win.h#L691
exports . UV _FS _O _EXLOCK = 0x10000000 ;
exports . READONLY = fs . constants . O _RDONLY ;
2021-04-26 16:42:09 +07:00
function exists ( fsPath ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
try {
yield exports . stat ( fsPath ) ;
}
catch ( err ) {
if ( err . code === 'ENOENT' ) {
return false ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
throw err ;
}
return true ;
} ) ;
2019-12-10 06:52:33 +07:00
}
2021-04-26 16:42:09 +07:00
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 ( ) ;
} ) ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
exports . isDirectory = isDirectory ;
2021-02-22 17:27:16 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* 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 ) .
2021-02-22 17:27:16 +07:00
* /
2021-04-26 16:42:09 +07:00
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 ( '/' ) ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
exports . isRooted = isRooted ;
2021-02-22 17:27:16 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* 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 .
2021-02-22 17:27:16 +07:00
* /
2021-04-26 16:42:09 +07:00
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 '' ;
} ) ;
2019-12-10 06:52:33 +07:00
}
2021-04-26 16:42:09 +07:00
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 , '\\' ) ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
// remove redundant slashes
return p . replace ( /\/\/+/g , '/' ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
// on Mac/Linux, test the execute bit
// R W X R W X R W X
// 256 128 64 32 16 8 4 2 1
function isUnixExecutable ( stats ) {
return ( ( stats . mode & 1 ) > 0 ||
( ( stats . mode & 8 ) > 0 && stats . gid === process . getgid ( ) ) ||
( ( stats . mode & 64 ) > 0 && stats . uid === process . getuid ( ) ) ) ;
}
2021-07-14 16:08:18 +07:00
// 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 ;
2021-04-26 16:42:09 +07:00
//# sourceMappingURL=io-util.js.map
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 7351 :
2021-04-26 16:42:09 +07:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-04-26 16:42:09 +07:00
2021-07-14 16:08:18 +07:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
2021-04-26 16:42:09 +07: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 ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-07-14 16:08:18 +07:00
exports . findInPath = exports . which = exports . mkdirP = exports . rmRF = exports . mv = exports . cp = void 0 ;
2022-08-17 18:35:01 +07:00
const assert _1 = _ _nccwpck _require _ _ ( 9491 ) ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 1017 ) ) ;
const ioUtil = _ _importStar ( _ _nccwpck _require _ _ ( 1962 ) ) ;
2019-11-24 06:44:53 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* Copies a file or folder .
* Based off of shelljs - https : //github.com/shelljs/shelljs/blob/9237f66c52e5daa40458f94f9565e18e8132f5a6/src/cp.js
2019-11-24 06:44:53 +07:00
*
2021-04-26 16:42:09 +07:00
* @ param source source path
* @ param dest destination path
* @ param options optional . See CopyOptions .
2019-11-24 06:44:53 +07:00
* /
2021-04-26 16:42:09 +07:00
function cp ( source , dest , options = { } ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
2021-07-14 16:08:18 +07:00
const { force , recursive , copySourceDirectory } = readCopyOptions ( options ) ;
2021-04-26 16:42:09 +07:00
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.
2021-07-14 16:08:18 +07:00
const newDest = destStat && destStat . isDirectory ( ) && copySourceDirectory
2021-04-26 16:42:09 +07:00
? 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 ) ;
}
} ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . cp = cp ;
2019-11-24 06:44:53 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* Moves a path .
2019-11-24 06:44:53 +07:00
*
2021-04-26 16:42:09 +07:00
* @ param source source path
* @ param dest destination path
* @ param options optional . See MoveOptions .
2019-11-24 06:44:53 +07:00
* /
2021-04-26 16:42:09 +07:00
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 ) ;
} ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . mv = mv ;
2019-11-24 06:44:53 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* Remove a path recursively with force
2019-11-24 06:44:53 +07:00
*
2021-04-26 16:42:09 +07:00
* @ param inputPath path to remove
2019-11-24 06:44:53 +07:00
* /
2021-04-26 16:42:09 +07:00
function rmRF ( inputPath ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( ioUtil . IS _WINDOWS ) {
2021-07-14 16:08:18 +07:00
// 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' ) ;
}
2021-04-26 16:42:09 +07:00
}
2023-04-03 11:34:23 +07:00
try {
// note if path does not exist, error is silent
yield ioUtil . rm ( inputPath , {
force : true ,
maxRetries : 3 ,
recursive : true ,
retryDelay : 300
} ) ;
}
catch ( err ) {
throw new Error ( ` File was unable to be removed ${ err } ` ) ;
2021-04-26 16:42:09 +07:00
}
} ) ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
exports . rmRF = rmRF ;
2021-02-22 17:27:16 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* Make a directory . Creates the full path with folders in between
* Will throw if it fails
2021-02-22 17:27:16 +07:00
*
2021-04-26 16:42:09 +07:00
* @ param fsPath path to create
* @ returns Promise < void >
2021-02-22 17:27:16 +07:00
* /
2021-04-26 16:42:09 +07:00
function mkdirP ( fsPath ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
2021-07-14 16:08:18 +07:00
assert _1 . ok ( fsPath , 'a path argument must be provided' ) ;
yield ioUtil . mkdir ( fsPath , { recursive : true } ) ;
2021-04-26 16:42:09 +07:00
} ) ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
exports . mkdirP = mkdirP ;
2021-02-22 17:27:16 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* 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 .
2021-02-22 17:27:16 +07:00
*
2021-04-26 16:42:09 +07:00
* @ param tool name of the tool
* @ param check whether to check if tool exists
* @ returns Promise < string > path to tool
2021-02-22 17:27:16 +07:00
* /
2021-04-26 16:42:09 +07:00
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 '' ;
} ) ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
exports . which = which ;
2021-02-22 17:27:16 +07:00
/ * *
2021-04-26 16:42:09 +07:00
* Returns a list of all occurrences of the given tool on the system path .
2021-02-22 17:27:16 +07:00
*
2021-04-26 16:42:09 +07:00
* @ returns Promise < string [ ] > the paths of the tool
2021-02-22 17:27:16 +07:00
* /
2021-04-26 16:42:09 +07:00
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 ;
} ) ;
2019-11-24 06:44:53 +07:00
}
2021-04-26 16:42:09 +07:00
exports . findInPath = findInPath ;
function readCopyOptions ( options ) {
const force = options . force == null ? true : options . force ;
const recursive = Boolean ( options . recursive ) ;
2021-07-14 16:08:18 +07:00
const copySourceDirectory = options . copySourceDirectory == null
? true
: Boolean ( options . copySourceDirectory ) ;
return { force , recursive , copySourceDirectory } ;
2021-02-22 17:27:16 +07:00
}
2021-04-26 16:42:09 +07:00
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 ) ;
} ) ;
2021-03-17 06:18:19 +07:00
}
2021-04-26 16:42:09 +07:00
// 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
2019-11-24 06:44:53 +07:00
2023-06-12 12:25:01 +07:00
/***/ } ) ,
/***/ 4773 :
/***/ ( function ( _ _unused _webpack _module , exports ) {
( function ( global , factory ) {
true ? factory ( exports ) :
0 ;
} ) ( this , ( function ( exports ) { 'use strict' ;
/ * *
* Compare [ semver ] ( https : //semver.org/) version strings to find greater, equal or lesser.
* This library supports the full semver specification , including comparing versions with different number of digits like ` 1.0.0 ` , ` 1.0 ` , ` 1 ` , and pre - release versions like ` 1.0.0-alpha ` .
* @ param v1 - First version to compare
* @ param v2 - Second version to compare
* @ returns Numeric value compatible with the [ Array . sort ( fn ) interface ] ( https : //developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#Parameters).
* /
const compareVersions = ( v1 , v2 ) => {
// validate input and split into segments
const n1 = validateAndParse ( v1 ) ;
const n2 = validateAndParse ( v2 ) ;
// pop off the patch
const p1 = n1 . pop ( ) ;
const p2 = n2 . pop ( ) ;
// validate numbers
const r = compareSegments ( n1 , n2 ) ;
if ( r !== 0 )
return r ;
// validate pre-release
if ( p1 && p2 ) {
return compareSegments ( p1 . split ( '.' ) , p2 . split ( '.' ) ) ;
}
else if ( p1 || p2 ) {
return p1 ? - 1 : 1 ;
}
return 0 ;
} ;
/ * *
* Validate [ semver ] ( https : //semver.org/) version strings.
*
* @ param version Version number to validate
* @ returns ` true ` if the version number is a valid semver version number , ` false ` otherwise .
*
* @ example
* ` ` `
* validate ( '1.0.0-rc.1' ) ; // return true
* validate ( '1.0-rc.1' ) ; // return false
* validate ( 'foo' ) ; // return false
* ` ` `
* /
const validate = ( version ) => typeof version === 'string' && /^[v\d]/ . test ( version ) && semver . test ( version ) ;
/ * *
* Compare [ semver ] ( https : //semver.org/) version strings using the specified operator.
*
* @ param v1 First version to compare
* @ param v2 Second version to compare
* @ param operator Allowed arithmetic operator to use
* @ returns ` true ` if the comparison between the firstVersion and the secondVersion satisfies the operator , ` false ` otherwise .
*
* @ example
* ` ` `
* compare ( '10.1.8' , '10.0.4' , '>' ) ; // return true
* compare ( '10.0.1' , '10.0.1' , '=' ) ; // return true
* compare ( '10.1.1' , '10.2.2' , '<' ) ; // return true
* compare ( '10.1.1' , '10.2.2' , '<=' ) ; // return true
* compare ( '10.1.1' , '10.2.2' , '>=' ) ; // return false
* ` ` `
* /
const compare = ( v1 , v2 , operator ) => {
// validate input operator
assertValidOperator ( operator ) ;
// since result of compareVersions can only be -1 or 0 or 1
// a simple map can be used to replace switch
const res = compareVersions ( v1 , v2 ) ;
return operatorResMap [ operator ] . includes ( res ) ;
} ;
/ * *
* Match [ npm semver ] ( https : //docs.npmjs.com/cli/v6/using-npm/semver) version range.
*
* @ param version Version number to match
* @ param range Range pattern for version
* @ returns ` true ` if the version number is within the range , ` false ` otherwise .
*
* @ example
* ` ` `
* satisfies ( '1.1.0' , '^1.0.0' ) ; // return true
* satisfies ( '1.1.0' , '~1.0.0' ) ; // return false
* ` ` `
* /
const satisfies = ( version , range ) => {
// handle multiple comparators
if ( range . includes ( '||' ) ) {
return range . split ( '||' ) . some ( ( r ) => satisfies ( version , r ) ) ;
}
2023-07-02 04:04:06 +07:00
else if ( range . includes ( ' - ' ) ) {
const [ a , b ] = range . split ( ' - ' , 2 ) ;
return satisfies ( version , ` >= ${ a } <= ${ b } ` ) ;
}
2023-06-12 12:25:01 +07:00
else if ( range . includes ( ' ' ) ) {
return range
. trim ( )
. replace ( /\s{2,}/g , ' ' )
. split ( ' ' )
. every ( ( r ) => satisfies ( version , r ) ) ;
}
// if no range operator then "="
const m = range . match ( /^([<>=~^]+)/ ) ;
const op = m ? m [ 1 ] : '=' ;
// if gt/lt/eq then operator compare
if ( op !== '^' && op !== '~' )
return compare ( version , range , op ) ;
// else range of either "~" or "^" is assumed
const [ v1 , v2 , v3 , , vp ] = validateAndParse ( version ) ;
const [ r1 , r2 , r3 , , rp ] = validateAndParse ( range ) ;
const v = [ v1 , v2 , v3 ] ;
const r = [ r1 , r2 !== null && r2 !== void 0 ? r2 : 'x' , r3 !== null && r3 !== void 0 ? r3 : 'x' ] ;
// validate pre-release
if ( rp ) {
if ( ! vp )
return false ;
if ( compareSegments ( v , r ) !== 0 )
return false ;
if ( compareSegments ( vp . split ( '.' ) , rp . split ( '.' ) ) === - 1 )
return false ;
}
// first non-zero number
const nonZero = r . findIndex ( ( v ) => v !== '0' ) + 1 ;
// pointer to where segments can be >=
const i = op === '~' ? 2 : nonZero > 1 ? nonZero : 1 ;
// before pointer must be equal
if ( compareSegments ( v . slice ( 0 , i ) , r . slice ( 0 , i ) ) !== 0 )
return false ;
// after pointer must be >=
if ( compareSegments ( v . slice ( i ) , r . slice ( i ) ) === - 1 )
return false ;
return true ;
} ;
const semver = /^[v^~<>=]*?(\d+)(?:\.([x*]|\d+)(?:\.([x*]|\d+)(?:\.([x*]|\d+))?(?:-([\da-z\-]+(?:\.[\da-z\-]+)*))?(?:\+[\da-z\-]+(?:\.[\da-z\-]+)*)?)?)?$/i ;
const validateAndParse = ( version ) => {
if ( typeof version !== 'string' ) {
throw new TypeError ( 'Invalid argument expected string' ) ;
}
const match = version . match ( semver ) ;
if ( ! match ) {
throw new Error ( ` Invalid argument not valid semver (' ${ version } ' received) ` ) ;
}
match . shift ( ) ;
return match ;
} ;
const isWildcard = ( s ) => s === '*' || s === 'x' || s === 'X' ;
const tryParse = ( v ) => {
const n = parseInt ( v , 10 ) ;
return isNaN ( n ) ? v : n ;
} ;
const forceType = ( a , b ) => typeof a !== typeof b ? [ String ( a ) , String ( b ) ] : [ a , b ] ;
const compareStrings = ( a , b ) => {
if ( isWildcard ( a ) || isWildcard ( b ) )
return 0 ;
const [ ap , bp ] = forceType ( tryParse ( a ) , tryParse ( b ) ) ;
if ( ap > bp )
return 1 ;
if ( ap < bp )
return - 1 ;
return 0 ;
} ;
const compareSegments = ( a , b ) => {
for ( let i = 0 ; i < Math . max ( a . length , b . length ) ; i ++ ) {
const r = compareStrings ( a [ i ] || '0' , b [ i ] || '0' ) ;
if ( r !== 0 )
return r ;
}
return 0 ;
} ;
const operatorResMap = {
'>' : [ 1 ] ,
'>=' : [ 0 , 1 ] ,
'=' : [ 0 ] ,
'<=' : [ - 1 , 0 ] ,
'<' : [ - 1 ] ,
2023-07-02 04:04:06 +07:00
'!=' : [ - 1 , 1 ] ,
2023-06-12 12:25:01 +07:00
} ;
const allowedOperators = Object . keys ( operatorResMap ) ;
const assertValidOperator = ( op ) => {
if ( typeof op !== 'string' ) {
throw new TypeError ( ` Invalid operator type, expected string but got ${ typeof op } ` ) ;
}
if ( allowedOperators . indexOf ( op ) === - 1 ) {
throw new Error ( ` Invalid operator, expected one of ${ allowedOperators . join ( '|' ) } ` ) ;
}
} ;
exports . compare = compare ;
exports . compareVersions = compareVersions ;
exports . satisfies = satisfies ;
exports . validate = validate ;
} ) ) ;
//# sourceMappingURL=index.js.map
2019-11-24 06:44:53 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 4294 :
2021-11-26 01:45:10 +07:00
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-08-17 18:35:01 +07:00
module . exports = _ _nccwpck _require _ _ ( 4219 ) ;
2021-11-26 01:45:10 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 4219 :
2021-11-26 01:45:10 +07:00
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
2022-08-17 18:35:01 +07:00
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 ) ;
2021-11-26 01:45:10 +07:00
exports . httpOverHttp = httpOverHttp ;
exports . httpsOverHttp = httpsOverHttp ;
exports . httpOverHttps = httpOverHttps ;
exports . httpsOverHttps = httpsOverHttps ;
function httpOverHttp ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = http . request ;
return agent ;
}
function httpsOverHttp ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = http . request ;
agent . createSocket = createSecureSocket ;
agent . defaultPort = 443 ;
return agent ;
}
function httpOverHttps ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = https . request ;
return agent ;
}
function httpsOverHttps ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = https . request ;
agent . createSocket = createSecureSocket ;
agent . defaultPort = 443 ;
return agent ;
}
function TunnelingAgent ( options ) {
var self = this ;
self . options = options || { } ;
self . proxyOptions = self . options . proxy || { } ;
self . maxSockets = self . options . maxSockets || http . Agent . defaultMaxSockets ;
self . requests = [ ] ;
self . sockets = [ ] ;
self . on ( 'free' , function onFree ( socket , host , port , localAddress ) {
var options = toOptions ( host , port , localAddress ) ;
for ( var i = 0 , len = self . requests . length ; i < len ; ++ i ) {
var pending = self . requests [ i ] ;
if ( pending . host === options . host && pending . port === options . port ) {
// Detect the request to connect same origin server,
// reuse the connection.
self . requests . splice ( i , 1 ) ;
pending . request . onSocket ( socket ) ;
return ;
}
}
socket . destroy ( ) ;
self . removeSocket ( socket ) ;
} ) ;
}
util . inherits ( TunnelingAgent , events . EventEmitter ) ;
TunnelingAgent . prototype . addRequest = function addRequest ( req , host , port , localAddress ) {
var self = this ;
var options = mergeOptions ( { request : req } , self . options , toOptions ( host , port , localAddress ) ) ;
if ( self . sockets . length >= this . maxSockets ) {
// We are over limit so we'll add it to the queue.
self . requests . push ( options ) ;
return ;
}
// If we are under maxSockets create a new one.
self . createSocket ( options , function ( socket ) {
socket . on ( 'free' , onFree ) ;
socket . on ( 'close' , onCloseOrRemove ) ;
socket . on ( 'agentRemove' , onCloseOrRemove ) ;
req . onSocket ( socket ) ;
function onFree ( ) {
self . emit ( 'free' , socket , options ) ;
}
function onCloseOrRemove ( err ) {
self . removeSocket ( socket ) ;
socket . removeListener ( 'free' , onFree ) ;
socket . removeListener ( 'close' , onCloseOrRemove ) ;
socket . removeListener ( 'agentRemove' , onCloseOrRemove ) ;
}
} ) ;
} ;
TunnelingAgent . prototype . createSocket = function createSocket ( options , cb ) {
var self = this ;
var placeholder = { } ;
self . sockets . push ( placeholder ) ;
var connectOptions = mergeOptions ( { } , self . proxyOptions , {
method : 'CONNECT' ,
path : options . host + ':' + options . port ,
agent : false ,
headers : {
host : options . host + ':' + options . port
}
} ) ;
if ( options . localAddress ) {
connectOptions . localAddress = options . localAddress ;
}
if ( connectOptions . proxyAuth ) {
connectOptions . headers = connectOptions . headers || { } ;
connectOptions . headers [ 'Proxy-Authorization' ] = 'Basic ' +
new Buffer ( connectOptions . proxyAuth ) . toString ( 'base64' ) ;
}
debug ( 'making CONNECT request' ) ;
var connectReq = self . request ( connectOptions ) ;
connectReq . useChunkedEncodingByDefault = false ; // for v0.6
connectReq . once ( 'response' , onResponse ) ; // for v0.6
connectReq . once ( 'upgrade' , onUpgrade ) ; // for v0.6
connectReq . once ( 'connect' , onConnect ) ; // for v0.7 or later
connectReq . once ( 'error' , onError ) ;
connectReq . end ( ) ;
function onResponse ( res ) {
// Very hacky. This is necessary to avoid http-parser leaks.
res . upgrade = true ;
}
function onUpgrade ( res , socket , head ) {
// Hacky.
process . nextTick ( function ( ) {
onConnect ( res , socket , head ) ;
} ) ;
}
function onConnect ( res , socket , head ) {
connectReq . removeAllListeners ( ) ;
socket . removeAllListeners ( ) ;
if ( res . statusCode !== 200 ) {
debug ( 'tunneling socket could not be established, statusCode=%d' ,
res . statusCode ) ;
socket . destroy ( ) ;
var error = new Error ( 'tunneling socket could not be established, ' +
'statusCode=' + res . statusCode ) ;
error . code = 'ECONNRESET' ;
options . request . emit ( 'error' , error ) ;
self . removeSocket ( placeholder ) ;
return ;
}
if ( head . length > 0 ) {
debug ( 'got illegal response body from proxy' ) ;
socket . destroy ( ) ;
var error = new Error ( 'got illegal response body from proxy' ) ;
error . code = 'ECONNRESET' ;
options . request . emit ( 'error' , error ) ;
self . removeSocket ( placeholder ) ;
return ;
}
debug ( 'tunneling connection has established' ) ;
self . sockets [ self . sockets . indexOf ( placeholder ) ] = socket ;
return cb ( socket ) ;
}
function onError ( cause ) {
connectReq . removeAllListeners ( ) ;
debug ( 'tunneling socket could not be established, cause=%s\n' ,
cause . message , cause . stack ) ;
var error = new Error ( 'tunneling socket could not be established, ' +
'cause=' + cause . message ) ;
error . code = 'ECONNRESET' ;
options . request . emit ( 'error' , error ) ;
self . removeSocket ( placeholder ) ;
}
} ;
TunnelingAgent . prototype . removeSocket = function removeSocket ( socket ) {
var pos = this . sockets . indexOf ( socket )
if ( pos === - 1 ) {
return ;
}
this . sockets . splice ( pos , 1 ) ;
var pending = this . requests . shift ( ) ;
if ( pending ) {
// If we have pending requests and a socket gets closed a new one
// needs to be created to take over in the pool for the one that closed.
this . createSocket ( pending , function ( socket ) {
pending . request . onSocket ( socket ) ;
} ) ;
}
} ;
function createSecureSocket ( options , cb ) {
var self = this ;
TunnelingAgent . prototype . createSocket . call ( self , options , function ( socket ) {
var hostHeader = options . request . getHeader ( 'host' ) ;
var tlsOptions = mergeOptions ( { } , self . options , {
socket : socket ,
servername : hostHeader ? hostHeader . replace ( /:.*$/ , '' ) : options . host
} ) ;
// 0 is dummy port for v0.6
var secureSocket = tls . connect ( 0 , tlsOptions ) ;
self . sockets [ self . sockets . indexOf ( socket ) ] = secureSocket ;
cb ( secureSocket ) ;
} ) ;
}
function toOptions ( host , port , localAddress ) {
if ( typeof host === 'string' ) { // since v0.10
return {
host : host ,
port : port ,
localAddress : localAddress
} ;
}
return host ; // for v0.11 or later
}
function mergeOptions ( target ) {
for ( var i = 1 , len = arguments . length ; i < len ; ++ i ) {
var overrides = arguments [ i ] ;
if ( typeof overrides === 'object' ) {
var keys = Object . keys ( overrides ) ;
for ( var j = 0 , keyLen = keys . length ; j < keyLen ; ++ j ) {
var k = keys [ j ] ;
if ( overrides [ k ] !== undefined ) {
target [ k ] = overrides [ k ] ;
}
}
}
}
return target ;
}
var debug ;
if ( process . env . NODE _DEBUG && /\btunnel\b/ . test ( process . env . NODE _DEBUG ) ) {
debug = function ( ) {
var args = Array . prototype . slice . call ( arguments ) ;
if ( typeof args [ 0 ] === 'string' ) {
args [ 0 ] = 'TUNNEL: ' + args [ 0 ] ;
} else {
args . unshift ( 'TUNNEL:' ) ;
}
console . error . apply ( console , args ) ;
}
} else {
debug = function ( ) { } ;
}
exports . debug = debug ; // for test
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 5840 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
Object . defineProperty ( exports , "v1" , ( {
enumerable : true ,
get : function ( ) {
return _v . default ;
}
} ) ) ;
Object . defineProperty ( exports , "v3" , ( {
enumerable : true ,
get : function ( ) {
return _v2 . default ;
}
} ) ) ;
Object . defineProperty ( exports , "v4" , ( {
enumerable : true ,
get : function ( ) {
return _v3 . default ;
}
} ) ) ;
Object . defineProperty ( exports , "v5" , ( {
enumerable : true ,
get : function ( ) {
return _v4 . default ;
}
} ) ) ;
Object . defineProperty ( exports , "NIL" , ( {
enumerable : true ,
get : function ( ) {
return _nil . default ;
}
} ) ) ;
Object . defineProperty ( exports , "version" , ( {
enumerable : true ,
get : function ( ) {
return _version . default ;
}
} ) ) ;
Object . defineProperty ( exports , "validate" , ( {
enumerable : true ,
get : function ( ) {
return _validate . default ;
}
} ) ) ;
Object . defineProperty ( exports , "stringify" , ( {
enumerable : true ,
get : function ( ) {
return _stringify . default ;
}
} ) ) ;
Object . defineProperty ( exports , "parse" , ( {
enumerable : true ,
get : function ( ) {
return _parse . default ;
}
} ) ) ;
var _v = _interopRequireDefault ( _ _nccwpck _require _ _ ( 8628 ) ) ;
var _v2 = _interopRequireDefault ( _ _nccwpck _require _ _ ( 6409 ) ) ;
var _v3 = _interopRequireDefault ( _ _nccwpck _require _ _ ( 5122 ) ) ;
var _v4 = _interopRequireDefault ( _ _nccwpck _require _ _ ( 9120 ) ) ;
var _nil = _interopRequireDefault ( _ _nccwpck _require _ _ ( 5332 ) ) ;
var _version = _interopRequireDefault ( _ _nccwpck _require _ _ ( 1595 ) ) ;
var _validate = _interopRequireDefault ( _ _nccwpck _require _ _ ( 6900 ) ) ;
var _stringify = _interopRequireDefault ( _ _nccwpck _require _ _ ( 8950 ) ) ;
var _parse = _interopRequireDefault ( _ _nccwpck _require _ _ ( 2746 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
/***/ } ) ,
/***/ 4569 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
var _crypto = _interopRequireDefault ( _ _nccwpck _require _ _ ( 6113 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
function md5 ( bytes ) {
if ( Array . isArray ( bytes ) ) {
bytes = Buffer . from ( bytes ) ;
} else if ( typeof bytes === 'string' ) {
bytes = Buffer . from ( bytes , 'utf8' ) ;
}
return _crypto . default . createHash ( 'md5' ) . update ( bytes ) . digest ( ) ;
}
var _default = md5 ;
exports [ "default" ] = _default ;
/***/ } ) ,
/***/ 5332 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
var _default = '00000000-0000-0000-0000-000000000000' ;
exports [ "default" ] = _default ;
/***/ } ) ,
/***/ 2746 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
var _validate = _interopRequireDefault ( _ _nccwpck _require _ _ ( 6900 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
function parse ( uuid ) {
if ( ! ( 0 , _validate . default ) ( uuid ) ) {
throw TypeError ( 'Invalid UUID' ) ;
}
let v ;
const arr = new Uint8Array ( 16 ) ; // Parse ########-....-....-....-............
arr [ 0 ] = ( v = parseInt ( uuid . slice ( 0 , 8 ) , 16 ) ) >>> 24 ;
arr [ 1 ] = v >>> 16 & 0xff ;
arr [ 2 ] = v >>> 8 & 0xff ;
arr [ 3 ] = v & 0xff ; // Parse ........-####-....-....-............
arr [ 4 ] = ( v = parseInt ( uuid . slice ( 9 , 13 ) , 16 ) ) >>> 8 ;
arr [ 5 ] = v & 0xff ; // Parse ........-....-####-....-............
arr [ 6 ] = ( v = parseInt ( uuid . slice ( 14 , 18 ) , 16 ) ) >>> 8 ;
arr [ 7 ] = v & 0xff ; // Parse ........-....-....-####-............
arr [ 8 ] = ( v = parseInt ( uuid . slice ( 19 , 23 ) , 16 ) ) >>> 8 ;
arr [ 9 ] = v & 0xff ; // Parse ........-....-....-....-############
// (Use "/" to avoid 32-bit truncation when bit-shifting high-order bytes)
arr [ 10 ] = ( v = parseInt ( uuid . slice ( 24 , 36 ) , 16 ) ) / 0x10000000000 & 0xff ;
arr [ 11 ] = v / 0x100000000 & 0xff ;
arr [ 12 ] = v >>> 24 & 0xff ;
arr [ 13 ] = v >>> 16 & 0xff ;
arr [ 14 ] = v >>> 8 & 0xff ;
arr [ 15 ] = v & 0xff ;
return arr ;
}
var _default = parse ;
exports [ "default" ] = _default ;
/***/ } ) ,
/***/ 814 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
var _default = /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i ;
exports [ "default" ] = _default ;
/***/ } ) ,
/***/ 807 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = rng ;
var _crypto = _interopRequireDefault ( _ _nccwpck _require _ _ ( 6113 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
const rnds8Pool = new Uint8Array ( 256 ) ; // # of random values to pre-allocate
let poolPtr = rnds8Pool . length ;
function rng ( ) {
if ( poolPtr > rnds8Pool . length - 16 ) {
_crypto . default . randomFillSync ( rnds8Pool ) ;
poolPtr = 0 ;
}
return rnds8Pool . slice ( poolPtr , poolPtr += 16 ) ;
}
/***/ } ) ,
/***/ 5274 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
var _crypto = _interopRequireDefault ( _ _nccwpck _require _ _ ( 6113 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
function sha1 ( bytes ) {
if ( Array . isArray ( bytes ) ) {
bytes = Buffer . from ( bytes ) ;
} else if ( typeof bytes === 'string' ) {
bytes = Buffer . from ( bytes , 'utf8' ) ;
}
return _crypto . default . createHash ( 'sha1' ) . update ( bytes ) . digest ( ) ;
}
var _default = sha1 ;
exports [ "default" ] = _default ;
/***/ } ) ,
/***/ 8950 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
var _validate = _interopRequireDefault ( _ _nccwpck _require _ _ ( 6900 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
/ * *
* Convert array of 16 byte values to UUID string format of the form :
* XXXXXXXX - XXXX - XXXX - XXXX - XXXXXXXXXXXX
* /
const byteToHex = [ ] ;
for ( let i = 0 ; i < 256 ; ++ i ) {
byteToHex . push ( ( i + 0x100 ) . toString ( 16 ) . substr ( 1 ) ) ;
}
function stringify ( arr , offset = 0 ) {
// Note: Be careful editing this code! It's been tuned for performance
// and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434
const uuid = ( byteToHex [ arr [ offset + 0 ] ] + byteToHex [ arr [ offset + 1 ] ] + byteToHex [ arr [ offset + 2 ] ] + byteToHex [ arr [ offset + 3 ] ] + '-' + byteToHex [ arr [ offset + 4 ] ] + byteToHex [ arr [ offset + 5 ] ] + '-' + byteToHex [ arr [ offset + 6 ] ] + byteToHex [ arr [ offset + 7 ] ] + '-' + byteToHex [ arr [ offset + 8 ] ] + byteToHex [ arr [ offset + 9 ] ] + '-' + byteToHex [ arr [ offset + 10 ] ] + byteToHex [ arr [ offset + 11 ] ] + byteToHex [ arr [ offset + 12 ] ] + byteToHex [ arr [ offset + 13 ] ] + byteToHex [ arr [ offset + 14 ] ] + byteToHex [ arr [ offset + 15 ] ] ) . toLowerCase ( ) ; // Consistency check for valid UUID. If this throws, it's likely due to one
// of the following:
// - One or more input array values don't map to a hex octet (leading to
// "undefined" in the uuid)
// - Invalid input values for the RFC `version` or `variant` fields
if ( ! ( 0 , _validate . default ) ( uuid ) ) {
throw TypeError ( 'Stringified UUID is invalid' ) ;
}
return uuid ;
}
var _default = stringify ;
exports [ "default" ] = _default ;
/***/ } ) ,
/***/ 8628 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
var _rng = _interopRequireDefault ( _ _nccwpck _require _ _ ( 807 ) ) ;
var _stringify = _interopRequireDefault ( _ _nccwpck _require _ _ ( 8950 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
// **`v1()` - Generate time-based UUID**
//
// Inspired by https://github.com/LiosK/UUID.js
// and http://docs.python.org/library/uuid.html
let _nodeId ;
let _clockseq ; // Previous uuid creation time
let _lastMSecs = 0 ;
let _lastNSecs = 0 ; // See https://github.com/uuidjs/uuid for API details
function v1 ( options , buf , offset ) {
let i = buf && offset || 0 ;
const b = buf || new Array ( 16 ) ;
options = options || { } ;
let node = options . node || _nodeId ;
let clockseq = options . clockseq !== undefined ? options . clockseq : _clockseq ; // node and clockseq need to be initialized to random values if they're not
// specified. We do this lazily to minimize issues related to insufficient
// system entropy. See #189
if ( node == null || clockseq == null ) {
const seedBytes = options . random || ( options . rng || _rng . default ) ( ) ;
if ( node == null ) {
// Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)
node = _nodeId = [ seedBytes [ 0 ] | 0x01 , seedBytes [ 1 ] , seedBytes [ 2 ] , seedBytes [ 3 ] , seedBytes [ 4 ] , seedBytes [ 5 ] ] ;
}
if ( clockseq == null ) {
// Per 4.2.2, randomize (14 bit) clockseq
clockseq = _clockseq = ( seedBytes [ 6 ] << 8 | seedBytes [ 7 ] ) & 0x3fff ;
}
} // UUID timestamps are 100 nano-second units since the Gregorian epoch,
// (1582-10-15 00:00). JSNumbers aren't precise enough for this, so
// time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'
// (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.
let msecs = options . msecs !== undefined ? options . msecs : Date . now ( ) ; // Per 4.2.1.2, use count of uuid's generated during the current clock
// cycle to simulate higher resolution clock
let nsecs = options . nsecs !== undefined ? options . nsecs : _lastNSecs + 1 ; // Time since last uuid creation (in msecs)
const dt = msecs - _lastMSecs + ( nsecs - _lastNSecs ) / 10000 ; // Per 4.2.1.2, Bump clockseq on clock regression
if ( dt < 0 && options . clockseq === undefined ) {
clockseq = clockseq + 1 & 0x3fff ;
} // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new
// time interval
if ( ( dt < 0 || msecs > _lastMSecs ) && options . nsecs === undefined ) {
nsecs = 0 ;
} // Per 4.2.1.2 Throw error if too many uuids are requested
if ( nsecs >= 10000 ) {
throw new Error ( "uuid.v1(): Can't create more than 10M uuids/sec" ) ;
}
_lastMSecs = msecs ;
_lastNSecs = nsecs ;
_clockseq = clockseq ; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch
msecs += 12219292800000 ; // `time_low`
const tl = ( ( msecs & 0xfffffff ) * 10000 + nsecs ) % 0x100000000 ;
b [ i ++ ] = tl >>> 24 & 0xff ;
b [ i ++ ] = tl >>> 16 & 0xff ;
b [ i ++ ] = tl >>> 8 & 0xff ;
b [ i ++ ] = tl & 0xff ; // `time_mid`
const tmh = msecs / 0x100000000 * 10000 & 0xfffffff ;
b [ i ++ ] = tmh >>> 8 & 0xff ;
b [ i ++ ] = tmh & 0xff ; // `time_high_and_version`
b [ i ++ ] = tmh >>> 24 & 0xf | 0x10 ; // include version
b [ i ++ ] = tmh >>> 16 & 0xff ; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)
b [ i ++ ] = clockseq >>> 8 | 0x80 ; // `clock_seq_low`
b [ i ++ ] = clockseq & 0xff ; // `node`
for ( let n = 0 ; n < 6 ; ++ n ) {
b [ i + n ] = node [ n ] ;
}
return buf || ( 0 , _stringify . default ) ( b ) ;
}
var _default = v1 ;
exports [ "default" ] = _default ;
/***/ } ) ,
/***/ 6409 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
var _v = _interopRequireDefault ( _ _nccwpck _require _ _ ( 5998 ) ) ;
var _md = _interopRequireDefault ( _ _nccwpck _require _ _ ( 4569 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
const v3 = ( 0 , _v . default ) ( 'v3' , 0x30 , _md . default ) ;
var _default = v3 ;
exports [ "default" ] = _default ;
/***/ } ) ,
/***/ 5998 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = _default ;
exports . URL = exports . DNS = void 0 ;
var _stringify = _interopRequireDefault ( _ _nccwpck _require _ _ ( 8950 ) ) ;
var _parse = _interopRequireDefault ( _ _nccwpck _require _ _ ( 2746 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
function stringToBytes ( str ) {
str = unescape ( encodeURIComponent ( str ) ) ; // UTF8 escape
const bytes = [ ] ;
for ( let i = 0 ; i < str . length ; ++ i ) {
bytes . push ( str . charCodeAt ( i ) ) ;
}
return bytes ;
}
const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8' ;
exports . DNS = DNS ;
const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8' ;
exports . URL = URL ;
function _default ( name , version , hashfunc ) {
function generateUUID ( value , namespace , buf , offset ) {
if ( typeof value === 'string' ) {
value = stringToBytes ( value ) ;
}
if ( typeof namespace === 'string' ) {
namespace = ( 0 , _parse . default ) ( namespace ) ;
}
if ( namespace . length !== 16 ) {
throw TypeError ( 'Namespace must be array-like (16 iterable integer values, 0-255)' ) ;
} // Compute hash of namespace and value, Per 4.3
// Future: Use spread syntax when supported on all platforms, e.g. `bytes =
// hashfunc([...namespace, ... value])`
let bytes = new Uint8Array ( 16 + value . length ) ;
bytes . set ( namespace ) ;
bytes . set ( value , namespace . length ) ;
bytes = hashfunc ( bytes ) ;
bytes [ 6 ] = bytes [ 6 ] & 0x0f | version ;
bytes [ 8 ] = bytes [ 8 ] & 0x3f | 0x80 ;
if ( buf ) {
offset = offset || 0 ;
for ( let i = 0 ; i < 16 ; ++ i ) {
buf [ offset + i ] = bytes [ i ] ;
}
return buf ;
}
return ( 0 , _stringify . default ) ( bytes ) ;
} // Function#name is not settable on some platforms (#270)
try {
generateUUID . name = name ; // eslint-disable-next-line no-empty
} catch ( err ) { } // For CommonJS default export support
generateUUID . DNS = DNS ;
generateUUID . URL = URL ;
return generateUUID ;
}
/***/ } ) ,
/***/ 5122 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
var _rng = _interopRequireDefault ( _ _nccwpck _require _ _ ( 807 ) ) ;
var _stringify = _interopRequireDefault ( _ _nccwpck _require _ _ ( 8950 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
function v4 ( options , buf , offset ) {
options = options || { } ;
const rnds = options . random || ( options . rng || _rng . default ) ( ) ; // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`
rnds [ 6 ] = rnds [ 6 ] & 0x0f | 0x40 ;
rnds [ 8 ] = rnds [ 8 ] & 0x3f | 0x80 ; // Copy bytes to buffer, if provided
if ( buf ) {
offset = offset || 0 ;
for ( let i = 0 ; i < 16 ; ++ i ) {
buf [ offset + i ] = rnds [ i ] ;
}
return buf ;
}
return ( 0 , _stringify . default ) ( rnds ) ;
}
var _default = v4 ;
exports [ "default" ] = _default ;
/***/ } ) ,
/***/ 9120 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
var _v = _interopRequireDefault ( _ _nccwpck _require _ _ ( 5998 ) ) ;
var _sha = _interopRequireDefault ( _ _nccwpck _require _ _ ( 5274 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
const v5 = ( 0 , _v . default ) ( 'v5' , 0x50 , _sha . default ) ;
var _default = v5 ;
exports [ "default" ] = _default ;
/***/ } ) ,
/***/ 6900 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
var _regex = _interopRequireDefault ( _ _nccwpck _require _ _ ( 814 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
function validate ( uuid ) {
return typeof uuid === 'string' && _regex . default . test ( uuid ) ;
}
var _default = validate ;
exports [ "default" ] = _default ;
/***/ } ) ,
/***/ 1595 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
var _validate = _interopRequireDefault ( _ _nccwpck _require _ _ ( 6900 ) ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
function version ( uuid ) {
if ( ! ( 0 , _validate . default ) ( uuid ) ) {
throw TypeError ( 'Invalid UUID' ) ;
}
return parseInt ( uuid . substr ( 14 , 1 ) , 16 ) ;
}
var _default = version ;
exports [ "default" ] = _default ;
/***/ } ) ,
/***/ 9491 :
2021-02-22 17:27:16 +07:00
/***/ ( ( module ) => {
2019-11-24 06:44:53 +07:00
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-08-23 14:50:03 +07:00
module . exports = require ( "assert" ) ;
2019-11-24 06:44:53 +07:00
2021-02-22 17:27:16 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 2081 :
2021-02-22 17:27:16 +07:00
/***/ ( ( module ) => {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-08-23 14:50:03 +07:00
module . exports = require ( "child_process" ) ;
2021-02-22 17:27:16 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 6113 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "crypto" ) ;
/***/ } ) ,
/***/ 2361 :
2021-02-22 17:27:16 +07:00
/***/ ( ( module ) => {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-08-23 14:50:03 +07:00
module . exports = require ( "events" ) ;
2021-02-22 17:27:16 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 7147 :
2021-02-22 17:27:16 +07:00
/***/ ( ( module ) => {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-08-23 14:50:03 +07:00
module . exports = require ( "fs" ) ;
2021-02-22 17:27:16 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 3685 :
2021-11-26 01:45:10 +07:00
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "http" ) ;
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 5687 :
2021-02-22 17:27:16 +07:00
/***/ ( ( module ) => {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-08-23 14:50:03 +07:00
module . exports = require ( "https" ) ;
2021-02-22 17:27:16 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 1808 :
2021-02-22 17:27:16 +07:00
/***/ ( ( module ) => {
2021-11-26 01:45:10 +07:00
"use strict" ;
module . exports = require ( "net" ) ;
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 2037 :
2021-11-26 01:45:10 +07:00
/***/ ( ( module ) => {
"use strict" ;
2021-08-23 14:50:03 +07:00
module . exports = require ( "os" ) ;
2021-02-22 17:27:16 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 1017 :
2021-02-22 17:27:16 +07:00
/***/ ( ( module ) => {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-08-23 14:50:03 +07:00
module . exports = require ( "path" ) ;
2021-02-22 17:27:16 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 1576 :
2021-07-14 16:08:18 +07:00
/***/ ( ( module ) => {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-08-23 14:50:03 +07:00
module . exports = require ( "string_decoder" ) ;
2021-07-14 16:08:18 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 9512 :
2021-07-14 16:08:18 +07:00
/***/ ( ( module ) => {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-08-23 14:50:03 +07:00
module . exports = require ( "timers" ) ;
2021-07-14 16:08:18 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 4404 :
2021-11-26 01:45:10 +07:00
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "tls" ) ;
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 7310 :
2021-07-05 17:42:58 +07:00
/***/ ( ( module ) => {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-08-23 14:50:03 +07:00
module . exports = require ( "url" ) ;
2021-07-05 17:42:58 +07:00
/***/ } ) ,
2022-08-17 18:35:01 +07:00
/***/ 3837 :
2021-02-22 17:27:16 +07:00
/***/ ( ( module ) => {
2021-11-26 01:45:10 +07:00
"use strict" ;
2021-08-23 14:50:03 +07:00
module . exports = require ( "util" ) ;
2019-11-24 06:44:53 +07:00
/***/ } )
2021-02-22 17:27:16 +07:00
/******/ } ) ;
/************************************************************************/
/******/ // The module cache
/******/ var _ _webpack _module _cache _ _ = { } ;
/******/
/******/ // The require function
/******/ function _ _nccwpck _require _ _ ( moduleId ) {
/******/ // Check if module is in cache
2021-04-26 16:42:09 +07:00
/******/ var cachedModule = _ _webpack _module _cache _ _ [ moduleId ] ;
/******/ if ( cachedModule !== undefined ) {
/******/ return cachedModule . exports ;
2021-02-22 17:27:16 +07:00
/******/ }
/******/ // 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 */
/******/
2021-08-23 14:50:03 +07:00
/******/ if ( typeof _ _nccwpck _require _ _ !== 'undefined' ) _ _nccwpck _require _ _ . ab = _ _dirname + "/" ;
/******/
/************************************************************************/
2021-04-26 16:42:09 +07:00
/******/
2021-02-22 17:27:16 +07:00
/******/ // startup
/******/ // Load entry module and return exports
2021-04-26 16:42:09 +07:00
/******/ // This entry module is referenced by other modules so it can't be inlined
2022-08-17 18:35:01 +07:00
/******/ var _ _webpack _exports _ _ = _ _nccwpck _require _ _ ( 9039 ) ;
2021-04-26 16:42:09 +07:00
/******/ module . exports = _ _webpack _exports _ _ ;
/******/
2021-02-22 17:27:16 +07:00
/******/ } ) ( )
;