2024-05-19 08:24:38 +02:00
/******/ ( ( ) => { // webpackBootstrap
/******/ var _ _webpack _modules _ _ = ( {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 661 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02: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 } ) ) ;
exports . action = exports . getActionParams = void 0 ;
const inputHelper _1 = _ _nccwpck _require _ _ ( 6559 ) ;
const createOctokit _1 = _ _nccwpck _require _ _ ( 8890 ) ;
exports . getActionParams = inputHelper _1 . getActionParamsFactory ( {
"inputNameSubset" : [
"owner" ,
"repo" ,
"event_type" ,
"client_payload_json" ,
"github_token"
]
} ) . getActionParams ;
function action ( _actionName , params , core ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { owner , repo , event _type , client _payload _json , github _token } = params ;
core . debug ( JSON . stringify ( { _actionName , params } ) ) ;
const octokit = createOctokit _1 . createOctokit ( { github _token } ) ;
yield octokit . repos . createDispatchEvent ( Object . assign ( { owner ,
repo ,
event _type } , ( ! ! client _payload _json ?
{ "client_payload" : JSON . parse ( client _payload _json ) } :
{ } ) ) ) ;
} ) ;
}
exports . action = action ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 8289 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02: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 _ _importDefault = ( this && this . _ _importDefault ) || function ( mod ) {
return ( mod && mod . _ _esModule ) ? mod : { "default" : mod } ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . action = exports . setOutput = exports . getActionParams = void 0 ;
const node _fetch _1 = _ _importDefault ( _ _nccwpck _require _ _ ( 467 ) ) ;
const urlJoin = _ _nccwpck _require _ _ ( 2821 ) ;
const outputHelper _1 = _ _nccwpck _require _ _ ( 3627 ) ;
const NpmModuleVersion _1 = _ _nccwpck _require _ _ ( 3294 ) ;
const inputHelper _1 = _ _nccwpck _require _ _ ( 6559 ) ;
exports . getActionParams = inputHelper _1 . getActionParamsFactory ( {
"inputNameSubset" : [
"owner" ,
"repo" ,
"branch" ,
"compare_to_version"
]
} ) . getActionParams ;
exports . setOutput = outputHelper _1 . setOutputFactory ( ) . setOutput ;
function action ( _actionName , params , core ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
core . debug ( JSON . stringify ( params ) ) ;
const { owner , repo , branch , compare _to _version } = params ;
const version = yield node _fetch _1 . default ( urlJoin ( "https://raw.github.com" , owner , repo , branch , "package.json" ) )
. then ( res => res . text ( ) )
. then ( text => JSON . parse ( text ) )
. then ( ( { version } ) => version )
. catch ( ( ) => "" ) ;
core . debug ( ` Version on ${ owner } / ${ repo } # ${ branch } is ${ version } ` ) ;
return {
version ,
"compare_result" : NpmModuleVersion _1 . NpmModuleVersion . compare ( NpmModuleVersion _1 . NpmModuleVersion . parse ( version || "0.0.0" ) , NpmModuleVersion _1 . NpmModuleVersion . parse ( compare _to _version ) ) . toString ( )
} ;
} ) ;
}
exports . action = action ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 6559 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02: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-12-01 13:39:57 +01:00
} ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . getActionName = exports . getActionParamsFactory = exports . getInputDefault = exports . getInputDescription = exports . availableActions = exports . inputNames = void 0 ;
const core = _ _importStar ( _ _nccwpck _require _ _ ( 2186 ) ) ;
exports . inputNames = [
"action_name" ,
"owner" ,
"repo" ,
"event_type" ,
"client_payload_json" ,
"branch" ,
"exclude_commit_from_author_names_json" ,
"module_name" ,
"compare_to_version" ,
"input_string" ,
"search_value" ,
"replace_value" ,
"should_webhook_be_enabled" ,
"github_token"
] ;
exports . availableActions = [
"get_package_json_version" ,
"dispatch_event" ,
"update_changelog" ,
"sync_package_and_package_lock_version" ,
"setup_repo_webhook_for_deno_land_publishing" ,
"is_well_formed_and_available_module_name" ,
"string_replace" ,
"tell_if_project_uses_npm_or_yarn" ,
"is_package_json_version_upgraded" ,
"remove_dark_mode_specific_images_from_readme"
] ;
function getInputDescription ( inputName ) {
switch ( inputName ) {
case "action_name" : return [
` Action to run, one of: ` ,
exports . availableActions . map ( s => ` " ${ s } " ` ) . join ( ", " )
] . join ( "" ) ;
case "owner" : return [
"Repository owner, example: 'garronej'," ,
"github.repository_owner"
] . join ( "" ) ;
case "repo" : return [
"Repository name, example: " ,
"'evt', github.event.repository.name"
] . join ( "" ) ;
case "event_type" : return [
"see: https://developer.github.com/v3/" ,
"repos/#create-a-repository-dispatch-event"
] . join ( "" ) ;
case "client_payload_json" : return [
"Example '{\"p\":\"foo\"}' see: https://developer.github.com/v3/" ,
"repos/#create-a-repository-dispatch-event"
] . join ( "" ) ;
case "branch" : return "Example: default ( can also be a sha )" ;
case "exclude_commit_from_author_names_json" : return [
"For update_changelog, do not includes commit from user " ,
` certain committer in the CHANGELOG.md, ex: '["denoify_ci"]' `
] . join ( "" ) ;
case "module_name" : return [
` A candidate module name, Example: lodash `
] . join ( "" ) ;
case "compare_to_version" : return [
` For get_package_json_version, a version against which comparing the result ` ,
` if found version more recent than compare_to_version compare_result is 1 ` ,
` if found version is equal to compare_to_version compare_result is 0 ` ,
` if found version is older to compare_to_version compare_result -1 ` ,
` Example: 0.1.3 `
] . join ( " " ) ;
case "input_string" : return ` For string_replace, the string to replace ` ;
case "search_value" : return ` For string_replace, Example '-' ( Will be used as arg for RegExp constructor ) ` ;
case "replace_value" : return ` For string_replace, Example '_' ` ;
case "should_webhook_be_enabled" : return ` true|false, Should the create webhook be enabled, with setup_repo_webhook_for_deno_land_publishing ` ;
case "github_token" : return "GitHub Personal access token" ;
}
}
exports . getInputDescription = getInputDescription ;
function getInputDefault ( inputName ) {
switch ( inputName ) {
case "owner" : return "${{github.repository_owner}}" ;
case "repo" : return "${{github.event.repository.name}}" ;
case "branch" : return "${{ github.sha }}" ;
case "github_token" : return "${{ github.token }}" ;
case "exclude_commit_from_author_names_json" : return '["actions"]' ;
case "should_webhook_be_enabled" : return "true" ;
}
}
exports . getInputDefault = getInputDefault ;
const getInput = ( inputName ) => {
if ( exports . inputNames . indexOf ( inputName ) < 0 ) {
throw new Error ( ` ${ inputName } expected ` ) ;
}
return core . getInput ( inputName ) ;
} ;
function getActionParamsFactory ( params ) {
const { inputNameSubset } = params ;
function getActionParams ( ) {
const params = { } ;
inputNameSubset . forEach ( inputName => params [ inputName ] = getInput ( inputName ) ) ;
return params ;
}
;
return { getActionParams } ;
}
exports . getActionParamsFactory = getActionParamsFactory ;
function getActionName ( ) {
return getInput ( "action_name" ) ;
}
exports . getActionName = getActionName ;
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 1045 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02: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-12-01 13:39:57 +01:00
} ;
2024-05-19 08:24:38 +02:00
var _ _importDefault = ( this && this . _ _importDefault ) || function ( mod ) {
return ( mod && mod . _ _esModule ) ? mod : { "default" : mod } ;
2021-12-01 13:39:57 +01:00
} ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . action = exports . setOutput = exports . getActionParams = void 0 ;
const node _fetch _1 = _ _importDefault ( _ _nccwpck _require _ _ ( 467 ) ) ;
const urlJoin = _ _nccwpck _require _ _ ( 2821 ) ;
const outputHelper _1 = _ _nccwpck _require _ _ ( 3627 ) ;
const NpmModuleVersion _1 = _ _nccwpck _require _ _ ( 3294 ) ;
const inputHelper _1 = _ _nccwpck _require _ _ ( 6559 ) ;
const createOctokit _1 = _ _nccwpck _require _ _ ( 8890 ) ;
const getLatestSemVersionedTag _1 = _ _nccwpck _require _ _ ( 6396 ) ;
exports . getActionParams = inputHelper _1 . getActionParamsFactory ( {
"inputNameSubset" : [
"owner" ,
"repo" ,
"branch" ,
"github_token"
]
} ) . getActionParams ;
exports . setOutput = outputHelper _1 . setOutputFactory ( ) . setOutput ;
function action ( _actionName , params , core ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
core . debug ( JSON . stringify ( params ) ) ;
const { owner , repo , github _token } = params ;
//params.branch <- github.head_ref || github.ref
//When it's a normal branch: github.head_ref==="" and github.ref==="refs/heads/main"
//When it's a pr from: github.head_ref==="<name of the branch branch>"
const branch = params . branch . replace ( /^refs\/heads\// , "" ) ;
2024-06-20 03:11:42 +02:00
const to _version = yield getPackageJsonVersion ( { owner , repo , branch , github _token } ) ;
2024-05-19 08:24:38 +02:00
if ( to _version === undefined ) {
throw new Error ( ` No version in package.json on ${ owner } / ${ repo } # ${ branch } (or repo is private) ` ) ;
}
core . debug ( ` Version on ${ owner } / ${ repo } # ${ branch } is ${ NpmModuleVersion _1 . NpmModuleVersion . stringify ( to _version ) } ` ) ;
const octokit = createOctokit _1 . createOctokit ( { github _token } ) ;
const { getLatestSemVersionedTag } = getLatestSemVersionedTag _1 . getLatestSemVersionedTagFactory ( { octokit } ) ;
const from _version = yield ( ( ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const getLatestSemVersionedTagParam = {
owner ,
repo ,
"rcPolicy" : to _version . rc !== undefined ?
"ONLY LOOK FOR RC" : "IGNORE RC" ,
"major" : to _version . major
} ;
let wrap = yield getLatestSemVersionedTag ( getLatestSemVersionedTagParam ) ;
if ( wrap !== undefined ) {
return wrap . version ;
}
wrap = yield getLatestSemVersionedTag ( Object . assign ( Object . assign ( { } , getLatestSemVersionedTagParam ) , { "major" : undefined } ) ) ;
if ( wrap !== undefined ) {
return wrap . version ;
}
return NpmModuleVersion _1 . NpmModuleVersion . parse ( "0.0.0" ) ;
} ) ) ( ) ;
core . debug ( ` Last version was ${ NpmModuleVersion _1 . NpmModuleVersion . stringify ( from _version ) } ` ) ;
const is _upgraded _version = NpmModuleVersion _1 . NpmModuleVersion . compare ( to _version , from _version ) === 1 ? "true" : "false" ;
core . debug ( ` Is version upgraded: ${ is _upgraded _version } ` ) ;
const is _pre _release = is _upgraded _version === "false" ? "false" : to _version . rc !== undefined ? "true" : "false" ;
core . debug ( ` Is pre release: ${ is _pre _release } ` ) ;
return {
"to_version" : NpmModuleVersion _1 . NpmModuleVersion . stringify ( to _version ) ,
"from_version" : NpmModuleVersion _1 . NpmModuleVersion . stringify ( from _version ) ,
is _upgraded _version ,
is _pre _release
} ;
} ) ;
}
exports . action = action ;
//TODO: Find a way to make it work with private repo
function getPackageJsonVersion ( params ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
2024-06-20 03:11:42 +02:00
const { owner , repo , branch , github _token } = params ;
2024-06-20 03:39:57 +02:00
const version = yield node _fetch _1 . default ( ` https://api.github.com/repos/ ${ owner } / ${ repo } /contents/package.json?ref= ${ branch } ` , {
2024-06-20 03:11:42 +02:00
"headers" : {
"Authorization" : ` token ${ github _token } `
}
} )
2024-06-20 03:39:57 +02:00
. then ( ( res ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { content } = JSON . parse ( yield res . text ( ) ) ;
return Buffer . from ( content , "base64" ) . toString ( "utf-8" ) ;
} ) )
2024-05-19 08:24:38 +02:00
. then ( text => JSON . parse ( text ) )
. then ( ( { version } ) => version )
. catch ( ( ) => undefined ) ;
if ( version === undefined ) {
return undefined ;
}
return NpmModuleVersion _1 . NpmModuleVersion . parse ( version ) ;
} ) ;
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 3932 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02: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 _ _importDefault = ( this && this . _ _importDefault ) || function ( mod ) {
return ( mod && mod . _ _esModule ) ? mod : { "default" : mod } ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . action = exports . setOutput = exports . getActionParams = void 0 ;
const outputHelper _1 = _ _nccwpck _require _ _ ( 3627 ) ;
const inputHelper _1 = _ _nccwpck _require _ _ ( 6559 ) ;
const is404 _1 = _ _nccwpck _require _ _ ( 6642 ) ;
const validate _npm _package _name _1 = _ _importDefault ( _ _nccwpck _require _ _ ( 4150 ) ) ;
exports . getActionParams = inputHelper _1 . getActionParamsFactory ( {
"inputNameSubset" : [
"module_name"
]
} ) . getActionParams ;
exports . setOutput = outputHelper _1 . setOutputFactory ( ) . setOutput ;
function action ( _actionName , params , core ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { module _name } = params ;
const { validForNewPackages } = validate _npm _package _name _1 . default ( module _name ) ;
const validForDenoPackages = validForNewPackages && module _name . indexOf ( "-" ) < 0 ;
return {
"is_valid_node_module_name" : validForNewPackages ? "true" : "false" ,
"is_available_on_npm" : ! validForNewPackages ?
"false"
:
( yield is404 _1 . is404 ( ` https://www.npmjs.com/package/ ${ module _name } ` ) ) ?
"true" : "false" ,
"is_valid_deno_module_name" : validForDenoPackages ? "true" : "false" ,
"is_available_on_deno_land" : ! validForDenoPackages ?
"false"
:
( yield is404 _1 . is404 ( ` https://deno.land/x/ ${ module _name } / ` ) ) ?
"true" : "false"
} ;
} ) ;
}
exports . action = action ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 3109 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
const core = _ _importStar ( _ _nccwpck _require _ _ ( 2186 ) ) ;
const get _package _json _version = _ _importStar ( _ _nccwpck _require _ _ ( 8289 ) ) ;
const dispatch _event = _ _importStar ( _ _nccwpck _require _ _ ( 661 ) ) ;
const sync _package _and _package _lock _version = _ _importStar ( _ _nccwpck _require _ _ ( 5768 ) ) ;
const setup _repo _webhook _for _deno _land _publishing = _ _importStar ( _ _nccwpck _require _ _ ( 3492 ) ) ;
const is _well _formed _and _available _module _name = _ _importStar ( _ _nccwpck _require _ _ ( 3932 ) ) ;
const tell _if _project _uses _npm _or _yarn = _ _importStar ( _ _nccwpck _require _ _ ( 8915 ) ) ;
const remove _dark _mode _specific _images _from _readme = _ _importStar ( _ _nccwpck _require _ _ ( 7803 ) ) ;
const string _replace = _ _importStar ( _ _nccwpck _require _ _ ( 3398 ) ) ;
const is _package _json _version _upgraded = _ _importStar ( _ _nccwpck _require _ _ ( 1045 ) ) ;
const inputHelper _1 = _ _nccwpck _require _ _ ( 6559 ) ;
const update _changelog = _ _importStar ( _ _nccwpck _require _ _ ( 9050 ) ) ;
const assert _1 = _ _nccwpck _require _ _ ( 8078 ) ;
function run ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const action _name = inputHelper _1 . getActionName ( ) ;
switch ( action _name ) {
case "get_package_json_version" :
get _package _json _version . setOutput ( yield get _package _json _version . action ( action _name , get _package _json _version . getActionParams ( ) , core ) ) ;
return null ;
case "dispatch_event" :
yield dispatch _event . action ( action _name , dispatch _event . getActionParams ( ) , core ) ;
return null ;
case "update_changelog" :
yield update _changelog . action ( action _name , update _changelog . getActionParams ( ) , core ) ;
return null ;
case "sync_package_and_package_lock_version" :
yield sync _package _and _package _lock _version . action ( action _name , sync _package _and _package _lock _version . getActionParams ( ) , core ) ;
return null ;
case "setup_repo_webhook_for_deno_land_publishing" :
setup _repo _webhook _for _deno _land _publishing . setOutput ( yield setup _repo _webhook _for _deno _land _publishing . action ( action _name , setup _repo _webhook _for _deno _land _publishing . getActionParams ( ) , core ) ) ;
return null ;
case "is_well_formed_and_available_module_name" :
is _well _formed _and _available _module _name . setOutput ( yield is _well _formed _and _available _module _name . action ( action _name , is _well _formed _and _available _module _name . getActionParams ( ) , core ) ) ;
return null ;
case "string_replace" :
string _replace . setOutput ( yield string _replace . action ( action _name , string _replace . getActionParams ( ) , core ) ) ;
return null ;
case "tell_if_project_uses_npm_or_yarn" :
tell _if _project _uses _npm _or _yarn . setOutput ( yield tell _if _project _uses _npm _or _yarn . action ( action _name , tell _if _project _uses _npm _or _yarn . getActionParams ( ) , core ) ) ;
return null ;
case "is_package_json_version_upgraded" :
is _package _json _version _upgraded . setOutput ( yield is _package _json _version _upgraded . action ( action _name , is _package _json _version _upgraded . getActionParams ( ) , core ) ) ;
return null ;
case "remove_dark_mode_specific_images_from_readme" :
yield remove _dark _mode _specific _images _from _readme . action ( action _name ) ;
return null ;
}
assert _1 . assert ( false ) ;
} ) ;
}
( ( ) => _ _awaiter ( void 0 , void 0 , void 0 , function * ( ) {
try {
yield run ( ) ;
}
catch ( error ) {
core . setFailed ( String ( error ) ) ;
}
} ) ) ( ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 3627 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02: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-12-01 13:39:57 +01:00
} ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . setOutputFactory = exports . getOutputDescription = exports . outputNames = void 0 ;
const core = _ _importStar ( _ _nccwpck _require _ _ ( 2186 ) ) ;
const objectKeys _1 = _ _nccwpck _require _ _ ( 3440 ) ;
exports . outputNames = [
"version" ,
"is_valid_node_module_name" ,
"is_valid_deno_module_name" ,
"is_available_on_npm" ,
"is_available_on_deno_land" ,
"was_already_published" ,
"compare_result" ,
"replace_result" ,
"was_hook_created" ,
"npm_or_yarn" ,
"from_version" ,
"to_version" ,
"is_upgraded_version" ,
"is_pre_release"
] ;
function getOutputDescription ( inputName ) {
switch ( inputName ) {
case "version" : return "Output of get_package_json_version" ;
case "is_valid_node_module_name" : return "true|false" ;
case "is_valid_deno_module_name" : return "true|false" ;
case "is_available_on_npm" : return "true|false" ;
case "is_available_on_deno_land" : return "true|false" ;
case "was_already_published" : return "true|false" ;
case "compare_result" : return "1|0|-1" ;
case "replace_result" : return "Output of string_replace" ;
case "was_hook_created" : return "true|false" ;
case "npm_or_yarn" : return "npm|yarn" ;
case "from_version" : return "Output of is_package_json_version_upgraded, string" ;
case "to_version" : return "Output of is_package_json_version_upgraded, string" ;
case "is_upgraded_version" : return "Output of is_package_json_version_upgraded, true|false" ;
case "is_pre_release" : return "Output of is_package_json_version_upgraded, true|false" ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
}
exports . getOutputDescription = getOutputDescription ;
function setOutputFactory ( ) {
function setOutput ( outputs ) {
objectKeys _1 . objectKeys ( outputs )
. forEach ( outputName => core . setOutput ( outputName , outputs [ outputName ] ) ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
;
return { setOutput } ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
exports . setOutputFactory = setOutputFactory ;
2021-12-01 13:39:57 +01:00
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 7803 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02: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 ) ;
2021-12-01 13:39:57 +01:00
return result ;
2024-05-19 08:24:38 +02: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 } ) ) ;
exports . removeDarkModeSpecificImageFromReadme = exports . action = void 0 ;
const fs = _ _importStar ( _ _nccwpck _require _ _ ( 7147 ) ) ;
function action ( _actionName ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
fs . writeFileSync ( "README.md" , Buffer . from ( removeDarkModeSpecificImageFromReadme ( fs . readFileSync ( "README.md" ) . toString ( "utf8" ) ) , "utf8" ) ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
exports . action = action ;
function removeDarkModeSpecificImageFromReadme ( readmeRawContent ) {
return readmeRawContent
. replace ( /^!\[[^\]]*\]\([^#]+#gh-dark-mode-only\)/gm , "" ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
exports . removeDarkModeSpecificImageFromReadme = removeDarkModeSpecificImageFromReadme ;
2022-10-12 17:48:05 +02:00
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 3492 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
"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 ( ) ) ;
} ) ;
} ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . action = exports . setOutput = exports . getActionParams = void 0 ;
const outputHelper _1 = _ _nccwpck _require _ _ ( 3627 ) ;
const inputHelper _1 = _ _nccwpck _require _ _ ( 6559 ) ;
const createOctokit _1 = _ _nccwpck _require _ _ ( 8890 ) ;
exports . getActionParams = inputHelper _1 . getActionParamsFactory ( {
"inputNameSubset" : [
"owner" ,
"repo" ,
"should_webhook_be_enabled" ,
"github_token"
]
} ) . getActionParams ;
exports . setOutput = outputHelper _1 . setOutputFactory ( ) . setOutput ;
function action ( _actionName , params , core ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { owner , repo , should _webhook _be _enabled , github _token } = params ;
const octokit = createOctokit _1 . createOctokit ( { github _token } ) ;
try {
yield octokit . repos . createWebhook ( {
owner ,
repo ,
"active" : should _webhook _be _enabled === "true" ,
"events" : [ "create" ] ,
"config" : {
"url" : ` https://api.deno.land/webhook/gh/ ${ repo } ?subdir=deno_dist%252F ` ,
"content_type" : "json"
}
} ) ;
}
catch ( _a ) {
return { "was_hook_created" : "false" } ;
}
return { "was_hook_created" : "true" } ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
exports . action = action ;
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 3398 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02: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-12-01 13:39:57 +01:00
} ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . action = exports . setOutput = exports . getActionParams = void 0 ;
const outputHelper _1 = _ _nccwpck _require _ _ ( 3627 ) ;
const inputHelper _1 = _ _nccwpck _require _ _ ( 6559 ) ;
exports . getActionParams = inputHelper _1 . getActionParamsFactory ( {
"inputNameSubset" : [
"input_string" ,
"search_value" ,
"replace_value"
]
} ) . getActionParams ;
exports . setOutput = outputHelper _1 . setOutputFactory ( ) . setOutput ;
function action ( _actionName , params , core ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
core . debug ( JSON . stringify ( params ) ) ;
const { input _string , search _value , replace _value } = params ;
return {
"replace_result" : input _string . replace ( new RegExp ( search _value , "g" ) , replace _value )
} ;
} ) ;
}
exports . action = action ;
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 5768 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . action = exports . getActionParams = void 0 ;
const inputHelper _1 = _ _nccwpck _require _ _ ( 6559 ) ;
const st = _ _importStar ( _ _nccwpck _require _ _ ( 8804 ) ) ;
const fs = _ _importStar ( _ _nccwpck _require _ _ ( 7147 ) ) ;
const gitCommit _1 = _ _nccwpck _require _ _ ( 4191 ) ;
exports . getActionParams = inputHelper _1 . getActionParamsFactory ( {
"inputNameSubset" : [
"owner" ,
"repo" ,
"branch" ,
"github_token"
]
} ) . getActionParams ;
function action ( _actionName , params , core ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
core . debug ( JSON . stringify ( params ) ) ;
const { owner , repo , branch , github _token } = params ;
yield gitCommit _1 . gitCommit ( {
owner ,
repo ,
github _token ,
"commitAuthorEmail" : "actions@github.com" ,
"performChanges" : ( ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
yield st . exec ( ` git checkout ${ branch } ` ) ;
const { version } = JSON . parse ( fs . readFileSync ( "package.json" )
. toString ( "utf8" ) ) ;
if ( ! fs . existsSync ( "package-lock.json" ) ) {
core . debug ( ` No package-lock.json tracked by ${ owner } / ${ repo } # ${ branch } ` ) ;
return { "commit" : false } ;
}
const packageLockJsonRaw = fs . readFileSync ( "package-lock.json" )
. toString ( "utf8" ) ;
const packageLockJsonParsed = JSON . parse ( packageLockJsonRaw ) ;
if ( packageLockJsonParsed . version === version ) {
core . debug ( "Nothing to do, version in package.json and package-lock.json are the same" ) ;
return { "commit" : false } ;
}
fs . writeFileSync ( "package-lock.json" , Buffer . from ( JSON . stringify ( ( ( ) => {
packageLockJsonParsed . version = version ;
packageLockJsonParsed . packages [ "" ] . version = version ;
return packageLockJsonParsed ;
} ) ( ) , null , packageLockJsonRaw
. replace ( /\t/g , " " )
. match ( /^(\s*)\"version\"/m ) [ 1 ] . length ) + packageLockJsonRaw . match ( /}([\r\n]*)$/ ) [ 1 ] , "utf8" ) ) ;
return {
"commit" : true ,
"addAll" : false ,
"message" : "Sync package.json and package.lock version"
} ;
} )
} ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
exports . action = action ;
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 8915 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
"use strict" ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
var _ _importDefault = ( this && this . _ _importDefault ) || function ( mod ) {
return ( mod && mod . _ _esModule ) ? mod : { "default" : mod } ;
} ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-12-01 13:39:57 +01:00
exports . action = exports . setOutput = exports . getActionParams = void 0 ;
2024-05-19 08:24:38 +02:00
const node _fetch _1 = _ _importDefault ( _ _nccwpck _require _ _ ( 467 ) ) ;
const urlJoin = _ _nccwpck _require _ _ ( 2821 ) ;
const outputHelper _1 = _ _nccwpck _require _ _ ( 3627 ) ;
const inputHelper _1 = _ _nccwpck _require _ _ ( 6559 ) ;
2021-12-01 13:39:57 +01:00
exports . getActionParams = inputHelper _1 . getActionParamsFactory ( {
"inputNameSubset" : [
"owner" ,
"repo" ,
2024-05-19 08:24:38 +02:00
"branch"
2021-12-01 13:39:57 +01:00
]
} ) . getActionParams ;
exports . setOutput = outputHelper _1 . setOutputFactory ( ) . setOutput ;
function action ( _actionName , params , core ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
core . debug ( JSON . stringify ( params ) ) ;
2024-05-19 08:24:38 +02:00
const { owner , repo } = params ;
//params.branch <- github.head_ref || github.ref
//When it's a normal branch: github.head_ref==="" and github.ref==="refs/heads/main"
//When it's a pr from: github.head_ref==="<name of the branch branch>"
const branch = params . branch . replace ( /^refs\/heads\// , "" ) ;
const npm _or _yarn = yield node _fetch _1 . default ( urlJoin ( "https://raw.github.com" , owner , repo , branch , "yarn.lock" ) ) . then ( res => res . status === 404 ? "npm" : "yarn" ) ;
core . debug ( ` Version on ${ owner } / ${ repo } # ${ branch } is using ${ npm _or _yarn } ` ) ;
return { npm _or _yarn } ;
2021-12-01 13:39:57 +01:00
} ) ;
}
exports . action = action ;
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 3294 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . NpmModuleVersion = void 0 ;
var NpmModuleVersion ;
( function ( NpmModuleVersion ) {
function parse ( versionStr ) {
const match = versionStr . match ( /^([0-9]+)\.([0-9]+)\.([0-9]+)(?:-rc.([0-9]+))?$/ ) ;
if ( ! match ) {
throw new Error ( ` ${ versionStr } is not a valid NPM version ` ) ;
}
return Object . assign ( { "major" : parseInt ( match [ 1 ] ) , "minor" : parseInt ( match [ 2 ] ) , "patch" : parseInt ( match [ 3 ] ) } , ( ( ) => {
const str = match [ 4 ] ;
return str === undefined ?
{ } :
{ "rc" : parseInt ( str ) } ;
} ) ( ) ) ;
}
NpmModuleVersion . parse = parse ;
;
function stringify ( v ) {
return ` ${ v . major } . ${ v . minor } . ${ v . patch } ${ v . rc === undefined ? "" : ` -rc. ${ v . rc } ` } ` ;
}
NpmModuleVersion . stringify = stringify ;
/ * *
*
* v1 < v2 => - 1
* v1 === v2 => 0
* v1 > v2 => 1
*
* /
function compare ( v1 , v2 ) {
const sign = ( diff ) => diff === 0 ? 0 : ( diff < 0 ? - 1 : 1 ) ;
const noUndefined = ( n ) => n !== null && n !== void 0 ? n : Infinity ;
for ( const level of [ "major" , "minor" , "patch" , "rc" ] ) {
if ( noUndefined ( v1 [ level ] ) !== noUndefined ( v2 [ level ] ) ) {
return sign ( noUndefined ( v1 [ level ] ) - noUndefined ( v2 [ level ] ) ) ;
}
}
return 0 ;
}
NpmModuleVersion . compare = compare ;
/ *
console . log ( compare ( parse ( "3.0.0-rc.3" ) , parse ( "3.0.0" ) ) === - 1 )
console . log ( compare ( parse ( "3.0.0-rc.3" ) , parse ( "3.0.0-rc.4" ) ) === - 1 )
console . log ( compare ( parse ( "3.0.0-rc.3" ) , parse ( "4.0.0" ) ) === - 1 )
* /
function bumpType ( params ) {
const versionAhead = parse ( params . versionAheadStr ) ;
const versionBehind = parse ( params . versionBehindStr ) ;
if ( compare ( versionBehind , versionAhead ) === 1 ) {
throw new Error ( ` Version regression ${ versionBehind } -> ${ versionAhead } ` ) ;
}
for ( const level of [ "major" , "minor" , "patch" , "rc" ] ) {
if ( versionBehind [ level ] !== versionAhead [ level ] ) {
return level ;
}
}
return "same" ;
}
NpmModuleVersion . bumpType = bumpType ;
} ) ( NpmModuleVersion = exports . NpmModuleVersion || ( exports . NpmModuleVersion = { } ) ) ;
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 8890 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . createOctokit = void 0 ;
const rest _1 = _ _nccwpck _require _ _ ( 5375 ) ;
function createOctokit ( params ) {
const { github _token } = params ;
return new rest _1 . Octokit ( Object . assign ( { } , ( github _token !== "" ? { "auth" : github _token } : { } ) ) ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
exports . createOctokit = createOctokit ;
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 4191 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
"use strict" ;
2022-10-12 17:48:05 +02: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-12-01 13:39:57 +01:00
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
2022-10-12 17:48:05 +02: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-12-01 13:39:57 +01:00
return result ;
} ;
2024-05-19 08:24:38 +02: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 } ) ) ;
exports . gitCommit = void 0 ;
const st = _ _importStar ( _ _nccwpck _require _ _ ( 8804 ) ) ;
function gitCommit ( params ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { owner , repo , commitAuthorEmail , performChanges , github _token } = params ;
yield st . exec ( ` git clone https://github.com/ ${ owner } / ${ repo } ` ) ;
const cwd = process . cwd ( ) ;
process . chdir ( repo ) ;
const changesResult = yield ( ( ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
try {
return yield performChanges ( ) ;
}
catch ( error ) {
return error ;
}
} ) ) ( ) ;
if ( ! ( changesResult instanceof Error ) && changesResult . commit ) {
yield st . exec ( ` git config --local user.email " ${ commitAuthorEmail } " ` ) ;
yield st . exec ( ` git config --local user.name " ${ commitAuthorEmail . split ( "@" ) [ 0 ] } " ` ) ;
if ( changesResult . addAll ) {
yield st . exec ( ` git add -A ` ) ;
}
yield st . exec ( ` git commit -am " ${ changesResult . message } " ` ) ;
yield st . exec ( ` git push "https:// ${ owner } : ${ github _token } @github.com/ ${ owner } / ${ repo } .git" ` ) ;
}
process . chdir ( cwd ) ;
yield st . exec ( ` rm -r ${ repo } ` ) ;
if ( changesResult instanceof Error ) {
throw changesResult ;
}
2021-12-01 13:39:57 +01:00
} ) ;
}
2024-05-19 08:24:38 +02:00
exports . gitCommit = gitCommit ;
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 6642 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
var _ _importDefault = ( this && this . _ _importDefault ) || function ( mod ) {
return ( mod && mod . _ _esModule ) ? mod : { "default" : mod } ;
2021-12-01 13:39:57 +01:00
} ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . is404 = void 0 ;
const node _fetch _1 = _ _importDefault ( _ _nccwpck _require _ _ ( 467 ) ) ;
function is404 ( url ) {
return node _fetch _1 . default ( url ) . then ( ( { status } ) => status === 404 ) ;
}
exports . is404 = is404 ;
2021-12-01 13:39:57 +01:00
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 8267 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2022-10-11 16:10:23 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
2022-10-11 16:10:23 +02:00
} ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . getCommitAheadFactory = void 0 ;
const getCommonOrigin _1 = _ _nccwpck _require _ _ ( 2116 ) ;
const listCommit _1 = _ _nccwpck _require _ _ ( 5183 ) ;
/ * * T a k e t w o b r a n c h t h a t h a v e a c o m m o n o r i g i n a n d l i s t a l l t h e
* commit that have been made on the branch that is ahead since it
* has been forked from the branch that is behind .
* From the older to the newest .
* * /
function getCommitAheadFactory ( params ) {
const { octokit } = params ;
const { getCommonOrigin } = getCommonOrigin _1 . getCommonOriginFactory ( { octokit } ) ;
const { listCommit } = listCommit _1 . listCommitFactory ( { octokit } ) ;
function getCommitAhead ( params ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { owner , repo , branchBehind , branchAhead } = params ;
const { sha } = yield getCommonOrigin ( {
owner ,
repo ,
"branch1" : branchBehind ,
"branch2" : branchAhead
} ) ;
const commits = yield listCommit ( {
owner ,
repo ,
"branch" : branchAhead ,
sha
} ) ;
return { commits } ;
} ) ;
}
return { getCommitAhead } ;
}
exports . getCommitAheadFactory = getCommitAheadFactory ;
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 4530 :
/***/ ( function ( _ _unused _webpack _module , exports ) {
2022-10-12 17:48:05 +02:00
"use strict" ;
2024-05-19 08:24:38 +02: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 } ) ) ;
exports . getCommitAsyncIterableFactory = void 0 ;
const per _page = 30 ;
/** Iterate over the commits of a repo's branch */
function getCommitAsyncIterableFactory ( params ) {
const { octokit } = params ;
function getCommitAsyncIterable ( params ) {
const { owner , repo , branch } = params ;
let commits = [ ] ;
let page = 0 ;
let isLastPage = undefined ;
const getReposListCommitsResponseData = ( params ) => octokit . repos . listCommits ( {
owner ,
repo ,
per _page ,
"page" : params . page ,
"sha" : branch
} ) . then ( ( { data } ) => data ) ;
return {
[ Symbol . asyncIterator ] ( ) {
return {
"next" : ( ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( commits . length === 0 ) {
if ( isLastPage ) {
return { "done" : true , "value" : undefined } ;
}
page ++ ;
commits = yield getReposListCommitsResponseData ( { page } ) ;
if ( commits . length === 0 ) {
return { "done" : true , "value" : undefined } ;
}
isLastPage =
commits . length !== per _page ||
( yield getReposListCommitsResponseData ( { "page" : page + 1 } ) ) . length === 0 ;
}
const [ commit , ... rest ] = commits ;
commits = rest ;
return {
"value" : commit ,
"done" : false
} ;
} )
} ;
}
} ;
}
return { getCommitAsyncIterable } ;
}
exports . getCommitAsyncIterableFactory = getCommitAsyncIterableFactory ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 2116 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02: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 } ) ) ;
exports . getCommonOriginFactory = void 0 ;
const getCommitAsyncIterable _1 = _ _nccwpck _require _ _ ( 4530 ) ;
/** Return the sha of the first common commit between two branches */
function getCommonOriginFactory ( params ) {
const { octokit } = params ;
const { getCommitAsyncIterable } = getCommitAsyncIterable _1 . getCommitAsyncIterableFactory ( { octokit } ) ;
function getCommonOrigin ( params ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { owner , repo , branch1 , branch2 } = params ;
const [ commitAsyncIterable1 , commitAsyncIterable2 ] = [ branch1 , branch2 ]
. map ( branch => getCommitAsyncIterable ( { owner , repo , branch } ) ) ;
let shas1 = [ ] ;
let shas2 = [ ] ;
while ( true ) {
const [ itRes1 , itRes2 ] = yield Promise . all ( [ commitAsyncIterable1 , commitAsyncIterable2 ]
. map ( commitAsyncIterable => commitAsyncIterable [ Symbol . asyncIterator ] ( )
. next ( ) ) ) ;
let sha1 = undefined ;
if ( ! itRes1 . done ) {
sha1 = itRes1 . value . sha ;
shas1 . push ( sha1 ) ;
}
let sha2 = undefined ;
if ( ! itRes2 . done ) {
sha2 = itRes2 . value . sha ;
shas2 . push ( sha2 ) ;
}
if ( ! ! sha1 && shas2 . includes ( sha1 ) ) {
return { "sha" : sha1 } ;
}
if ( ! ! sha2 && shas1 . includes ( sha2 ) ) {
return { "sha" : sha2 } ;
}
if ( itRes1 . done && itRes2 . done ) {
throw new Error ( "No common origin" ) ;
}
}
} ) ;
}
return { getCommonOrigin } ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
exports . getCommonOriginFactory = getCommonOriginFactory ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 6396 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02: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 _ _asyncValues = ( this && this . _ _asyncValues ) || function ( o ) {
if ( ! Symbol . asyncIterator ) throw new TypeError ( "Symbol.asyncIterator is not defined." ) ;
var m = o [ Symbol . asyncIterator ] , i ;
return m ? m . call ( o ) : ( o = typeof _ _values === "function" ? _ _values ( o ) : o [ Symbol . iterator ] ( ) , i = { } , verb ( "next" ) , verb ( "throw" ) , verb ( "return" ) , i [ Symbol . asyncIterator ] = function ( ) { return this ; } , i ) ;
function verb ( n ) { i [ n ] = o [ n ] && function ( v ) { return new Promise ( function ( resolve , reject ) { v = o [ n ] ( v ) , settle ( resolve , reject , v . done , v . value ) ; } ) ; } ; }
function settle ( resolve , reject , d , v ) { Promise . resolve ( v ) . then ( function ( v ) { resolve ( { value : v , done : d } ) ; } , reject ) ; }
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . getLatestSemVersionedTagFactory = void 0 ;
const listTags _1 = _ _nccwpck _require _ _ ( 653 ) ;
const NpmModuleVersion _1 = _ _nccwpck _require _ _ ( 3294 ) ;
function getLatestSemVersionedTagFactory ( params ) {
const { octokit } = params ;
function getLatestSemVersionedTag ( params ) {
var e _1 , _a ;
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { owner , repo , rcPolicy , major } = params ;
const semVersionedTags = [ ] ;
const { listTags } = listTags _1 . listTagsFactory ( { octokit } ) ;
try {
for ( var _b = _ _asyncValues ( listTags ( { owner , repo } ) ) , _c ; _c = yield _b . next ( ) , ! _c . done ; ) {
const tag = _c . value ;
let version ;
try {
version = NpmModuleVersion _1 . NpmModuleVersion . parse ( tag . replace ( /^[vV]?/ , "" ) ) ;
if ( major !== undefined && version . major !== major ) {
continue ;
}
}
catch ( _d ) {
continue ;
}
switch ( rcPolicy ) {
case "IGNORE RC" :
if ( version . rc !== undefined ) {
continue ;
}
break ;
case "ONLY LOOK FOR RC" :
if ( version . rc === undefined ) {
continue ;
}
case "RC OR REGULAR RELEASE" :
break ;
}
semVersionedTags . push ( { tag , version } ) ;
}
}
catch ( e _1 _1 ) { e _1 = { error : e _1 _1 } ; }
finally {
try {
if ( _c && ! _c . done && ( _a = _b . return ) ) yield _a . call ( _b ) ;
}
finally { if ( e _1 ) throw e _1 . error ; }
}
return semVersionedTags
. sort ( ( { version : vX } , { version : vY } ) => NpmModuleVersion _1 . NpmModuleVersion . compare ( vY , vX ) ) [ 0 ] ;
} ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
;
return { getLatestSemVersionedTag } ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
exports . getLatestSemVersionedTagFactory = getLatestSemVersionedTagFactory ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 5183 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
2022-10-12 17:48:05 +02:00
} ;
2024-05-19 08:24:38 +02:00
var _ _asyncValues = ( this && this . _ _asyncValues ) || function ( o ) {
if ( ! Symbol . asyncIterator ) throw new TypeError ( "Symbol.asyncIterator is not defined." ) ;
var m = o [ Symbol . asyncIterator ] , i ;
return m ? m . call ( o ) : ( o = typeof _ _values === "function" ? _ _values ( o ) : o [ Symbol . iterator ] ( ) , i = { } , verb ( "next" ) , verb ( "throw" ) , verb ( "return" ) , i [ Symbol . asyncIterator ] = function ( ) { return this ; } , i ) ;
function verb ( n ) { i [ n ] = o [ n ] && function ( v ) { return new Promise ( function ( resolve , reject ) { v = o [ n ] ( v ) , settle ( resolve , reject , v . done , v . value ) ; } ) ; } ; }
function settle ( resolve , reject , d , v ) { Promise . resolve ( v ) . then ( function ( v ) { resolve ( { value : v , done : d } ) ; } , reject ) ; }
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . listCommitFactory = void 0 ;
const getCommitAsyncIterable _1 = _ _nccwpck _require _ _ ( 4530 ) ;
/ * * R e t u r n t h e l i s t o f c o m m i t s i n c e g i v e n s h a ( e x c l u d e d )
* ordered from the oldest to the newest * /
function listCommitFactory ( params ) {
const { octokit } = params ;
const { getCommitAsyncIterable } = getCommitAsyncIterable _1 . getCommitAsyncIterableFactory ( { octokit } ) ;
function listCommit ( params ) {
var e _1 , _a ;
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { owner , repo , branch , sha } = params ;
const commitAsyncIterable = getCommitAsyncIterable ( {
owner ,
repo ,
branch
} ) ;
const commits = [ ] ;
try {
for ( var commitAsyncIterable _1 = _ _asyncValues ( commitAsyncIterable ) , commitAsyncIterable _1 _1 ; commitAsyncIterable _1 _1 = yield commitAsyncIterable _1 . next ( ) , ! commitAsyncIterable _1 _1 . done ; ) {
const commit = commitAsyncIterable _1 _1 . value ;
if ( commit . sha === sha ) {
break ;
}
commits . push ( commit ) ;
}
}
catch ( e _1 _1 ) { e _1 = { error : e _1 _1 } ; }
finally {
try {
if ( commitAsyncIterable _1 _1 && ! commitAsyncIterable _1 _1 . done && ( _a = commitAsyncIterable _1 . return ) ) yield _a . call ( commitAsyncIterable _1 ) ;
}
finally { if ( e _1 ) throw e _1 . error ; }
}
return commits . reverse ( ) ;
} ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
return { listCommit } ;
}
exports . listCommitFactory = listCommitFactory ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 653 :
/***/ ( function ( _ _unused _webpack _module , exports ) {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
2022-10-12 17:48:05 +02:00
} ) ;
} ;
2024-05-19 08:24:38 +02:00
var _ _await = ( this && this . _ _await ) || function ( v ) { return this instanceof _ _await ? ( this . v = v , this ) : new _ _await ( v ) ; }
var _ _asyncGenerator = ( this && this . _ _asyncGenerator ) || function ( thisArg , _arguments , generator ) {
if ( ! Symbol . asyncIterator ) throw new TypeError ( "Symbol.asyncIterator is not defined." ) ;
var g = generator . apply ( thisArg , _arguments || [ ] ) , i , q = [ ] ;
return i = { } , verb ( "next" ) , verb ( "throw" ) , verb ( "return" ) , i [ Symbol . asyncIterator ] = function ( ) { return this ; } , i ;
function verb ( n ) { if ( g [ n ] ) i [ n ] = function ( v ) { return new Promise ( function ( a , b ) { q . push ( [ n , v , a , b ] ) > 1 || resume ( n , v ) ; } ) ; } ; }
function resume ( n , v ) { try { step ( g [ n ] ( v ) ) ; } catch ( e ) { settle ( q [ 0 ] [ 3 ] , e ) ; } }
function step ( r ) { r . value instanceof _ _await ? Promise . resolve ( r . value . v ) . then ( fulfill , reject ) : settle ( q [ 0 ] [ 2 ] , r ) ; }
function fulfill ( value ) { resume ( "next" , value ) ; }
function reject ( value ) { resume ( "throw" , value ) ; }
function settle ( f , v ) { if ( f ( v ) , q . shift ( ) , q . length ) resume ( q [ 0 ] [ 0 ] , q [ 0 ] [ 1 ] ) ; }
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . listTagsFactory = void 0 ;
const per _page = 99 ;
function listTagsFactory ( params ) {
const { octokit } = params ;
const octokit _repo _listTags = ( ( params ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return octokit . repos . listTags ( params ) ;
} ) ) ;
function listTags ( params ) {
return _ _asyncGenerator ( this , arguments , function * listTags _1 ( ) {
const { owner , repo } = params ;
let page = 1 ;
while ( true ) {
const resp = yield _ _await ( octokit _repo _listTags ( {
owner ,
repo ,
per _page ,
"page" : page ++
} ) ) ;
for ( const branch of resp . data . map ( ( { name } ) => name ) ) {
yield yield _ _await ( branch ) ;
}
if ( resp . data . length < 99 ) {
break ;
}
}
} ) ;
}
/** Returns the same "latest" tag as deno.land/x, not actually the latest though */
function getLatestTag ( params ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { owner , repo } = params ;
const itRes = yield listTags ( { owner , repo } ) . next ( ) ;
if ( itRes . done ) {
return undefined ;
}
return itRes . value ;
} ) ;
}
return { listTags , getLatestTag } ;
}
exports . listTagsFactory = listTagsFactory ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 9050 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . action = exports . getActionParams = void 0 ;
const inputHelper _1 = _ _nccwpck _require _ _ ( 6559 ) ;
const st = _ _importStar ( _ _nccwpck _require _ _ ( 8804 ) ) ;
const getCommitAhead _1 = _ _nccwpck _require _ _ ( 8267 ) ;
const get _package _json _version = _ _importStar ( _ _nccwpck _require _ _ ( 8289 ) ) ;
const fs = _ _importStar ( _ _nccwpck _require _ _ ( 7147 ) ) ;
const NpmModuleVersion _1 = _ _nccwpck _require _ _ ( 3294 ) ;
const gitCommit _1 = _ _nccwpck _require _ _ ( 4191 ) ;
const getLatestSemVersionedTag _1 = _ _nccwpck _require _ _ ( 6396 ) ;
const createOctokit _1 = _ _nccwpck _require _ _ ( 8890 ) ;
const assert _1 = _ _nccwpck _require _ _ ( 8078 ) ;
exports . getActionParams = inputHelper _1 . getActionParamsFactory ( {
"inputNameSubset" : [
"owner" ,
"repo" ,
"branch" ,
"exclude_commit_from_author_names_json" ,
"github_token"
]
} ) . getActionParams ;
function action ( _actionName , params , core ) {
var _a ;
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { owner , repo , github _token } = params ;
//params.branch <- github.head_ref || github.ref
//When it's a normal branch: github.head_ref==="" and github.ref==="refs/heads/main"
//When it's a pr from: github.head_ref==="<name of the branch branch>"
const branch = params . branch . replace ( /^refs\/heads\// , "" ) ;
core . debug ( ` params: ${ JSON . stringify ( params ) } ` ) ;
const exclude _commit _from _author _names = JSON . parse ( params . exclude _commit _from _author _names _json ) ;
const octokit = createOctokit _1 . createOctokit ( { github _token } ) ;
const { getCommitAhead } = getCommitAhead _1 . getCommitAheadFactory ( { octokit } ) ;
const { getLatestSemVersionedTag } = getLatestSemVersionedTag _1 . getLatestSemVersionedTagFactory ( { octokit } ) ;
const { tag : branchBehind } = ( _a = ( yield getLatestSemVersionedTag ( { owner , repo , "rcPolicy" : "IGNORE RC" , "major" : undefined } ) ) ) !== null && _a !== void 0 ? _a : { } ;
if ( branchBehind === undefined ) {
core . warning ( ` It's the first release, not editing the CHANGELOG.md ` ) ;
return ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
const { commits } = yield getCommitAhead ( {
owner ,
repo ,
branchBehind ,
"branchAhead" : branch
} ) . catch ( ( ) => ( { "commits" : undefined } ) ) ;
if ( commits === undefined ) {
core . warning ( ` ${ owner } / ${ repo } # ${ branchBehind } probably does not exist ( branch: ${ branch } ) ` ) ;
return ;
}
const [ branchBehindVersion , branchAheadVersion ] = yield Promise . all ( [ branchBehind , branch ]
. map ( branch => get _package _json _version . action ( "get_package_json_version" , {
owner ,
repo ,
branch ,
"compare_to_version" : "0.0.0"
} , core ) . then ( ( { version } ) => version ) ) ) ;
if ( NpmModuleVersion _1 . NpmModuleVersion . parse ( branchAheadVersion ) . rc !== undefined ) {
core . warning ( ` Version on ${ branch } is ${ branchAheadVersion } it's a release candidate, we do not update the CHANGELOG.md ` ) ;
return ;
}
const bumpType = NpmModuleVersion _1 . NpmModuleVersion . bumpType ( {
"versionAheadStr" : branchAheadVersion ,
"versionBehindStr" : branchBehindVersion || "0.0.0"
} ) ;
assert _1 . assert ( bumpType !== "rc" ) ;
if ( bumpType === "same" ) {
core . warning ( ` Version on ${ branch } and ${ branchBehind } are the same, not editing CHANGELOG.md ` ) ;
return ;
}
yield gitCommit _1 . gitCommit ( {
owner ,
repo ,
github _token ,
"commitAuthorEmail" : "actions@github.com" ,
"performChanges" : ( ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
yield st . exec ( ` git checkout ${ branch } ` ) ;
const { changelogRaw } = updateChangelog ( {
"changelogRaw" : fs . existsSync ( "CHANGELOG.md" ) ?
fs . readFileSync ( "CHANGELOG.md" )
. toString ( "utf8" )
: "" ,
"version" : branchAheadVersion ,
bumpType ,
"body" : commits
. reverse ( )
. filter ( ( { commit } ) => ! exclude _commit _from _author _names . includes ( commit . author . name ) )
. map ( ( { commit } ) => commit . message )
. filter ( message => ! /changelog/i . test ( message ) )
. filter ( message => ! /^Merge branch / . test ( message ) )
. filter ( message => ! /^GitBook: / . test ( message ) )
. map ( message => ` - ${ message } ` )
. join ( "\n" )
} ) ;
core . debug ( ` CHANGELOG.md: ${ changelogRaw } ` ) ;
fs . writeFileSync ( "CHANGELOG.md" , Buffer . from ( changelogRaw , "utf8" ) ) ;
return {
"commit" : true ,
"addAll" : true ,
"message" : ` Update changelog v ${ branchAheadVersion } `
} ;
} )
} ) ;
} ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
exports . action = action ;
function updateChangelog ( params ) {
const { body , version , bumpType } = params ;
const dateString = ( ( ) => {
const now = new Date ( ) ;
return new Date ( now . getTime ( ) - ( now . getTimezoneOffset ( ) * 60000 ) )
. toISOString ( )
. split ( "T" ) [ 0 ] ;
} ) ( ) ;
const changelogRaw = [
` ${ bumpType === "major" ? "#" : ( bumpType === "minor" ? "##" : "###" ) } ` ,
` ** ${ version } ** ( ${ dateString } ) \n \n ` ,
` ${ body } \n \n ` ,
params . changelogRaw
] . join ( "" ) ;
return { changelogRaw } ;
2022-10-12 17:48:05 +02:00
}
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 7351 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02: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 ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . issue = exports . issueCommand = void 0 ;
const os = _ _importStar ( _ _nccwpck _require _ _ ( 2037 ) ) ;
const utils _1 = _ _nccwpck _require _ _ ( 5278 ) ;
/ * *
* Commands
*
* Command Format :
* : : name key = value , key = value : : message
*
* Examples :
* : : warning : : This is the message
* : : set - env name = MY _VAR : : some value
* /
function issueCommand ( command , properties , message ) {
const cmd = new Command ( command , properties , message ) ;
process . stdout . write ( cmd . toString ( ) + os . EOL ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02: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 ;
}
toString ( ) {
let cmdStr = CMD _STRING + this . command ;
if ( this . properties && Object . keys ( this . properties ) . length > 0 ) {
cmdStr += ' ' ;
let first = true ;
for ( const key in this . properties ) {
if ( this . properties . hasOwnProperty ( key ) ) {
const val = this . properties [ key ] ;
if ( val ) {
if ( first ) {
first = false ;
}
else {
cmdStr += ',' ;
}
cmdStr += ` ${ key } = ${ escapeProperty ( val ) } ` ;
}
}
}
}
cmdStr += ` ${ CMD _STRING } ${ escapeData ( this . message ) } ` ;
return cmdStr ;
}
}
function escapeData ( s ) {
return utils _1 . toCommandValue ( s )
. replace ( /%/g , '%25' )
. replace ( /\r/g , '%0D' )
. replace ( /\n/g , '%0A' ) ;
}
function escapeProperty ( s ) {
return utils _1 . toCommandValue ( s )
. replace ( /%/g , '%25' )
. replace ( /\r/g , '%0D' )
. replace ( /\n/g , '%0A' )
. replace ( /:/g , '%3A' )
. replace ( /,/g , '%2C' ) ;
}
//# sourceMappingURL=command.js.map
2021-12-01 13:39:57 +01:00
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 2186 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2022-10-11 16:10:23 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
2022-10-11 16:10:23 +02:00
} ) ;
2024-05-19 08:24:38 +02:00
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . getIDToken = exports . getState = exports . saveState = exports . group = exports . endGroup = exports . startGroup = exports . info = exports . notice = exports . warning = exports . error = exports . debug = exports . isDebug = exports . setFailed = exports . setCommandEcho = exports . setOutput = exports . getBooleanInput = exports . getMultilineInput = exports . getInput = exports . addPath = exports . setSecret = exports . exportVariable = exports . ExitCode = void 0 ;
const command _1 = _ _nccwpck _require _ _ ( 7351 ) ;
const file _command _1 = _ _nccwpck _require _ _ ( 717 ) ;
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 ) ;
/ * *
* The code to exit an action
* /
var ExitCode ;
( function ( ExitCode ) {
/ * *
* A code indicating that the action was successful
* /
ExitCode [ ExitCode [ "Success" ] = 0 ] = "Success" ;
/ * *
* A code indicating that the action was a failure
* /
ExitCode [ ExitCode [ "Failure" ] = 1 ] = "Failure" ;
} ) ( ExitCode = exports . ExitCode || ( exports . ExitCode = { } ) ) ;
//-----------------------------------------------------------------------
// Variables
//-----------------------------------------------------------------------
/ * *
* Sets env variable for this action and future actions in the job
* @ param name the name of the variable to set
* @ param val the value of the variable . Non - string values will be converted to a string via JSON . stringify
* /
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function exportVariable ( name , val ) {
const convertedVal = utils _1 . toCommandValue ( val ) ;
process . env [ name ] = convertedVal ;
const filePath = process . env [ 'GITHUB_ENV' ] || '' ;
if ( filePath ) {
return file _command _1 . issueFileCommand ( 'ENV' , file _command _1 . prepareKeyValueMessage ( name , val ) ) ;
}
command _1 . issueCommand ( 'set-env' , { name } , convertedVal ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02: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 ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
exports . setSecret = setSecret ;
/ * *
* Prepends inputPath to the PATH ( for this action and future actions )
* @ param inputPath
* /
function addPath ( inputPath ) {
const filePath = process . env [ 'GITHUB_PATH' ] || '' ;
if ( filePath ) {
file _command _1 . issueFileCommand ( 'PATH' , inputPath ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
else {
command _1 . issueCommand ( 'add-path' , { } , inputPath ) ;
}
process . env [ 'PATH' ] = ` ${ inputPath } ${ path . delimiter } ${ process . env [ 'PATH' ] } ` ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
exports . addPath = addPath ;
/ * *
* Gets the value of an input .
* Unless trimWhitespace is set to false in InputOptions , the value is also trimmed .
* Returns an empty string if the value is not defined .
*
* @ param name name of the input to get
* @ param options optional . See InputOptions .
* @ returns string
* /
function getInput ( name , options ) {
const val = process . env [ ` INPUT_ ${ name . replace ( / /g , '_' ) . toUpperCase ( ) } ` ] || '' ;
if ( options && options . required && ! val ) {
throw new Error ( ` Input required and not supplied: ${ name } ` ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( options && options . trimWhitespace === false ) {
return val ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
return val . trim ( ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
exports . getInput = getInput ;
/ * *
* Gets the values of an multiline input . Each value is also trimmed .
*
* @ param name name of the input to get
* @ param options optional . See InputOptions .
* @ returns string [ ]
*
* /
function getMultilineInput ( name , options ) {
const inputs = getInput ( name , options )
. split ( '\n' )
. filter ( x => x !== '' ) ;
if ( options && options . trimWhitespace === false ) {
return inputs ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
return inputs . map ( input => input . trim ( ) ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
exports . getMultilineInput = getMultilineInput ;
/ * *
* Gets the input value of the boolean type in the YAML 1.2 "core schema" specification .
* Support boolean input list : ` true | True | TRUE | false | False | FALSE ` .
* The return value is also in boolean type .
* ref : https : //yaml.org/spec/1.2/spec.html#id2804923
*
* @ param name name of the input to get
* @ param options optional . See InputOptions .
* @ returns boolean
* /
function getBooleanInput ( name , options ) {
const trueValue = [ 'true' , 'True' , 'TRUE' ] ;
const falseValue = [ 'false' , 'False' , 'FALSE' ] ;
const val = getInput ( name , options ) ;
if ( trueValue . includes ( val ) )
return true ;
if ( falseValue . includes ( val ) )
2022-10-12 17:48:05 +02:00
return false ;
2024-05-19 08:24:38 +02:00
throw new TypeError ( ` Input does not meet YAML 1.2 "Core Schema" specification: ${ name } \n ` +
` Support boolean input list: \` true | True | TRUE | false | False | FALSE \` ` ) ;
}
exports . getBooleanInput = getBooleanInput ;
/ * *
* Sets the value of an output .
*
* @ param name name of the output to set
* @ param value value to store . Non - string values will be converted to a string via JSON . stringify
* /
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function setOutput ( name , value ) {
const filePath = process . env [ 'GITHUB_OUTPUT' ] || '' ;
if ( filePath ) {
return file _command _1 . issueFileCommand ( 'OUTPUT' , file _command _1 . prepareKeyValueMessage ( name , value ) ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
process . stdout . write ( os . EOL ) ;
command _1 . issueCommand ( 'set-output' , { name } , utils _1 . toCommandValue ( value ) ) ;
}
exports . setOutput = setOutput ;
/ * *
* Enables or disables the echoing of commands into stdout for the rest of the step .
* Echoing is disabled by default if ACTIONS _STEP _DEBUG is not set .
*
* /
function setCommandEcho ( enabled ) {
command _1 . issue ( 'echo' , enabled ? 'on' : 'off' ) ;
}
exports . setCommandEcho = setCommandEcho ;
//-----------------------------------------------------------------------
// Results
//-----------------------------------------------------------------------
/ * *
* Sets the action status to failed .
* When the action exits it will be with an exit code of 1
* @ param message add error issue message
* /
function setFailed ( message ) {
process . exitCode = ExitCode . Failure ;
error ( message ) ;
}
exports . setFailed = setFailed ;
//-----------------------------------------------------------------------
// Logging Commands
//-----------------------------------------------------------------------
/ * *
* Gets whether Actions Step Debug is on or not
* /
function isDebug ( ) {
return process . env [ 'RUNNER_DEBUG' ] === '1' ;
}
exports . isDebug = isDebug ;
/ * *
* Writes debug message to user log
* @ param message debug message
* /
function debug ( message ) {
command _1 . issueCommand ( 'debug' , { } , message ) ;
}
exports . debug = debug ;
/ * *
* Adds an error issue
* @ param message error issue message . Errors will be converted to string via toString ( )
* @ param properties optional properties to add to the annotation .
* /
function error ( message , properties = { } ) {
command _1 . issueCommand ( 'error' , utils _1 . toCommandProperties ( properties ) , message instanceof Error ? message . toString ( ) : message ) ;
}
exports . error = error ;
/ * *
* Adds a warning issue
* @ param message warning issue message . Errors will be converted to string via toString ( )
* @ param properties optional properties to add to the annotation .
* /
function warning ( message , properties = { } ) {
command _1 . issueCommand ( 'warning' , utils _1 . toCommandProperties ( properties ) , message instanceof Error ? message . toString ( ) : message ) ;
}
exports . warning = warning ;
/ * *
* Adds a notice issue
* @ param message notice issue message . Errors will be converted to string via toString ( )
* @ param properties optional properties to add to the annotation .
* /
function notice ( message , properties = { } ) {
command _1 . issueCommand ( 'notice' , utils _1 . toCommandProperties ( properties ) , message instanceof Error ? message . toString ( ) : message ) ;
}
exports . notice = notice ;
/ * *
* Writes info to log with console . log .
* @ param message info message
* /
function info ( message ) {
process . stdout . write ( message + os . EOL ) ;
}
exports . info = info ;
/ * *
* Begin an output group .
*
* Output until the next ` groupEnd ` will be foldable in this group
*
* @ param name The name of the output group
* /
function startGroup ( name ) {
command _1 . issue ( 'group' , name ) ;
}
exports . startGroup = startGroup ;
/ * *
* End an output group .
* /
function endGroup ( ) {
command _1 . issue ( 'endgroup' ) ;
}
exports . endGroup = endGroup ;
/ * *
* Wrap an asynchronous function call in a group .
*
* Returns the same type as the function itself .
*
* @ param name The name of the group
* @ param fn The function to wrap in the group
* /
function group ( name , fn ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
startGroup ( name ) ;
let result ;
try {
result = yield fn ( ) ;
}
finally {
endGroup ( ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
return result ;
} ) ;
}
exports . group = group ;
//-----------------------------------------------------------------------
// Wrapper action state
//-----------------------------------------------------------------------
/ * *
* Saves state for current action , the state can only be retrieved by this action ' s post job execution .
*
* @ param name name of the state to store
* @ param value value to store . Non - string values will be converted to a string via JSON . stringify
* /
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function saveState ( name , value ) {
const filePath = process . env [ 'GITHUB_STATE' ] || '' ;
if ( filePath ) {
return file _command _1 . issueFileCommand ( 'STATE' , file _command _1 . prepareKeyValueMessage ( name , value ) ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
command _1 . issueCommand ( 'save-state' , { name } , utils _1 . toCommandValue ( value ) ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
exports . saveState = saveState ;
/ * *
* Gets the value of an state set by this action ' s main execution .
*
* @ param name name of the state to get
* @ returns string
* /
function getState ( name ) {
return process . env [ ` STATE_ ${ name } ` ] || '' ;
}
exports . getState = getState ;
function getIDToken ( aud ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return yield oidc _utils _1 . OidcClient . getIDToken ( aud ) ;
} ) ;
}
exports . getIDToken = getIDToken ;
/ * *
* Summary exports
* /
var summary _1 = _ _nccwpck _require _ _ ( 1327 ) ;
Object . defineProperty ( exports , "summary" , ( { enumerable : true , get : function ( ) { return summary _1 . summary ; } } ) ) ;
/ * *
* @ deprecated use core . summary
* /
var summary _2 = _ _nccwpck _require _ _ ( 1327 ) ;
Object . defineProperty ( exports , "markdownSummary" , ( { enumerable : true , get : function ( ) { return summary _2 . markdownSummary ; } } ) ) ;
/ * *
* Path exports
* /
var path _utils _1 = _ _nccwpck _require _ _ ( 2981 ) ;
Object . defineProperty ( exports , "toPosixPath" , ( { enumerable : true , get : function ( ) { return path _utils _1 . toPosixPath ; } } ) ) ;
Object . defineProperty ( exports , "toWin32Path" , ( { enumerable : true , get : function ( ) { return path _utils _1 . toWin32Path ; } } ) ) ;
Object . defineProperty ( exports , "toPlatformPath" , ( { enumerable : true , get : function ( ) { return path _utils _1 . toPlatformPath ; } } ) ) ;
//# sourceMappingURL=core.js.map
2022-10-12 17:48:05 +02:00
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 717 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
2022-10-11 16:10:23 +02:00
"use strict" ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
// For internal use, subject to change.
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . prepareKeyValueMessage = exports . issueFileCommand = void 0 ;
// We use any as a valid input type
/* eslint-disable @typescript-eslint/no-explicit-any */
const fs = _ _importStar ( _ _nccwpck _require _ _ ( 7147 ) ) ;
const os = _ _importStar ( _ _nccwpck _require _ _ ( 2037 ) ) ;
const uuid _1 = _ _nccwpck _require _ _ ( 5840 ) ;
const utils _1 = _ _nccwpck _require _ _ ( 5278 ) ;
function issueFileCommand ( command , message ) {
const filePath = process . env [ ` GITHUB_ ${ command } ` ] ;
if ( ! filePath ) {
throw new Error ( ` Unable to find environment variable for file command ${ command } ` ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( ! fs . existsSync ( filePath ) ) {
throw new Error ( ` Missing file at path: ${ filePath } ` ) ;
}
fs . appendFileSync ( filePath , ` ${ utils _1 . toCommandValue ( message ) } ${ os . EOL } ` , {
encoding : 'utf8'
} ) ;
}
exports . issueFileCommand = issueFileCommand ;
function prepareKeyValueMessage ( key , value ) {
const delimiter = ` ghadelimiter_ ${ uuid _1 . v4 ( ) } ` ;
const convertedValue = utils _1 . toCommandValue ( value ) ;
// These should realistically never happen, but just in case someone finds a
// way to exploit uuid generation let's not allow keys or values that contain
// the delimiter.
if ( key . includes ( delimiter ) ) {
throw new Error ( ` Unexpected input: name should not contain the delimiter " ${ delimiter } " ` ) ;
}
if ( convertedValue . includes ( delimiter ) ) {
throw new Error ( ` Unexpected input: value should not contain the delimiter " ${ delimiter } " ` ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
return ` ${ key } << ${ delimiter } ${ os . EOL } ${ convertedValue } ${ os . EOL } ${ delimiter } ` ;
}
exports . prepareKeyValueMessage = prepareKeyValueMessage ;
//# sourceMappingURL=file-command.js.map
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 8041 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02: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 } ) ) ;
exports . OidcClient = void 0 ;
const http _client _1 = _ _nccwpck _require _ _ ( 6255 ) ;
const auth _1 = _ _nccwpck _require _ _ ( 5526 ) ;
const core _1 = _ _nccwpck _require _ _ ( 2186 ) ;
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 ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
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 ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
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 ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
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 ;
} ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
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 } ` ) ;
}
} ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
}
exports . OidcClient = OidcClient ;
//# sourceMappingURL=oidc-utils.js.map
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 2981 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2022-10-11 16:10:23 +02:00
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2021-12-01 13:39:57 +01:00
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 ;
} ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . toPlatformPath = exports . toWin32Path = exports . toPosixPath = void 0 ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 1017 ) ) ;
/ * *
* toPosixPath converts the given path to the posix form . On Windows , \ \ will be
* replaced with / .
*
* @ param pth . Path to transform .
* @ return string Posix path .
* /
function toPosixPath ( pth ) {
return pth . replace ( /[\\]/g , '/' ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
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
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 1327 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
"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 ( ) ) ;
} ) ;
} ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . summary = exports . markdownSummary = exports . SUMMARY _DOCS _URL = exports . SUMMARY _ENV _VAR = void 0 ;
const os _1 = _ _nccwpck _require _ _ ( 2037 ) ;
const fs _1 = _ _nccwpck _require _ _ ( 7147 ) ;
const { access , appendFile , writeFile } = fs _1 . promises ;
exports . SUMMARY _ENV _VAR = 'GITHUB_STEP_SUMMARY' ;
exports . SUMMARY _DOCS _URL = 'https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#adding-a-job-summary' ;
class Summary {
constructor ( ) {
this . _buffer = '' ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
/ * *
* 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 ;
} ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
/ * *
* 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 } > ` ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
/ * *
* 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 ( ) ;
} ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
/ * *
* 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 } ) ;
} ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
/ * *
* Returns the current summary buffer as a string
*
* @ returns { string } string of summary buffer
* /
stringify ( ) {
return this . _buffer ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
/ * *
* If the summary buffer is empty
*
* @ returns { boolen } true if the buffer is empty
* /
isEmptyBuffer ( ) {
return this . _buffer . length === 0 ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
/ * *
* Resets the summary buffer without writing to summary file
*
* @ returns { Summary } summary instance
* /
emptyBuffer ( ) {
this . _buffer = '' ;
return this ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
/ * *
* 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 ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
/ * *
* Adds the operating system - specific end - of - line marker to the buffer
*
* @ returns { Summary } summary instance
* /
addEOL ( ) {
return this . addRaw ( os _1 . EOL ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
/ * *
* 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 ( ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
/ * *
* 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 ( ) ;
2022-10-11 16:10:23 +02:00
}
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
const _summary = new Summary ( ) ;
/ * *
* @ deprecated use ` core.summary `
* /
exports . markdownSummary = _summary ;
exports . summary = _summary ;
//# sourceMappingURL=summary.js.map
2021-12-01 13:39:57 +01:00
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 5278 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
2022-10-11 16:10:23 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
// We use any as a valid input type
/* eslint-disable @typescript-eslint/no-explicit-any */
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . toCommandProperties = exports . toCommandValue = void 0 ;
/ * *
* Sanitizes an input into a string so it can be passed into issueCommand safely
* @ param input input to sanitize into a string
* /
function toCommandValue ( input ) {
if ( input === null || input === undefined ) {
return '' ;
}
else if ( typeof input === 'string' || input instanceof String ) {
return input ;
}
return JSON . stringify ( input ) ;
}
exports . toCommandValue = toCommandValue ;
/ * *
*
* @ param annotationProperties
* @ returns The command properties to send with the actual annotation command
* See IssueCommandProperties : https : //github.com/actions/runner/blob/main/src/Runner.Worker/ActionCommandManager.cs#L646
* /
function toCommandProperties ( annotationProperties ) {
if ( ! Object . keys ( annotationProperties ) . length ) {
return { } ;
}
return {
title : annotationProperties . title ,
file : annotationProperties . file ,
line : annotationProperties . startLine ,
endLine : annotationProperties . endLine ,
col : annotationProperties . startColumn ,
endColumn : annotationProperties . endColumn
} ;
}
exports . toCommandProperties = toCommandProperties ;
//# sourceMappingURL=utils.js.map
2022-10-11 16:10:23 +02:00
2022-10-21 19:34:09 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 5526 :
/***/ ( function ( _ _unused _webpack _module , exports ) {
2022-10-21 19:34:09 +02:00
"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 ( ) ) ;
} ) ;
} ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . PersonalAccessTokenCredentialHandler = exports . BearerCredentialHandler = exports . BasicCredentialHandler = void 0 ;
class BasicCredentialHandler {
constructor ( username , password ) {
this . username = username ;
this . password = password ;
}
prepareRequest ( options ) {
if ( ! options . headers ) {
throw Error ( 'The request has no headers' ) ;
}
options . headers [ 'Authorization' ] = ` Basic ${ Buffer . from ( ` ${ this . username } : ${ this . password } ` ) . toString ( 'base64' ) } ` ;
}
// This handler cannot handle 401
canHandleAuthentication ( ) {
return false ;
}
handleAuthentication ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
throw new Error ( 'not implemented' ) ;
} ) ;
}
2022-10-21 19:34:09 +02:00
}
2024-05-19 08:24:38 +02: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 ) {
if ( ! options . headers ) {
throw Error ( 'The request has no headers' ) ;
}
options . headers [ 'Authorization' ] = ` Bearer ${ this . token } ` ;
}
// This handler cannot handle 401
canHandleAuthentication ( ) {
return false ;
}
handleAuthentication ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
throw new Error ( 'not implemented' ) ;
} ) ;
}
2022-10-21 19:34:09 +02:00
}
2024-05-19 08:24:38 +02: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 ) {
if ( ! options . headers ) {
throw Error ( 'The request has no headers' ) ;
}
options . headers [ 'Authorization' ] = ` Basic ${ Buffer . from ( ` PAT: ${ this . token } ` ) . toString ( 'base64' ) } ` ;
}
// This handler cannot handle 401
canHandleAuthentication ( ) {
return false ;
}
handleAuthentication ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
throw new Error ( 'not implemented' ) ;
} ) ;
}
}
exports . PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHandler ;
//# sourceMappingURL=auth.js.map
2022-10-21 19:34:09 +02:00
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 6255 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02: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 ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . HttpClient = exports . isHttps = exports . HttpClientResponse = exports . HttpClientError = exports . getProxyUrl = exports . MediaTypes = exports . Headers = exports . HttpCodes = void 0 ;
const http = _ _importStar ( _ _nccwpck _require _ _ ( 3685 ) ) ;
const https = _ _importStar ( _ _nccwpck _require _ _ ( 5687 ) ) ;
const pm = _ _importStar ( _ _nccwpck _require _ _ ( 9835 ) ) ;
const tunnel = _ _importStar ( _ _nccwpck _require _ _ ( 4294 ) ) ;
var HttpCodes ;
( function ( HttpCodes ) {
HttpCodes [ HttpCodes [ "OK" ] = 200 ] = "OK" ;
HttpCodes [ HttpCodes [ "MultipleChoices" ] = 300 ] = "MultipleChoices" ;
HttpCodes [ HttpCodes [ "MovedPermanently" ] = 301 ] = "MovedPermanently" ;
HttpCodes [ HttpCodes [ "ResourceMoved" ] = 302 ] = "ResourceMoved" ;
HttpCodes [ HttpCodes [ "SeeOther" ] = 303 ] = "SeeOther" ;
HttpCodes [ HttpCodes [ "NotModified" ] = 304 ] = "NotModified" ;
HttpCodes [ HttpCodes [ "UseProxy" ] = 305 ] = "UseProxy" ;
HttpCodes [ HttpCodes [ "SwitchProxy" ] = 306 ] = "SwitchProxy" ;
HttpCodes [ HttpCodes [ "TemporaryRedirect" ] = 307 ] = "TemporaryRedirect" ;
HttpCodes [ HttpCodes [ "PermanentRedirect" ] = 308 ] = "PermanentRedirect" ;
HttpCodes [ HttpCodes [ "BadRequest" ] = 400 ] = "BadRequest" ;
HttpCodes [ HttpCodes [ "Unauthorized" ] = 401 ] = "Unauthorized" ;
HttpCodes [ HttpCodes [ "PaymentRequired" ] = 402 ] = "PaymentRequired" ;
HttpCodes [ HttpCodes [ "Forbidden" ] = 403 ] = "Forbidden" ;
HttpCodes [ HttpCodes [ "NotFound" ] = 404 ] = "NotFound" ;
HttpCodes [ HttpCodes [ "MethodNotAllowed" ] = 405 ] = "MethodNotAllowed" ;
HttpCodes [ HttpCodes [ "NotAcceptable" ] = 406 ] = "NotAcceptable" ;
HttpCodes [ HttpCodes [ "ProxyAuthenticationRequired" ] = 407 ] = "ProxyAuthenticationRequired" ;
HttpCodes [ HttpCodes [ "RequestTimeout" ] = 408 ] = "RequestTimeout" ;
HttpCodes [ HttpCodes [ "Conflict" ] = 409 ] = "Conflict" ;
HttpCodes [ HttpCodes [ "Gone" ] = 410 ] = "Gone" ;
HttpCodes [ HttpCodes [ "TooManyRequests" ] = 429 ] = "TooManyRequests" ;
HttpCodes [ HttpCodes [ "InternalServerError" ] = 500 ] = "InternalServerError" ;
HttpCodes [ HttpCodes [ "NotImplemented" ] = 501 ] = "NotImplemented" ;
HttpCodes [ HttpCodes [ "BadGateway" ] = 502 ] = "BadGateway" ;
HttpCodes [ HttpCodes [ "ServiceUnavailable" ] = 503 ] = "ServiceUnavailable" ;
HttpCodes [ HttpCodes [ "GatewayTimeout" ] = 504 ] = "GatewayTimeout" ;
} ) ( HttpCodes = exports . HttpCodes || ( exports . HttpCodes = { } ) ) ;
var Headers ;
( function ( Headers ) {
Headers [ "Accept" ] = "accept" ;
Headers [ "ContentType" ] = "content-type" ;
} ) ( Headers = exports . Headers || ( exports . Headers = { } ) ) ;
var MediaTypes ;
( function ( MediaTypes ) {
MediaTypes [ "ApplicationJson" ] = "application/json" ;
} ) ( MediaTypes = exports . MediaTypes || ( exports . MediaTypes = { } ) ) ;
/ * *
* Returns the proxy URL , depending upon the supplied url and proxy environment variables .
* @ param serverUrl The server URL where the request will be sent . For example , https : //api.github.com
* /
function getProxyUrl ( serverUrl ) {
const proxyUrl = pm . getProxyUrl ( new URL ( serverUrl ) ) ;
return proxyUrl ? proxyUrl . href : '' ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
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 ) ;
2021-12-01 13:39:57 +01:00
}
}
2024-05-19 08:24:38 +02:00
exports . HttpClientError = HttpClientError ;
class HttpClientResponse {
constructor ( message ) {
this . message = message ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
readBody ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return new Promise ( ( resolve ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
let output = Buffer . alloc ( 0 ) ;
this . message . on ( 'data' , ( chunk ) => {
output = Buffer . concat ( [ output , chunk ] ) ;
} ) ;
this . message . on ( 'end' , ( ) => {
resolve ( output . toString ( ) ) ;
} ) ;
} ) ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
}
2024-05-19 08:24:38 +02:00
exports . HttpClientResponse = HttpClientResponse ;
function isHttps ( requestUrl ) {
const parsedUrl = new URL ( requestUrl ) ;
return parsedUrl . protocol === 'https:' ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
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 ;
}
2021-12-01 13:39:57 +01:00
}
}
2024-05-19 08:24:38 +02:00
options ( requestUrl , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'OPTIONS' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
get ( requestUrl , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'GET' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
del ( requestUrl , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'DELETE' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
post ( requestUrl , data , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'POST' , requestUrl , data , additionalHeaders || { } ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
patch ( requestUrl , data , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'PATCH' , requestUrl , data , additionalHeaders || { } ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
put ( requestUrl , data , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'PUT' , requestUrl , data , additionalHeaders || { } ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
head ( requestUrl , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'HEAD' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
sendStream ( verb , requestUrl , stream , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( verb , requestUrl , stream , additionalHeaders ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02: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
* /
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 ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
postJson ( requestUrl , obj , additionalHeaders = { } ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const data = JSON . stringify ( obj , null , 2 ) ;
additionalHeaders [ Headers . Accept ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . Accept , MediaTypes . ApplicationJson ) ;
additionalHeaders [ Headers . ContentType ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . ContentType , MediaTypes . ApplicationJson ) ;
const res = yield this . post ( requestUrl , data , additionalHeaders ) ;
return this . _processResponse ( res , this . requestOptions ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
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 ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
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-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02: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
* /
request ( verb , requestUrl , data , headers ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( this . _disposed ) {
throw new Error ( 'Client has already been disposed.' ) ;
}
const parsedUrl = new URL ( requestUrl ) ;
let info = this . _prepareRequest ( verb , parsedUrl , headers ) ;
// Only perform retries on reads since writes may not be idempotent.
const maxTries = this . _allowRetries && RetryableHttpVerbs . includes ( verb )
? this . _maxRetries + 1
: 1 ;
let numTries = 0 ;
let response ;
do {
response = yield this . requestRaw ( info , data ) ;
// Check if it's an authentication challenge
if ( response &&
response . message &&
response . message . statusCode === HttpCodes . Unauthorized ) {
let authenticationHandler ;
for ( const handler of this . handlers ) {
if ( handler . canHandleAuthentication ( response ) ) {
authenticationHandler = handler ;
break ;
}
}
if ( authenticationHandler ) {
return authenticationHandler . handleAuthentication ( this , info , data ) ;
}
else {
// We have received an unauthorized response but have no handlers to handle it.
// Let the response return to the caller.
return response ;
}
}
let redirectsRemaining = this . _maxRedirects ;
while ( response . message . statusCode &&
HttpRedirectCodes . includes ( response . message . statusCode ) &&
this . _allowRedirects &&
redirectsRemaining > 0 ) {
const redirectUrl = response . message . headers [ 'location' ] ;
if ( ! redirectUrl ) {
// if there's no location to redirect to, we won't
break ;
}
const parsedRedirectUrl = new URL ( redirectUrl ) ;
if ( parsedUrl . protocol === 'https:' &&
parsedUrl . protocol !== parsedRedirectUrl . protocol &&
! this . _allowRedirectDowngrade ) {
throw new Error ( 'Redirect from HTTPS to HTTP protocol. This downgrade is not allowed for security reasons. If you want to allow this behavior, set the allowRedirectDowngrade option to true.' ) ;
}
// we need to finish reading the response before reassigning response
// which will leak the open socket.
yield response . readBody ( ) ;
// strip authorization header if redirected to a different hostname
if ( parsedRedirectUrl . hostname !== parsedUrl . hostname ) {
for ( const header in headers ) {
// header names are case insensitive
if ( header . toLowerCase ( ) === 'authorization' ) {
delete headers [ header ] ;
}
}
}
// let's make the request with the new redirectUrl
info = this . _prepareRequest ( verb , parsedRedirectUrl , headers ) ;
response = yield this . requestRaw ( info , data ) ;
redirectsRemaining -- ;
}
if ( ! response . message . statusCode ||
! HttpResponseRetryCodes . includes ( response . message . statusCode ) ) {
// If not a retry code, return immediately instead of retrying
return response ;
}
numTries += 1 ;
if ( numTries < maxTries ) {
yield response . readBody ( ) ;
yield this . _performExponentialBackoff ( numTries ) ;
}
} while ( numTries < maxTries ) ;
return response ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
/ * *
* Needs to be called if keepAlive is set to true in request options .
* /
dispose ( ) {
if ( this . _agent ) {
this . _agent . destroy ( ) ;
}
this . _disposed = true ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
/ * *
* Raw request .
* @ param info
* @ param data
* /
requestRaw ( info , data ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return new Promise ( ( resolve , reject ) => {
function callbackForResult ( err , res ) {
if ( err ) {
reject ( err ) ;
}
else if ( ! res ) {
// If `err` is not passed, then `res` must be passed.
reject ( new Error ( 'Unknown error' ) ) ;
}
else {
resolve ( res ) ;
}
}
this . requestRawWithCallback ( info , data , callbackForResult ) ;
} ) ;
} ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
/ * *
* Raw request with callback .
* @ param info
* @ param data
* @ param onResult
* /
requestRawWithCallback ( info , data , onResult ) {
if ( typeof data === 'string' ) {
if ( ! info . options . headers ) {
info . options . headers = { } ;
}
info . options . headers [ 'Content-Length' ] = Buffer . byteLength ( data , 'utf8' ) ;
}
let callbackCalled = false ;
function handleResult ( err , res ) {
if ( ! callbackCalled ) {
callbackCalled = true ;
onResult ( err , res ) ;
}
}
const req = info . httpModule . request ( info . options , ( msg ) => {
const res = new HttpClientResponse ( msg ) ;
handleResult ( undefined , res ) ;
} ) ;
let socket ;
req . on ( 'socket' , sock => {
socket = sock ;
} ) ;
// If we ever get disconnected, we want the socket to timeout eventually
req . setTimeout ( this . _socketTimeout || 3 * 60000 , ( ) => {
if ( socket ) {
socket . end ( ) ;
}
handleResult ( new Error ( ` Request timeout: ${ info . options . path } ` ) ) ;
} ) ;
req . on ( 'error' , function ( err ) {
// err has statusCode property
// res should have headers
handleResult ( err ) ;
} ) ;
if ( data && typeof data === 'string' ) {
req . write ( data , 'utf8' ) ;
}
if ( data && typeof data !== 'string' ) {
data . on ( 'close' , function ( ) {
req . end ( ) ;
} ) ;
data . pipe ( req ) ;
}
else {
req . end ( ) ;
}
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
/ * *
* Gets an http agent . This function is useful when you need an http agent that handles
* routing through a proxy server - depending upon the url and proxy environment variables .
* @ param serverUrl The server URL where the request will be sent . For example , https : //api.github.com
* /
getAgent ( serverUrl ) {
const parsedUrl = new URL ( serverUrl ) ;
return this . _getAgent ( parsedUrl ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
_prepareRequest ( method , requestUrl , headers ) {
const info = { } ;
info . parsedUrl = requestUrl ;
const usingSsl = info . parsedUrl . protocol === 'https:' ;
info . httpModule = usingSsl ? https : http ;
const defaultPort = usingSsl ? 443 : 80 ;
info . options = { } ;
info . options . host = info . parsedUrl . hostname ;
info . options . port = info . parsedUrl . port
? parseInt ( info . parsedUrl . port )
: defaultPort ;
info . options . path =
( info . parsedUrl . pathname || '' ) + ( info . parsedUrl . search || '' ) ;
info . options . method = method ;
info . options . headers = this . _mergeHeaders ( headers ) ;
if ( this . userAgent != null ) {
info . options . headers [ 'user-agent' ] = this . userAgent ;
}
info . options . agent = this . _getAgent ( info . parsedUrl ) ;
// gives handlers an opportunity to participate
if ( this . handlers ) {
for ( const handler of this . handlers ) {
handler . prepareRequest ( info . options ) ;
}
}
return info ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
_mergeHeaders ( headers ) {
if ( this . requestOptions && this . requestOptions . headers ) {
return Object . assign ( { } , lowercaseKeys ( this . requestOptions . headers ) , lowercaseKeys ( headers || { } ) ) ;
}
return lowercaseKeys ( headers || { } ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
_getExistingOrDefaultHeader ( additionalHeaders , header , _default ) {
let clientHeader ;
if ( this . requestOptions && this . requestOptions . headers ) {
clientHeader = lowercaseKeys ( this . requestOptions . headers ) [ header ] ;
}
return additionalHeaders [ header ] || clientHeader || _default ;
}
_getAgent ( parsedUrl ) {
let agent ;
const proxyUrl = pm . getProxyUrl ( parsedUrl ) ;
const useProxy = proxyUrl && proxyUrl . hostname ;
if ( this . _keepAlive && useProxy ) {
agent = this . _proxyAgent ;
}
if ( this . _keepAlive && ! useProxy ) {
agent = this . _agent ;
}
// if agent is already assigned use that agent.
if ( agent ) {
return agent ;
}
const usingSsl = parsedUrl . protocol === 'https:' ;
let maxSockets = 100 ;
if ( this . requestOptions ) {
maxSockets = this . requestOptions . maxSockets || http . globalAgent . maxSockets ;
}
// This is `useProxy` again, but we need to check `proxyURl` directly for TypeScripts's flow analysis.
if ( proxyUrl && proxyUrl . hostname ) {
const agentOptions = {
maxSockets ,
keepAlive : this . _keepAlive ,
proxy : Object . assign ( Object . assign ( { } , ( ( proxyUrl . username || proxyUrl . password ) && {
proxyAuth : ` ${ proxyUrl . username } : ${ proxyUrl . password } `
} ) ) , { host : proxyUrl . hostname , port : proxyUrl . port } )
} ;
let tunnelAgent ;
const overHttps = proxyUrl . protocol === 'https:' ;
if ( usingSsl ) {
tunnelAgent = overHttps ? tunnel . httpsOverHttps : tunnel . httpsOverHttp ;
}
else {
tunnelAgent = overHttps ? tunnel . httpOverHttps : tunnel . httpOverHttp ;
}
agent = tunnelAgent ( agentOptions ) ;
this . _proxyAgent = agent ;
}
// if reusing agent across request and tunneling agent isn't assigned create a new agent
if ( this . _keepAlive && ! agent ) {
const options = { keepAlive : this . _keepAlive , maxSockets } ;
agent = usingSsl ? new https . Agent ( options ) : new http . Agent ( options ) ;
this . _agent = agent ;
}
// if not using private agent and tunnel agent isn't setup then use global agent
if ( ! agent ) {
agent = usingSsl ? https . globalAgent : http . globalAgent ;
}
if ( usingSsl && this . _ignoreSslError ) {
// we don't want to set NODE_TLS_REJECT_UNAUTHORIZED=0 since that will affect request for entire process
// http.RequestOptions doesn't expose a way to modify RequestOptions.agent.options
// we have to cast it to any and change it directly
agent . options = Object . assign ( agent . options || { } , {
rejectUnauthorized : false
} ) ;
}
return agent ;
}
_performExponentialBackoff ( retryNumber ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
retryNumber = Math . min ( ExponentialBackoffCeiling , retryNumber ) ;
const ms = ExponentialBackoffTimeSlice * Math . pow ( 2 , retryNumber ) ;
return new Promise ( resolve => setTimeout ( ( ) => resolve ( ) , ms ) ) ;
} ) ;
}
_processResponse ( res , options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return new Promise ( ( resolve , reject ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const statusCode = res . message . statusCode || 0 ;
const response = {
statusCode ,
result : null ,
headers : { }
} ;
// not found leads to null obj returned
if ( statusCode === HttpCodes . NotFound ) {
resolve ( response ) ;
}
// get the result from the body
function dateTimeDeserializer ( key , value ) {
if ( typeof value === 'string' ) {
const a = new Date ( value ) ;
if ( ! isNaN ( a . valueOf ( ) ) ) {
return a ;
}
}
return value ;
}
let obj ;
let contents ;
try {
contents = yield res . readBody ( ) ;
if ( contents && contents . length > 0 ) {
if ( options && options . deserializeDates ) {
obj = JSON . parse ( contents , dateTimeDeserializer ) ;
}
else {
obj = JSON . parse ( contents ) ;
}
response . result = obj ;
}
response . headers = res . message . headers ;
}
catch ( err ) {
// Invalid resource (contents not json); leaving result obj null
}
// note that 3xx redirects are handled by the http layer.
if ( statusCode > 299 ) {
let msg ;
// if exception/error in body, attempt to get better error
if ( obj && obj . message ) {
msg = obj . message ;
}
else if ( contents && contents . length > 0 ) {
// it may be the case that the exception is in the body message as string
msg = contents ;
}
else {
msg = ` Failed request: ( ${ statusCode } ) ` ;
}
const err = new HttpClientError ( msg , statusCode ) ;
err . result = response . result ;
reject ( err ) ;
}
else {
resolve ( response ) ;
}
} ) ) ;
} ) ;
2022-10-11 16:10:23 +02:00
}
}
2024-05-19 08:24:38 +02:00
exports . HttpClient = HttpClient ;
const lowercaseKeys = ( obj ) => Object . keys ( obj ) . reduce ( ( c , k ) => ( ( c [ k . toLowerCase ( ) ] = obj [ k ] ) , c ) , { } ) ;
//# sourceMappingURL=index.js.map
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 9835 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . checkBypass = exports . getProxyUrl = void 0 ;
function getProxyUrl ( reqUrl ) {
const usingSsl = reqUrl . protocol === 'https:' ;
if ( checkBypass ( reqUrl ) ) {
return undefined ;
}
const proxyVar = ( ( ) => {
if ( usingSsl ) {
return process . env [ 'https_proxy' ] || process . env [ 'HTTPS_PROXY' ] ;
}
else {
return process . env [ 'http_proxy' ] || process . env [ 'HTTP_PROXY' ] ;
}
} ) ( ) ;
if ( proxyVar ) {
return new URL ( proxyVar ) ;
}
else {
return undefined ;
}
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
exports . getProxyUrl = getProxyUrl ;
function checkBypass ( reqUrl ) {
if ( ! reqUrl . hostname ) {
return false ;
}
const noProxy = process . env [ 'no_proxy' ] || process . env [ 'NO_PROXY' ] || '' ;
if ( ! noProxy ) {
return false ;
}
// Determine the request port
let reqPort ;
if ( reqUrl . port ) {
reqPort = Number ( reqUrl . port ) ;
}
else if ( reqUrl . protocol === 'http:' ) {
reqPort = 80 ;
}
else if ( reqUrl . protocol === 'https:' ) {
reqPort = 443 ;
}
// Format the request hostname and hostname with port
const upperReqHosts = [ reqUrl . hostname . toUpperCase ( ) ] ;
if ( typeof reqPort === 'number' ) {
upperReqHosts . push ( ` ${ upperReqHosts [ 0 ] } : ${ reqPort } ` ) ;
}
// Compare request host against noproxy
for ( const upperNoProxyItem of noProxy
. split ( ',' )
. map ( x => x . trim ( ) . toUpperCase ( ) )
. filter ( x => x ) ) {
if ( upperReqHosts . some ( x => x === upperNoProxyItem ) ) {
return true ;
}
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
return false ;
}
exports . checkBypass = checkBypass ;
//# sourceMappingURL=proxy.js.map
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 4193 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const VERSION = "2.11.0" ;
2022-10-11 16:10:23 +02:00
/ * *
* Some “ list ” response that can be paginated have a different response structure
*
* They have a ` total_count ` key in the response ( search also has ` incomplete_results ` ,
* / i n s t a l l a t i o n / r e p o s i t o r i e s a l s o h a s ` r e p o s i t o r y _ s e l e c t i o n ` ) , a s w e l l a s a k e y w i t h
* the list of the items which name varies from endpoint to endpoint .
*
* Octokit normalizes these responses so that paginated results are always returned following
* the same structure . One challenge is that if the list response has only one page , no Link
* header is provided , so this header alone is not sufficient to check wether a response is
* paginated or not .
*
* We check if a "total_count" key is present in the response data , but also make sure that
* a "url" property is not , as the "Get the combined status for a specific ref" endpoint would
* otherwise match : https : //developer.github.com/v3/repos/statuses/#get-the-combined-status-for-a-specific-ref
* /
function normalizePaginatedListResponse ( response ) {
const responseNeedsNormalization = "total_count" in response . data && ! ( "url" in response . data ) ;
if ( ! responseNeedsNormalization ) return response ; // keep the additional properties intact as there is currently no other way
// to retrieve the same information.
const incompleteResults = response . data . incomplete _results ;
const repositorySelection = response . data . repository _selection ;
const totalCount = response . data . total _count ;
delete response . data . incomplete _results ;
delete response . data . repository _selection ;
delete response . data . total _count ;
const namespaceKey = Object . keys ( response . data ) [ 0 ] ;
const data = response . data [ namespaceKey ] ;
response . data = data ;
if ( typeof incompleteResults !== "undefined" ) {
response . data . incomplete _results = incompleteResults ;
}
if ( typeof repositorySelection !== "undefined" ) {
response . data . repository _selection = repositorySelection ;
}
response . data . total _count = totalCount ;
return response ;
}
function iterator ( octokit , route , parameters ) {
const options = typeof route === "function" ? route . endpoint ( parameters ) : octokit . request . endpoint ( route , parameters ) ;
const requestMethod = typeof route === "function" ? route : octokit . request ;
const method = options . method ;
const headers = options . headers ;
let url = options . url ;
return {
[ Symbol . asyncIterator ] : ( ) => ( {
async next ( ) {
if ( ! url ) return {
done : true
} ;
const response = await requestMethod ( {
method ,
url ,
headers
} ) ;
const normalizedResponse = normalizePaginatedListResponse ( response ) ; // `response.headers.link` format:
// '<https://api.github.com/users/aseemk/followers?page=2>; rel="next", <https://api.github.com/users/aseemk/followers?page=2>; rel="last"'
// sets `url` to undefined if "next" URL is not present or `link` header is not set
url = ( ( normalizedResponse . headers . link || "" ) . match ( /<([^>]+)>;\s*rel="next"/ ) || [ ] ) [ 1 ] ;
return {
value : normalizedResponse
} ;
}
} )
} ;
}
function paginate ( octokit , route , parameters , mapFn ) {
if ( typeof parameters === "function" ) {
mapFn = parameters ;
parameters = undefined ;
}
return gather ( octokit , [ ] , iterator ( octokit , route , parameters ) [ Symbol . asyncIterator ] ( ) , mapFn ) ;
}
function gather ( octokit , results , iterator , mapFn ) {
2021-12-01 13:39:57 +01:00
return iterator . next ( ) . then ( result => {
if ( result . done ) {
return results ;
}
let earlyExit = false ;
function done ( ) {
earlyExit = true ;
}
results = results . concat ( mapFn ? mapFn ( result . value , done ) : result . value . data ) ;
if ( earlyExit ) {
return results ;
}
return gather ( octokit , results , iterator , mapFn ) ;
} ) ;
}
const composePaginateRest = Object . assign ( paginate , {
iterator
} ) ;
/ * *
* @ param octokit Octokit instance
* @ param options Options passed to Octokit constructor
* /
function paginateRest ( octokit ) {
return {
paginate : Object . assign ( paginate . bind ( null , octokit ) , {
iterator : iterator . bind ( null , octokit )
} )
} ;
}
paginateRest . VERSION = VERSION ;
exports . composePaginateRest = composePaginateRest ;
exports . paginateRest = paginateRest ;
//# sourceMappingURL=index.js.map
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 8883 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
const VERSION = "1.0.3" ;
2021-12-01 13:39:57 +01:00
/ * *
2024-05-19 08:24:38 +02:00
* @ param octokit Octokit instance
* @ param options Options passed to Octokit constructor
2021-12-01 13:39:57 +01:00
* /
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function requestLog ( octokit ) {
octokit . hook . wrap ( "request" , ( request , options ) => {
octokit . log . debug ( "request" , options ) ;
const start = Date . now ( ) ;
const requestOptions = octokit . request . endpoint . parse ( options ) ;
const path = requestOptions . url . replace ( options . baseUrl , "" ) ;
return request ( options ) . then ( response => {
octokit . log . info ( ` ${ requestOptions . method } ${ path } - ${ response . status } in ${ Date . now ( ) - start } ms ` ) ;
return response ;
} ) . catch ( error => {
octokit . log . info ( ` ${ requestOptions . method } ${ path } - ${ error . status } in ${ Date . now ( ) - start } ms ` ) ;
throw error ;
} ) ;
} ) ;
}
requestLog . VERSION = VERSION ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
exports . requestLog = requestLog ;
//# sourceMappingURL=index.js.map
2022-10-12 17:48:05 +02:00
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 3044 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-12-01 13:39:57 +01:00
2022-10-11 16:10:23 +02:00
const Endpoints = {
actions : {
addSelectedRepoToOrgSecret : [ "PUT /orgs/{org}/actions/secrets/{secret_name}/repositories/{repository_id}" ] ,
cancelWorkflowRun : [ "POST /repos/{owner}/{repo}/actions/runs/{run_id}/cancel" ] ,
createOrUpdateOrgSecret : [ "PUT /orgs/{org}/actions/secrets/{secret_name}" ] ,
createOrUpdateRepoSecret : [ "PUT /repos/{owner}/{repo}/actions/secrets/{secret_name}" , { } , {
renamedParameters : {
name : "secret_name"
2021-12-01 13:39:57 +01:00
}
2022-10-11 16:10:23 +02:00
} ] ,
createOrUpdateSecretForRepo : [ "PUT /repos/{owner}/{repo}/actions/secrets/{secret_name}" , { } , {
renamed : [ "actions" , "createOrUpdateRepoSecret" ] ,
renamedParameters : {
name : "secret_name"
2021-12-01 13:39:57 +01:00
}
2022-10-11 16:10:23 +02:00
} ] ,
createRegistrationToken : [ "POST /repos/{owner}/{repo}/actions/runners/registration-token" , { } , {
renamed : [ "actions" , "createRegistrationTokenForRepo" ]
} ] ,
createRegistrationTokenForOrg : [ "POST /orgs/{org}/actions/runners/registration-token" ] ,
createRegistrationTokenForRepo : [ "POST /repos/{owner}/{repo}/actions/runners/registration-token" ] ,
createRemoveToken : [ "POST /repos/{owner}/{repo}/actions/runners/remove-token" , { } , {
renamed : [ "actions" , "createRemoveTokenForRepo" ]
} ] ,
createRemoveTokenForOrg : [ "POST /orgs/{org}/actions/runners/remove-token" ] ,
createRemoveTokenForRepo : [ "POST /repos/{owner}/{repo}/actions/runners/remove-token" ] ,
deleteArtifact : [ "DELETE /repos/{owner}/{repo}/actions/artifacts/{artifact_id}" ] ,
deleteOrgSecret : [ "DELETE /orgs/{org}/actions/secrets/{secret_name}" ] ,
deleteRepoSecret : [ "DELETE /repos/{owner}/{repo}/actions/secrets/{secret_name}" , { } , {
renamedParameters : {
name : "secret_name"
2021-12-01 13:39:57 +01:00
}
2022-10-11 16:10:23 +02:00
} ] ,
deleteSecretFromRepo : [ "DELETE /repos/{owner}/{repo}/actions/secrets/{secret_name}" , { } , {
renamed : [ "actions" , "deleteRepoSecret" ] ,
renamedParameters : {
name : "secret_name"
2021-12-01 13:39:57 +01:00
}
2022-10-11 16:10:23 +02:00
} ] ,
deleteSelfHostedRunnerFromOrg : [ "DELETE /orgs/{org}/actions/runners/{runner_id}" ] ,
deleteSelfHostedRunnerFromRepo : [ "DELETE /repos/{owner}/{repo}/actions/runners/{runner_id}" ] ,
deleteWorkflowRunLogs : [ "DELETE /repos/{owner}/{repo}/actions/runs/{run_id}/logs" ] ,
downloadArtifact : [ "GET /repos/{owner}/{repo}/actions/artifacts/{artifact_id}/{archive_format}" ] ,
downloadJobLogsForWorkflowRun : [ "GET /repos/{owner}/{repo}/actions/jobs/{job_id}/logs" ] ,
downloadWorkflowJobLogs : [ "GET /repos/{owner}/{repo}/actions/jobs/{job_id}/logs" , { } , {
renamed : [ "actions" , "downloadJobLogsForWorkflowRun" ]
} ] ,
downloadWorkflowRunLogs : [ "GET /repos/{owner}/{repo}/actions/runs/{run_id}/logs" ] ,
getArtifact : [ "GET /repos/{owner}/{repo}/actions/artifacts/{artifact_id}" ] ,
getJobForWorkflowRun : [ "GET /repos/{owner}/{repo}/actions/jobs/{job_id}" ] ,
getOrgPublicKey : [ "GET /orgs/{org}/actions/secrets/public-key" ] ,
getOrgSecret : [ "GET /orgs/{org}/actions/secrets/{secret_name}" ] ,
getPublicKey : [ "GET /repos/{owner}/{repo}/actions/secrets/public-key" , { } , {
renamed : [ "actions" , "getRepoPublicKey" ]
} ] ,
getRepoPublicKey : [ "GET /repos/{owner}/{repo}/actions/secrets/public-key" ] ,
getRepoSecret : [ "GET /repos/{owner}/{repo}/actions/secrets/{secret_name}" , { } , {
renamedParameters : {
name : "secret_name"
2021-12-01 13:39:57 +01:00
}
2022-10-11 16:10:23 +02:00
} ] ,
getSecret : [ "GET /repos/{owner}/{repo}/actions/secrets/{secret_name}" , { } , {
renamed : [ "actions" , "getRepoSecret" ] ,
renamedParameters : {
name : "secret_name"
2021-12-01 13:39:57 +01:00
}
} ] ,
getSelfHostedRunner : [ "GET /repos/{owner}/{repo}/actions/runners/{runner_id}" , { } , {
renamed : [ "actions" , "getSelfHostedRunnerForRepo" ]
} ] ,
getSelfHostedRunnerForOrg : [ "GET /orgs/{org}/actions/runners/{runner_id}" ] ,
getSelfHostedRunnerForRepo : [ "GET /repos/{owner}/{repo}/actions/runners/{runner_id}" ] ,
getWorkflow : [ "GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}" ] ,
getWorkflowJob : [ "GET /repos/{owner}/{repo}/actions/jobs/{job_id}" , { } , {
renamed : [ "actions" , "getJobForWorkflowRun" ]
} ] ,
getWorkflowRun : [ "GET /repos/{owner}/{repo}/actions/runs/{run_id}" ] ,
getWorkflowRunUsage : [ "GET /repos/{owner}/{repo}/actions/runs/{run_id}/timing" ] ,
getWorkflowUsage : [ "GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/timing" ] ,
listArtifactsForRepo : [ "GET /repos/{owner}/{repo}/actions/artifacts" ] ,
listDownloadsForSelfHostedRunnerApplication : [ "GET /repos/{owner}/{repo}/actions/runners/downloads" , { } , {
renamed : [ "actions" , "listRunnerApplicationsForRepo" ]
} ] ,
listJobsForWorkflowRun : [ "GET /repos/{owner}/{repo}/actions/runs/{run_id}/jobs" ] ,
listOrgSecrets : [ "GET /orgs/{org}/actions/secrets" ] ,
listRepoSecrets : [ "GET /repos/{owner}/{repo}/actions/secrets" ] ,
listRepoWorkflowRuns : [ "GET /repos/{owner}/{repo}/actions/runs" , { } , {
renamed : [ "actions" , "listWorkflowRunsForRepo" ]
} ] ,
listRepoWorkflows : [ "GET /repos/{owner}/{repo}/actions/workflows" ] ,
listRunnerApplicationsForOrg : [ "GET /orgs/{org}/actions/runners/downloads" ] ,
listRunnerApplicationsForRepo : [ "GET /repos/{owner}/{repo}/actions/runners/downloads" ] ,
listSecretsForRepo : [ "GET /repos/{owner}/{repo}/actions/secrets" , { } , {
renamed : [ "actions" , "listRepoSecrets" ]
} ] ,
listSelectedReposForOrgSecret : [ "GET /orgs/{org}/actions/secrets/{secret_name}/repositories" ] ,
listSelfHostedRunnersForOrg : [ "GET /orgs/{org}/actions/runners" ] ,
listSelfHostedRunnersForRepo : [ "GET /repos/{owner}/{repo}/actions/runners" ] ,
listWorkflowJobLogs : [ "GET /repos/{owner}/{repo}/actions/jobs/{job_id}/logs" , { } , {
renamed : [ "actions" , "downloadWorkflowJobLogs" ]
} ] ,
listWorkflowRunArtifacts : [ "GET /repos/{owner}/{repo}/actions/runs/{run_id}/artifacts" ] ,
listWorkflowRunLogs : [ "GET /repos/{owner}/{repo}/actions/runs/{run_id}/logs" , { } , {
renamed : [ "actions" , "downloadWorkflowRunLogs" ]
} ] ,
listWorkflowRuns : [ "GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/runs" ] ,
listWorkflowRunsForRepo : [ "GET /repos/{owner}/{repo}/actions/runs" ] ,
reRunWorkflow : [ "POST /repos/{owner}/{repo}/actions/runs/{run_id}/rerun" ] ,
removeSelectedRepoFromOrgSecret : [ "DELETE /orgs/{org}/actions/secrets/{secret_name}/repositories/{repository_id}" ] ,
removeSelfHostedRunner : [ "DELETE /repos/{owner}/{repo}/actions/runners/{runner_id}" , { } , {
renamed : [ "actions" , "deleteSelfHostedRunnerFromRepo" ]
} ] ,
setSelectedReposForOrgSecret : [ "PUT /orgs/{org}/actions/secrets/{secret_name}/repositories" ]
} ,
activity : {
checkRepoIsStarredByAuthenticatedUser : [ "GET /user/starred/{owner}/{repo}" ] ,
checkStarringRepo : [ "GET /user/starred/{owner}/{repo}" , { } , {
renamed : [ "activity" , "checkRepoIsStarredByAuthenticatedUser" ]
} ] ,
deleteRepoSubscription : [ "DELETE /repos/{owner}/{repo}/subscription" ] ,
deleteThreadSubscription : [ "DELETE /notifications/threads/{thread_id}/subscription" ] ,
getFeeds : [ "GET /feeds" ] ,
getRepoSubscription : [ "GET /repos/{owner}/{repo}/subscription" ] ,
getThread : [ "GET /notifications/threads/{thread_id}" ] ,
getThreadSubscription : [ "PUT /notifications" , { } , {
renamed : [ "activity" , "getThreadSubscriptionForAuthenticatedUser" ]
} ] ,
getThreadSubscriptionForAuthenticatedUser : [ "GET /notifications/threads/{thread_id}/subscription" ] ,
listEventsForAuthenticatedUser : [ "GET /users/{username}/events" ] ,
listEventsForOrg : [ "GET /users/{username}/events/orgs/{org}" , { } , {
renamed : [ "activity" , "listOrgEventsForAuthenticatedUser" ]
} ] ,
listEventsForUser : [ "GET /users/{username}/events" , { } , {
renamed : [ "activity" , "listEventsForAuthenticatedUser" ]
} ] ,
listFeeds : [ "GET /feeds" , { } , {
renamed : [ "activity" , "getFeeds" ]
} ] ,
listNotifications : [ "GET /notifications" , { } , {
renamed : [ "activity" , "listNotificationsForAuthenticatedUser" ]
} ] ,
listNotificationsForAuthenticatedUser : [ "GET /notifications" ] ,
listNotificationsForRepo : [ "GET /repos/{owner}/{repo}/notifications" , { } , {
renamed : [ "activity" , "listRepoNotificationsForAuthenticatedUser" ]
} ] ,
listOrgEventsForAuthenticatedUser : [ "GET /users/{username}/events/orgs/{org}" ] ,
listPublicEvents : [ "GET /events" ] ,
listPublicEventsForOrg : [ "GET /orgs/{org}/events" , { } , {
renamed : [ "activity" , "listPublicOrgEvents" ]
} ] ,
listPublicEventsForRepoNetwork : [ "GET /networks/{owner}/{repo}/events" ] ,
listPublicEventsForUser : [ "GET /users/{username}/events/public" ] ,
listPublicOrgEvents : [ "GET /orgs/{org}/events" ] ,
listReceivedEventsForUser : [ "GET /users/{username}/received_events" ] ,
listReceivedPublicEventsForUser : [ "GET /users/{username}/received_events/public" ] ,
listRepoEvents : [ "GET /repos/{owner}/{repo}/events" ] ,
listRepoNotificationsForAuthenticatedUser : [ "GET /repos/{owner}/{repo}/notifications" ] ,
listReposStarredByAuthenticatedUser : [ "GET /user/starred" ] ,
listReposStarredByUser : [ "GET /users/{username}/starred" ] ,
listReposWatchedByUser : [ "GET /users/{username}/subscriptions" ] ,
listStargazersForRepo : [ "GET /repos/{owner}/{repo}/stargazers" ] ,
listWatchedReposForAuthenticatedUser : [ "GET /user/subscriptions" ] ,
listWatchersForRepo : [ "GET /repos/{owner}/{repo}/subscribers" ] ,
markAsRead : [ "PUT /notifications" , { } , {
renamed : [ "activity" , "markNotificationsAsRead" ]
} ] ,
markNotificationsAsRead : [ "PUT /notifications" ] ,
markNotificationsAsReadForRepo : [ "PUT /repos/{owner}/{repo}/notifications" , { } , {
renamed : [ "activity" , "markRepoNotificationsAsRead" ]
} ] ,
markRepoNotificationsAsRead : [ "PUT /repos/{owner}/{repo}/notifications" ] ,
markThreadAsRead : [ "PATCH /notifications/threads/{thread_id}" ] ,
setRepoSubscription : [ "PUT /repos/{owner}/{repo}/subscription" ] ,
setThreadSubscription : [ "PUT /notifications/threads/{thread_id}/subscription" ] ,
starRepo : [ "PUT /user/starred/{owner}/{repo}" , { } , {
renamed : [ "activity" , "starRepoForAuthenticatedUser" ]
} ] ,
starRepoForAuthenticatedUser : [ "PUT /user/starred/{owner}/{repo}" ] ,
unstarRepo : [ "DELETE /user/starred/{owner}/{repo}" , { } , {
renamed : [ "activity" , "unstarRepoForAuthenticatedUser" ]
} ] ,
unstarRepoForAuthenticatedUser : [ "DELETE /user/starred/{owner}/{repo}" ]
} ,
apps : {
addRepoToInstallation : [ "PUT /user/installations/{installation_id}/repositories/{repository_id}" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
checkAccountIsAssociatedWithAny : [ "GET /marketplace_listing/accounts/{account_id}" , { } , {
renamed : [ "apps" , "getSubscriptionPlanForAccount" ]
} ] ,
checkAccountIsAssociatedWithAnyStubbed : [ "GET /marketplace_listing/stubbed/accounts/{account_id}" , { } , {
renamed : [ "apps" , "getSubscriptionPlanForAccountStubbed" ]
} ] ,
checkToken : [ "POST /applications/{client_id}/token" ] ,
createContentAttachment : [ "POST /content_references/{content_reference_id}/attachments" , {
mediaType : {
previews : [ "corsair" ]
}
} ] ,
createFromManifest : [ "POST /app-manifests/{code}/conversions" ] ,
createInstallationAccessToken : [ "POST /app/installations/{installation_id}/access_tokens" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
createInstallationToken : [ "POST /app/installations/{installation_id}/access_tokens" , {
mediaType : {
previews : [ "machine-man" ]
}
} , {
renamed : [ "apps" , "createInstallationAccessToken" ]
} ] ,
deleteAuthorization : [ "DELETE /applications/{client_id}/grant" ] ,
deleteInstallation : [ "DELETE /app/installations/{installation_id}" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
deleteToken : [ "DELETE /applications/{client_id}/token" ] ,
getAuthenticated : [ "GET /app" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
getBySlug : [ "GET /apps/{app_slug}" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
getInstallation : [ "GET /app/installations/{installation_id}" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
getOrgInstallation : [ "GET /orgs/{org}/installation" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
getRepoInstallation : [ "GET /repos/{owner}/{repo}/installation" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
getSubscriptionPlanForAccount : [ "GET /marketplace_listing/accounts/{account_id}" ] ,
getSubscriptionPlanForAccountStubbed : [ "GET /marketplace_listing/stubbed/accounts/{account_id}" ] ,
getUserInstallation : [ "GET /users/{username}/installation" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
listAccountsForPlan : [ "GET /marketplace_listing/plans/{plan_id}/accounts" ] ,
listAccountsForPlanStubbed : [ "GET /marketplace_listing/stubbed/plans/{plan_id}/accounts" ] ,
listAccountsUserOrOrgOnPlan : [ "GET /marketplace_listing/plans/{plan_id}/accounts" , { } , {
renamed : [ "apps" , "listAccountsForPlan" ]
} ] ,
listAccountsUserOrOrgOnPlanStubbed : [ "GET /marketplace_listing/stubbed/plans/{plan_id}/accounts" , { } , {
renamed : [ "apps" , "listAccountsForPlanStubbed" ]
} ] ,
listInstallationReposForAuthenticatedUser : [ "GET /user/installations/{installation_id}/repositories" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
listInstallations : [ "GET /app/installations" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
listInstallationsForAuthenticatedUser : [ "GET /user/installations" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
listMarketplacePurchasesForAuthenticatedUser : [ "GET /user/marketplace_purchases" , { } , {
renamed : [ "apps" , "listSubscriptionsForAuthenticatedUser" ]
} ] ,
listMarketplacePurchasesForAuthenticatedUserStubbed : [ "GET /user/marketplace_purchases/stubbed" , { } , {
renamed : [ "apps" , "listSubscriptionsForAuthenticatedUserStubbed" ]
} ] ,
listPlans : [ "GET /marketplace_listing/plans" ] ,
listPlansStubbed : [ "GET /marketplace_listing/stubbed/plans" ] ,
listRepos : [ "GET /installation/repositories" , {
mediaType : {
previews : [ "machine-man" ]
}
} , {
renamed : [ "apps" , "listReposAccessibleToInstallation" ]
} ] ,
listReposAccessibleToInstallation : [ "GET /installation/repositories" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
listSubscriptionsForAuthenticatedUser : [ "GET /user/marketplace_purchases" ] ,
listSubscriptionsForAuthenticatedUserStubbed : [ "GET /user/marketplace_purchases/stubbed" ] ,
removeRepoFromInstallation : [ "DELETE /user/installations/{installation_id}/repositories/{repository_id}" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
resetToken : [ "PATCH /applications/{client_id}/token" ] ,
revokeInstallationAccessToken : [ "DELETE /installation/token" ] ,
revokeInstallationToken : [ "DELETE /installation/token" , { } , {
renamed : [ "apps" , "revokeInstallationAccessToken" ]
} ] ,
suspendInstallation : [ "PUT /app/installations/{installation_id}/suspended" ] ,
unsuspendInstallation : [ "DELETE /app/installations/{installation_id}/suspended" ]
} ,
checks : {
create : [ "POST /repos/{owner}/{repo}/check-runs" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
createSuite : [ "POST /repos/{owner}/{repo}/check-suites" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
get : [ "GET /repos/{owner}/{repo}/check-runs/{check_run_id}" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
getSuite : [ "GET /repos/{owner}/{repo}/check-suites/{check_suite_id}" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
listAnnotations : [ "GET /repos/{owner}/{repo}/check-runs/{check_run_id}/annotations" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
listForRef : [ "GET /repos/{owner}/{repo}/commits/{ref}/check-runs" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
listForSuite : [ "GET /repos/{owner}/{repo}/check-suites/{check_suite_id}/check-runs" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
listSuitesForRef : [ "GET /repos/{owner}/{repo}/commits/{ref}/check-suites" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
rerequestSuite : [ "POST /repos/{owner}/{repo}/check-suites/{check_suite_id}/rerequest" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
setSuitesPreferences : [ "PATCH /repos/{owner}/{repo}/check-suites/preferences" , {
mediaType : {
previews : [ "antiope" ]
}
} ] ,
update : [ "PATCH /repos/{owner}/{repo}/check-runs/{check_run_id}" , {
mediaType : {
previews : [ "antiope" ]
}
} ]
} ,
codeScanning : {
getAlert : [ "GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_id}" ] ,
listAlertsForRepo : [ "GET /repos/{owner}/{repo}/code-scanning/alerts" ]
} ,
codesOfConduct : {
getAllCodesOfConduct : [ "GET /codes_of_conduct" , {
mediaType : {
previews : [ "scarlet-witch" ]
}
} ] ,
getConductCode : [ "GET /codes_of_conduct/{key}" , {
mediaType : {
previews : [ "scarlet-witch" ]
}
} ] ,
getForRepo : [ "GET /repos/{owner}/{repo}/community/code_of_conduct" , {
mediaType : {
previews : [ "scarlet-witch" ]
}
} ] ,
listConductCodes : [ "GET /codes_of_conduct" , {
mediaType : {
previews : [ "scarlet-witch" ]
}
} , {
renamed : [ "codesOfConduct" , "getAllCodesOfConduct" ]
} ]
} ,
emojis : {
get : [ "GET /emojis" ]
} ,
gists : {
checkIsStarred : [ "GET /gists/{gist_id}/star" ] ,
create : [ "POST /gists" ] ,
createComment : [ "POST /gists/{gist_id}/comments" ] ,
delete : [ "DELETE /gists/{gist_id}" ] ,
deleteComment : [ "DELETE /gists/{gist_id}/comments/{comment_id}" ] ,
fork : [ "POST /gists/{gist_id}/forks" ] ,
get : [ "GET /gists/{gist_id}" ] ,
getComment : [ "GET /gists/{gist_id}/comments/{comment_id}" ] ,
getRevision : [ "GET /gists/{gist_id}/{sha}" ] ,
list : [ "GET /gists" ] ,
listComments : [ "GET /gists/{gist_id}/comments" ] ,
listCommits : [ "GET /gists/{gist_id}/commits" ] ,
listForUser : [ "GET /users/{username}/gists" ] ,
listForks : [ "GET /gists/{gist_id}/forks" ] ,
listPublic : [ "GET /gists/public" ] ,
listPublicForUser : [ "GET /users/{username}/gists" , { } , {
renamed : [ "gists" , "listForUser" ]
} ] ,
listStarred : [ "GET /gists/starred" ] ,
star : [ "PUT /gists/{gist_id}/star" ] ,
unstar : [ "DELETE /gists/{gist_id}/star" ] ,
update : [ "PATCH /gists/{gist_id}" ] ,
updateComment : [ "PATCH /gists/{gist_id}/comments/{comment_id}" ]
} ,
git : {
createBlob : [ "POST /repos/{owner}/{repo}/git/blobs" ] ,
createCommit : [ "POST /repos/{owner}/{repo}/git/commits" ] ,
createRef : [ "POST /repos/{owner}/{repo}/git/refs" ] ,
createTag : [ "POST /repos/{owner}/{repo}/git/tags" ] ,
createTree : [ "POST /repos/{owner}/{repo}/git/trees" ] ,
deleteRef : [ "DELETE /repos/{owner}/{repo}/git/refs/{ref}" ] ,
getBlob : [ "GET /repos/{owner}/{repo}/git/blobs/{file_sha}" ] ,
getCommit : [ "GET /repos/{owner}/{repo}/git/commits/{commit_sha}" ] ,
getRef : [ "GET /repos/{owner}/{repo}/git/ref/{ref}" ] ,
getTag : [ "GET /repos/{owner}/{repo}/git/tags/{tag_sha}" ] ,
getTree : [ "GET /repos/{owner}/{repo}/git/trees/{tree_sha}" ] ,
listMatchingRefs : [ "GET /repos/{owner}/{repo}/git/matching-refs/{ref}" ] ,
updateRef : [ "PATCH /repos/{owner}/{repo}/git/refs/{ref}" ]
} ,
gitignore : {
getAllTemplates : [ "GET /gitignore/templates" ] ,
getTemplate : [ "GET /gitignore/templates/{name}" ] ,
listTemplates : [ "GET /gitignore/templates" , { } , {
renamed : [ "gitignore" , "getAllTemplates" ]
} ]
} ,
interactions : {
addOrUpdateRestrictionsForOrg : [ "PUT /orgs/{org}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} , {
renamed : [ "interactions" , "setRestrictionsForOrg" ]
} ] ,
addOrUpdateRestrictionsForRepo : [ "PUT /repos/{owner}/{repo}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} , {
renamed : [ "interactions" , "setRestrictionsForRepo" ]
} ] ,
getRestrictionsForOrg : [ "GET /orgs/{org}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} ] ,
getRestrictionsForRepo : [ "GET /repos/{owner}/{repo}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} ] ,
removeRestrictionsForOrg : [ "DELETE /orgs/{org}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} ] ,
removeRestrictionsForRepo : [ "DELETE /repos/{owner}/{repo}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} ] ,
setRestrictionsForOrg : [ "PUT /orgs/{org}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} ] ,
setRestrictionsForRepo : [ "PUT /repos/{owner}/{repo}/interaction-limits" , {
mediaType : {
previews : [ "sombra" ]
}
} ]
} ,
issues : {
addAssignees : [ "POST /repos/{owner}/{repo}/issues/{issue_number}/assignees" ] ,
addLabels : [ "POST /repos/{owner}/{repo}/issues/{issue_number}/labels" ] ,
checkAssignee : [ "GET /repos/{owner}/{repo}/assignees/{assignee}" , { } , {
renamed : [ "issues" , "checkUserCanBeAssigned" ]
} ] ,
checkUserCanBeAssigned : [ "GET /repos/{owner}/{repo}/assignees/{assignee}" ] ,
create : [ "POST /repos/{owner}/{repo}/issues" ] ,
createComment : [ "POST /repos/{owner}/{repo}/issues/{issue_number}/comments" ] ,
createLabel : [ "POST /repos/{owner}/{repo}/labels" ] ,
createMilestone : [ "POST /repos/{owner}/{repo}/milestones" ] ,
deleteComment : [ "DELETE /repos/{owner}/{repo}/issues/comments/{comment_id}" ] ,
deleteLabel : [ "DELETE /repos/{owner}/{repo}/labels/{name}" ] ,
deleteMilestone : [ "DELETE /repos/{owner}/{repo}/milestones/{milestone_number}" ] ,
get : [ "GET /repos/{owner}/{repo}/issues/{issue_number}" ] ,
getComment : [ "GET /repos/{owner}/{repo}/issues/comments/{comment_id}" ] ,
getEvent : [ "GET /repos/{owner}/{repo}/issues/events/{event_id}" ] ,
getLabel : [ "GET /repos/{owner}/{repo}/labels/{name}" ] ,
getMilestone : [ "GET /repos/{owner}/{repo}/milestones/{milestone_number}" ] ,
list : [ "GET /issues" ] ,
listAssignees : [ "GET /repos/{owner}/{repo}/assignees" ] ,
listComments : [ "GET /repos/{owner}/{repo}/issues/{issue_number}/comments" ] ,
listCommentsForRepo : [ "GET /repos/{owner}/{repo}/issues/comments" ] ,
listEvents : [ "GET /repos/{owner}/{repo}/issues/{issue_number}/events" ] ,
listEventsForRepo : [ "GET /repos/{owner}/{repo}/issues/events" ] ,
listEventsForTimeline : [ "GET /repos/{owner}/{repo}/issues/{issue_number}/timeline" , {
mediaType : {
previews : [ "mockingbird" ]
}
} ] ,
listForAuthenticatedUser : [ "GET /user/issues" ] ,
listForOrg : [ "GET /orgs/{org}/issues" ] ,
listForRepo : [ "GET /repos/{owner}/{repo}/issues" ] ,
listLabelsForMilestone : [ "GET /repos/{owner}/{repo}/milestones/{milestone_number}/labels" ] ,
listLabelsForRepo : [ "GET /repos/{owner}/{repo}/labels" ] ,
listLabelsOnIssue : [ "GET /repos/{owner}/{repo}/issues/{issue_number}/labels" ] ,
listMilestones : [ "GET /repos/{owner}/{repo}/milestones" ] ,
listMilestonesForRepo : [ "GET /repos/{owner}/{repo}/milestones" , { } , {
renamed : [ "issues" , "listMilestones" ]
} ] ,
lock : [ "PUT /repos/{owner}/{repo}/issues/{issue_number}/lock" ] ,
removeAllLabels : [ "DELETE /repos/{owner}/{repo}/issues/{issue_number}/labels" ] ,
removeAssignees : [ "DELETE /repos/{owner}/{repo}/issues/{issue_number}/assignees" ] ,
removeLabel : [ "DELETE /repos/{owner}/{repo}/issues/{issue_number}/labels/{name}" ] ,
removeLabels : [ "DELETE /repos/{owner}/{repo}/issues/{issue_number}/labels" , { } , {
renamed : [ "issues" , "removeAllLabels" ]
} ] ,
replaceAllLabels : [ "PUT /repos/{owner}/{repo}/issues/{issue_number}/labels" , { } , {
renamed : [ "issues" , "setLabels" ]
} ] ,
replaceLabels : [ "PUT /repos/{owner}/{repo}/issues/{issue_number}/labels" , { } , {
renamed : [ "issues" , "replaceAllLabels" ]
} ] ,
setLabels : [ "PUT /repos/{owner}/{repo}/issues/{issue_number}/labels" ] ,
unlock : [ "DELETE /repos/{owner}/{repo}/issues/{issue_number}/lock" ] ,
update : [ "PATCH /repos/{owner}/{repo}/issues/{issue_number}" ] ,
updateComment : [ "PATCH /repos/{owner}/{repo}/issues/comments/{comment_id}" ] ,
updateLabel : [ "PATCH /repos/{owner}/{repo}/labels/{name}" ] ,
updateMilestone : [ "PATCH /repos/{owner}/{repo}/milestones/{milestone_number}" ]
} ,
licenses : {
get : [ "GET /licenses/{license}" ] ,
getAllCommonlyUsed : [ "GET /licenses" ] ,
getForRepo : [ "GET /repos/{owner}/{repo}/license" ] ,
listCommonlyUsed : [ "GET /licenses" , { } , {
renamed : [ "licenses" , "getAllCommonlyUsed" ]
} ]
} ,
markdown : {
render : [ "POST /markdown" ] ,
renderRaw : [ "POST /markdown/raw" , {
headers : {
"content-type" : "text/plain; charset=utf-8"
}
} ]
} ,
meta : {
get : [ "GET /meta" ]
} ,
migrations : {
cancelImport : [ "DELETE /repos/{owner}/{repo}/import" ] ,
deleteArchiveForAuthenticatedUser : [ "DELETE /user/migrations/{migration_id}/archive" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
deleteArchiveForOrg : [ "DELETE /orgs/{org}/migrations/{migration_id}/archive" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
downloadArchiveForOrg : [ "GET /orgs/{org}/migrations/{migration_id}/archive" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
getArchiveForAuthenticatedUser : [ "GET /user/migrations/{migration_id}/archive" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
getCommitAuthors : [ "GET /repos/{owner}/{repo}/import/authors" ] ,
getImportProgress : [ "GET /repos/{owner}/{repo}/import" , { } , {
renamed : [ "migrations" , "getImportStatus" ]
} ] ,
getImportStatus : [ "GET /repos/{owner}/{repo}/import" ] ,
getLargeFiles : [ "GET /repos/{owner}/{repo}/import/large_files" ] ,
getStatusForAuthenticatedUser : [ "GET /user/migrations/{migration_id}" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
getStatusForOrg : [ "GET /orgs/{org}/migrations/{migration_id}" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
listForAuthenticatedUser : [ "GET /user/migrations" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
listForOrg : [ "GET /orgs/{org}/migrations" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
listReposForOrg : [ "GET /orgs/{org}/migrations/{migration_id}/repositories" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
listReposForUser : [ "GET /user/{migration_id}/repositories" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
mapCommitAuthor : [ "PATCH /repos/{owner}/{repo}/import/authors/{author_id}" ] ,
setLfsPreference : [ "PATCH /repos/{owner}/{repo}/import/lfs" ] ,
startForAuthenticatedUser : [ "POST /user/migrations" ] ,
startForOrg : [ "POST /orgs/{org}/migrations" ] ,
startImport : [ "PUT /repos/{owner}/{repo}/import" ] ,
unlockRepoForAuthenticatedUser : [ "DELETE /user/migrations/{migration_id}/repos/{repo_name}/lock" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
unlockRepoForOrg : [ "DELETE /orgs/{org}/migrations/{migration_id}/repos/{repo_name}/lock" , {
mediaType : {
previews : [ "wyandotte" ]
}
} ] ,
updateImport : [ "PATCH /repos/{owner}/{repo}/import" ]
} ,
orgs : {
addOrUpdateMembership : [ "PUT /orgs/{org}/memberships/{username}" , { } , {
renamed : [ "orgs" , "setMembershipForUser" ]
} ] ,
blockUser : [ "PUT /orgs/{org}/blocks/{username}" ] ,
checkBlockedUser : [ "GET /orgs/{org}/blocks/{username}" ] ,
checkMembership : [ "GET /orgs/{org}/members/{username}" , { } , {
renamed : [ "orgs" , "checkMembershipForUser" ]
} ] ,
checkMembershipForUser : [ "GET /orgs/{org}/members/{username}" ] ,
checkPublicMembership : [ "GET /orgs/{org}/public_members/{username}" , { } , {
renamed : [ "orgs" , "checkPublicMembershipForUser" ]
} ] ,
checkPublicMembershipForUser : [ "GET /orgs/{org}/public_members/{username}" ] ,
concealMembership : [ "DELETE /orgs/{org}/public_members/{username}" , { } , {
renamed : [ "orgs" , "removePublicMembershipForAuthenticatedUser" ]
} ] ,
convertMemberToOutsideCollaborator : [ "PUT /orgs/{org}/outside_collaborators/{username}" ] ,
createHook : [ "POST /orgs/{org}/hooks" , { } , {
renamed : [ "orgs" , "createWebhook" ]
} ] ,
createInvitation : [ "POST /orgs/{org}/invitations" ] ,
createWebhook : [ "POST /orgs/{org}/hooks" ] ,
deleteHook : [ "DELETE /orgs/{org}/hooks/{hook_id}" , { } , {
renamed : [ "orgs" , "deleteWebhook" ]
} ] ,
deleteWebhook : [ "DELETE /orgs/{org}/hooks/{hook_id}" ] ,
get : [ "GET /orgs/{org}" ] ,
getHook : [ "GET /orgs/{org}/hooks/{hook_id}" , { } , {
renamed : [ "orgs" , "getWebhook" ]
} ] ,
getMembership : [ "GET /orgs/{org}/memberships/{username}" , { } , {
renamed : [ "orgs" , "getMembershipForUser" ]
} ] ,
getMembershipForAuthenticatedUser : [ "GET /user/memberships/orgs/{org}" ] ,
getMembershipForUser : [ "GET /orgs/{org}/memberships/{username}" ] ,
getWebhook : [ "GET /orgs/{org}/hooks/{hook_id}" ] ,
list : [ "GET /organizations" ] ,
listAppInstallations : [ "GET /orgs/{org}/installations" , {
mediaType : {
previews : [ "machine-man" ]
}
} ] ,
listBlockedUsers : [ "GET /orgs/{org}/blocks" ] ,
listForAuthenticatedUser : [ "GET /user/orgs" ] ,
listForUser : [ "GET /users/{username}/orgs" ] ,
listHooks : [ "GET /orgs/{org}/hooks" , { } , {
renamed : [ "orgs" , "listWebhooks" ]
} ] ,
listInstallations : [ "GET /orgs/{org}/installations" , {
mediaType : {
previews : [ "machine-man" ]
}
} , {
renamed : [ "orgs" , "listAppInstallations" ]
} ] ,
listInvitationTeams : [ "GET /orgs/{org}/invitations/{invitation_id}/teams" ] ,
listMembers : [ "GET /orgs/{org}/members" ] ,
listMemberships : [ "GET /user/memberships/orgs" , { } , {
renamed : [ "orgs" , "listMembershipsForAuthenticatedUser" ]
} ] ,
listMembershipsForAuthenticatedUser : [ "GET /user/memberships/orgs" ] ,
listOutsideCollaborators : [ "GET /orgs/{org}/outside_collaborators" ] ,
listPendingInvitations : [ "GET /orgs/{org}/invitations" ] ,
listPublicMembers : [ "GET /orgs/{org}/public_members" ] ,
listWebhooks : [ "GET /orgs/{org}/hooks" ] ,
pingHook : [ "POST /orgs/{org}/hooks/{hook_id}/pings" , { } , {
renamed : [ "orgs" , "pingWebhook" ]
} ] ,
pingWebhook : [ "POST /orgs/{org}/hooks/{hook_id}/pings" ] ,
publicizeMembership : [ "PUT /orgs/{org}/public_members/{username}" , { } , {
renamed : [ "orgs" , "setPublicMembershipForAuthenticatedUser" ]
} ] ,
removeMember : [ "DELETE /orgs/{org}/members/{username}" ] ,
removeMembership : [ "DELETE /orgs/{org}/memberships/{username}" , { } , {
renamed : [ "orgs" , "removeMembershipForUser" ]
} ] ,
removeMembershipForUser : [ "DELETE /orgs/{org}/memberships/{username}" ] ,
removeOutsideCollaborator : [ "DELETE /orgs/{org}/outside_collaborators/{username}" ] ,
removePublicMembershipForAuthenticatedUser : [ "DELETE /orgs/{org}/public_members/{username}" ] ,
setMembershipForUser : [ "PUT /orgs/{org}/memberships/{username}" ] ,
setPublicMembershipForAuthenticatedUser : [ "PUT /orgs/{org}/public_members/{username}" ] ,
unblockUser : [ "DELETE /orgs/{org}/blocks/{username}" ] ,
update : [ "PATCH /orgs/{org}" ] ,
updateHook : [ "PATCH /orgs/{org}/hooks/{hook_id}" , { } , {
renamed : [ "orgs" , "updateWebhook" ]
} ] ,
updateMembership : [ "PATCH /user/memberships/orgs/{org}" , { } , {
renamed : [ "orgs" , "updateMembershipForAuthenticatedUser" ]
} ] ,
updateMembershipForAuthenticatedUser : [ "PATCH /user/memberships/orgs/{org}" ] ,
updateWebhook : [ "PATCH /orgs/{org}/hooks/{hook_id}" ]
} ,
projects : {
addCollaborator : [ "PUT /projects/{project_id}/collaborators/{username}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
createCard : [ "POST /projects/columns/{column_id}/cards" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
createColumn : [ "POST /projects/{project_id}/columns" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
createForAuthenticatedUser : [ "POST /user/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
createForOrg : [ "POST /orgs/{org}/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
createForRepo : [ "POST /repos/{owner}/{repo}/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
delete : [ "DELETE /projects/{project_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
deleteCard : [ "DELETE /projects/columns/cards/{card_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
deleteColumn : [ "DELETE /projects/columns/{column_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
get : [ "GET /projects/{project_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
getCard : [ "GET /projects/columns/cards/{card_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
getColumn : [ "GET /projects/columns/{column_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
getPermissionForUser : [ "GET /projects/{project_id}/collaborators/{username}/permission" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listCards : [ "GET /projects/columns/{column_id}/cards" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listCollaborators : [ "GET /projects/{project_id}/collaborators" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listColumns : [ "GET /projects/{project_id}/columns" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listForOrg : [ "GET /orgs/{org}/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listForRepo : [ "GET /repos/{owner}/{repo}/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
listForUser : [ "GET /users/{username}/projects" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
moveCard : [ "POST /projects/columns/cards/{card_id}/moves" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
moveColumn : [ "POST /projects/columns/{column_id}/moves" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
removeCollaborator : [ "DELETE /projects/{project_id}/collaborators/{username}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
reviewUserPermissionLevel : [ "GET /projects/{project_id}/collaborators/{username}/permission" , {
mediaType : {
previews : [ "inertia" ]
}
} , {
renamed : [ "projects" , "getPermissionForUser" ]
} ] ,
update : [ "PATCH /projects/{project_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
updateCard : [ "PATCH /projects/columns/cards/{card_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ] ,
updateColumn : [ "PATCH /projects/columns/{column_id}" , {
mediaType : {
previews : [ "inertia" ]
}
} ]
} ,
pulls : {
checkIfMerged : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/merge" ] ,
create : [ "POST /repos/{owner}/{repo}/pulls" ] ,
createComment : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/comments" , { } , {
renamed : [ "pulls" , "createReviewComment" ]
} ] ,
createReplyForReviewComment : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/comments/{comment_id}/replies" ] ,
createReview : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/reviews" ] ,
createReviewComment : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/comments" ] ,
createReviewCommentReply : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/comments/{comment_id}/replies" , { } , {
renamed : [ "pulls" , "createReplyForReviewComment" ]
} ] ,
createReviewRequest : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers" , { } , {
renamed : [ "pulls" , "requestReviewers" ]
} ] ,
deleteComment : [ "DELETE /repos/{owner}/{repo}/pulls/comments/{comment_id}" , { } , {
renamed : [ "pulls" , "deleteReviewComment" ]
} ] ,
deletePendingReview : [ "DELETE /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}" ] ,
deleteReviewComment : [ "DELETE /repos/{owner}/{repo}/pulls/comments/{comment_id}" ] ,
deleteReviewRequest : [ "DELETE /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers" , { } , {
renamed : [ "pulls" , "removeRequestedReviewers" ]
} ] ,
dismissReview : [ "PUT /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/dismissals" ] ,
get : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}" ] ,
getComment : [ "GET /repos/{owner}/{repo}/pulls/comments/{comment_id}" , { } , {
renamed : [ "pulls" , "getReviewComment" ]
} ] ,
getCommentsForReview : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/comments" , { } , {
renamed : [ "pulls" , "listCommentsForReview" ]
} ] ,
getReview : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}" ] ,
getReviewComment : [ "GET /repos/{owner}/{repo}/pulls/comments/{comment_id}" ] ,
list : [ "GET /repos/{owner}/{repo}/pulls" ] ,
listComments : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/comments" , { } , {
renamed : [ "pulls" , "listReviewComments" ]
} ] ,
listCommentsForRepo : [ "GET /repos/{owner}/{repo}/pulls/comments" , { } , {
renamed : [ "pulls" , "listReviewCommentsForRepo" ]
} ] ,
listCommentsForReview : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/comments" ] ,
listCommits : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/commits" ] ,
listFiles : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/files" ] ,
listRequestedReviewers : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers" ] ,
listReviewComments : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/comments" ] ,
listReviewCommentsForRepo : [ "GET /repos/{owner}/{repo}/pulls/comments" ] ,
listReviewRequests : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers" , { } , {
renamed : [ "pulls" , "listRequestedReviewers" ]
} ] ,
listReviews : [ "GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews" ] ,
merge : [ "PUT /repos/{owner}/{repo}/pulls/{pull_number}/merge" ] ,
removeRequestedReviewers : [ "DELETE /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers" ] ,
requestReviewers : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers" ] ,
submitReview : [ "POST /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/events" ] ,
update : [ "PATCH /repos/{owner}/{repo}/pulls/{pull_number}" ] ,
updateBranch : [ "PUT /repos/{owner}/{repo}/pulls/{pull_number}/update-branch" , {
mediaType : {
previews : [ "lydian" ]
}
} ] ,
updateComment : [ "PATCH /repos/{owner}/{repo}/pulls/comments/{comment_id}" , { } , {
renamed : [ "pulls" , "updateReviewComment" ]
} ] ,
updateReview : [ "PUT /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}" ] ,
updateReviewComment : [ "PATCH /repos/{owner}/{repo}/pulls/comments/{comment_id}" ]
} ,
rateLimit : {
get : [ "GET /rate_limit" ]
} ,
reactions : {
createForCommitComment : [ "POST /repos/{owner}/{repo}/comments/{comment_id}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
createForIssue : [ "POST /repos/{owner}/{repo}/issues/{issue_number}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
createForIssueComment : [ "POST /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
createForPullRequestReviewComment : [ "POST /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
createForTeamDiscussionCommentInOrg : [ "POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
createForTeamDiscussionInOrg : [ "POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
delete : [ "DELETE /reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} , {
renamed : [ "reactions" , "deleteLegacy" ]
} ] ,
deleteForCommitComment : [ "DELETE /repos/{owner}/{repo}/comments/{comment_id}/reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
deleteForIssue : [ "DELETE /repos/{owner}/{repo}/issues/{issue_number}/reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
deleteForIssueComment : [ "DELETE /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
deleteForPullRequestComment : [ "DELETE /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
deleteForTeamDiscussion : [ "DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
deleteForTeamDiscussionComment : [ "DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
2022-10-11 16:10:23 +02:00
deleteLegacy : [ "DELETE /reactions/{reaction_id}" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} , {
deprecated : "octokit.reactions.deleteLegacy() is deprecated, see https://developer.github.com/v3/reactions/#delete-a-reaction-legacy"
} ] ,
listForCommitComment : [ "GET /repos/{owner}/{repo}/comments/{comment_id}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
listForIssue : [ "GET /repos/{owner}/{repo}/issues/{issue_number}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
listForIssueComment : [ "GET /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
listForPullRequestReviewComment : [ "GET /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
listForTeamDiscussionCommentInOrg : [ "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ] ,
listForTeamDiscussionInOrg : [ "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions" , {
mediaType : {
previews : [ "squirrel-girl" ]
}
} ]
} ,
repos : {
acceptInvitation : [ "PATCH /user/repository_invitations/{invitation_id}" ] ,
addAppAccessRestrictions : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps" , { } , {
mapToData : "apps"
} ] ,
addCollaborator : [ "PUT /repos/{owner}/{repo}/collaborators/{username}" ] ,
addDeployKey : [ "POST /repos/{owner}/{repo}/keys" , { } , {
renamed : [ "repos" , "createDeployKey" ]
} ] ,
addProtectedBranchAdminEnforcement : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins" , { } , {
renamed : [ "repos" , "setAdminBranchProtection" ]
} ] ,
addProtectedBranchAppRestrictions : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps" , { } , {
mapToData : "apps" ,
renamed : [ "repos" , "addAppAccessRestrictions" ]
} ] ,
addProtectedBranchRequiredSignatures : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures" , {
mediaType : {
previews : [ "zzzax" ]
}
} , {
renamed : [ "repos" , "createCommitSignatureProtection" ]
} ] ,
addProtectedBranchRequiredStatusChecksContexts : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts" , { } , {
mapToData : "contexts" ,
renamed : [ "repos" , "addStatusCheckContexts" ]
} ] ,
addProtectedBranchTeamRestrictions : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams" , { } , {
mapToData : "teams" ,
renamed : [ "repos" , "addTeamAccessRestrictions" ]
} ] ,
addProtectedBranchUserRestrictions : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users" , { } , {
mapToData : "users" ,
renamed : [ "repos" , "addUserAccessRestrictions" ]
} ] ,
addStatusCheckContexts : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts" , { } , {
mapToData : "contexts"
} ] ,
addTeamAccessRestrictions : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams" , { } , {
mapToData : "teams"
} ] ,
addUserAccessRestrictions : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users" , { } , {
mapToData : "users"
} ] ,
checkCollaborator : [ "GET /repos/{owner}/{repo}/collaborators/{username}" ] ,
checkVulnerabilityAlerts : [ "GET /repos/{owner}/{repo}/vulnerability-alerts" , {
mediaType : {
previews : [ "dorian" ]
}
} ] ,
compareCommits : [ "GET /repos/{owner}/{repo}/compare/{base}...{head}" ] ,
createCommitComment : [ "POST /repos/{owner}/{repo}/commits/{commit_sha}/comments" ] ,
createCommitSignatureProtection : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures" , {
mediaType : {
previews : [ "zzzax" ]
}
} ] ,
createCommitStatus : [ "POST /repos/{owner}/{repo}/statuses/{sha}" ] ,
createDeployKey : [ "POST /repos/{owner}/{repo}/keys" ] ,
createDeployment : [ "POST /repos/{owner}/{repo}/deployments" ] ,
createDeploymentStatus : [ "POST /repos/{owner}/{repo}/deployments/{deployment_id}/statuses" ] ,
createDispatchEvent : [ "POST /repos/{owner}/{repo}/dispatches" ] ,
createForAuthenticatedUser : [ "POST /user/repos" ] ,
createFork : [ "POST /repos/{owner}/{repo}/forks" ] ,
createHook : [ "POST /repos/{owner}/{repo}/hooks" , { } , {
renamed : [ "repos" , "createWebhook" ]
} ] ,
createInOrg : [ "POST /orgs/{org}/repos" ] ,
createOrUpdateFile : [ "PUT /repos/{owner}/{repo}/contents/{path}" , { } , {
renamed : [ "repos" , "createOrUpdateFileContents" ]
} ] ,
createOrUpdateFileContents : [ "PUT /repos/{owner}/{repo}/contents/{path}" ] ,
createPagesSite : [ "POST /repos/{owner}/{repo}/pages" , {
mediaType : {
previews : [ "switcheroo" ]
}
} ] ,
createRelease : [ "POST /repos/{owner}/{repo}/releases" ] ,
createStatus : [ "POST /repos/{owner}/{repo}/statuses/{sha}" , { } , {
renamed : [ "repos" , "createCommitStatus" ]
} ] ,
createUsingTemplate : [ "POST /repos/{template_owner}/{template_repo}/generate" , {
mediaType : {
previews : [ "baptiste" ]
}
} ] ,
createWebhook : [ "POST /repos/{owner}/{repo}/hooks" ] ,
declineInvitation : [ "DELETE /user/repository_invitations/{invitation_id}" ] ,
delete : [ "DELETE /repos/{owner}/{repo}" ] ,
deleteAccessRestrictions : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions" ] ,
deleteAdminBranchProtection : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins" ] ,
deleteBranchProtection : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection" ] ,
deleteCommitComment : [ "DELETE /repos/{owner}/{repo}/comments/{comment_id}" ] ,
deleteCommitSignatureProtection : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures" , {
mediaType : {
previews : [ "zzzax" ]
}
} ] ,
deleteDeployKey : [ "DELETE /repos/{owner}/{repo}/keys/{key_id}" ] ,
deleteDeployment : [ "DELETE /repos/{owner}/{repo}/deployments/{deployment_id}" ] ,
deleteDownload : [ "DELETE /repos/{owner}/{repo}/downloads/{download_id}" ] ,
deleteFile : [ "DELETE /repos/{owner}/{repo}/contents/{path}" ] ,
deleteHook : [ "DELETE /repos/{owner}/{repo}/hooks/{hook_id}" , { } , {
renamed : [ "repos" , "deleteWebhook" ]
} ] ,
deleteInvitation : [ "DELETE /repos/{owner}/{repo}/invitations/{invitation_id}" ] ,
deletePagesSite : [ "DELETE /repos/{owner}/{repo}/pages" , {
mediaType : {
previews : [ "switcheroo" ]
}
} ] ,
deletePullRequestReviewProtection : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews" ] ,
deleteRelease : [ "DELETE /repos/{owner}/{repo}/releases/{release_id}" ] ,
deleteReleaseAsset : [ "DELETE /repos/{owner}/{repo}/releases/assets/{asset_id}" ] ,
deleteWebhook : [ "DELETE /repos/{owner}/{repo}/hooks/{hook_id}" ] ,
disableAutomatedSecurityFixes : [ "DELETE /repos/{owner}/{repo}/automated-security-fixes" , {
mediaType : {
previews : [ "london" ]
}
} ] ,
disablePagesSite : [ "DELETE /repos/{owner}/{repo}/pages" , {
mediaType : {
previews : [ "switcheroo" ]
}
} , {
renamed : [ "repos" , "deletePagesSite" ]
} ] ,
disableVulnerabilityAlerts : [ "DELETE /repos/{owner}/{repo}/vulnerability-alerts" , {
mediaType : {
previews : [ "dorian" ]
}
} ] ,
downloadArchive : [ "GET /repos/{owner}/{repo}/{archive_format}/{ref}" ] ,
enableAutomatedSecurityFixes : [ "PUT /repos/{owner}/{repo}/automated-security-fixes" , {
mediaType : {
previews : [ "london" ]
}
} ] ,
enablePagesSite : [ "POST /repos/{owner}/{repo}/pages" , {
mediaType : {
previews : [ "switcheroo" ]
}
} , {
renamed : [ "repos" , "createPagesSite" ]
} ] ,
enableVulnerabilityAlerts : [ "PUT /repos/{owner}/{repo}/vulnerability-alerts" , {
mediaType : {
previews : [ "dorian" ]
}
} ] ,
get : [ "GET /repos/{owner}/{repo}" ] ,
getAccessRestrictions : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions" ] ,
getAdminBranchProtection : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins" ] ,
getAllStatusCheckContexts : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts" ] ,
getAllTopics : [ "GET /repos/{owner}/{repo}/topics" , {
mediaType : {
previews : [ "mercy" ]
}
} ] ,
getAppsWithAccessToProtectedBranch : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps" ] ,
getArchiveLink : [ "GET /repos/{owner}/{repo}/{archive_format}/{ref}" , { } , {
renamed : [ "repos" , "downloadArchive" ]
} ] ,
getBranch : [ "GET /repos/{owner}/{repo}/branches/{branch}" ] ,
getBranchProtection : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection" ] ,
getClones : [ "GET /repos/{owner}/{repo}/traffic/clones" ] ,
getCodeFrequencyStats : [ "GET /repos/{owner}/{repo}/stats/code_frequency" ] ,
getCollaboratorPermissionLevel : [ "GET /repos/{owner}/{repo}/collaborators/{username}/permission" ] ,
getCombinedStatusForRef : [ "GET /repos/{owner}/{repo}/commits/{ref}/status" ] ,
getCommit : [ "GET /repos/{owner}/{repo}/commits/{ref}" ] ,
getCommitActivityStats : [ "GET /repos/{owner}/{repo}/stats/commit_activity" ] ,
getCommitComment : [ "GET /repos/{owner}/{repo}/comments/{comment_id}" ] ,
getCommitSignatureProtection : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures" , {
mediaType : {
previews : [ "zzzax" ]
}
} ] ,
getCommunityProfileMetrics : [ "GET /repos/{owner}/{repo}/community/profile" ] ,
getContent : [ "GET /repos/{owner}/{repo}/contents/{path}" ] ,
getContents : [ "GET /repos/{owner}/{repo}/contents/{path}" , { } , {
renamed : [ "repos" , "getContent" ]
} ] ,
getContributorsStats : [ "GET /repos/{owner}/{repo}/stats/contributors" ] ,
getDeployKey : [ "GET /repos/{owner}/{repo}/keys/{key_id}" ] ,
getDeployment : [ "GET /repos/{owner}/{repo}/deployments/{deployment_id}" ] ,
getDeploymentStatus : [ "GET /repos/{owner}/{repo}/deployments/{deployment_id}/statuses/{status_id}" ] ,
getDownload : [ "GET /repos/{owner}/{repo}/downloads/{download_id}" ] ,
getHook : [ "GET /repos/{owner}/{repo}/hooks/{hook_id}" , { } , {
renamed : [ "repos" , "getWebhook" ]
} ] ,
getLatestPagesBuild : [ "GET /repos/{owner}/{repo}/pages/builds/latest" ] ,
getLatestRelease : [ "GET /repos/{owner}/{repo}/releases/latest" ] ,
getPages : [ "GET /repos/{owner}/{repo}/pages" ] ,
getPagesBuild : [ "GET /repos/{owner}/{repo}/pages/builds/{build_id}" ] ,
getParticipationStats : [ "GET /repos/{owner}/{repo}/stats/participation" ] ,
getProtectedBranchAdminEnforcement : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins" , { } , {
renamed : [ "repos" , "getAdminBranchProtection" ]
} ] ,
getProtectedBranchPullRequestReviewEnforcement : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews" , { } , {
renamed : [ "repos" , "getPullRequestReviewProtection" ]
} ] ,
getProtectedBranchRequiredSignatures : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures" , {
2021-12-01 13:39:57 +01:00
mediaType : {
2022-10-11 16:10:23 +02:00
previews : [ "zzzax" ]
2021-12-01 13:39:57 +01:00
}
} , {
2022-10-11 16:10:23 +02:00
renamed : [ "repos" , "getCommitSignatureProtection" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
getProtectedBranchRequiredStatusChecks : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks" , { } , {
renamed : [ "repos" , "getStatusChecksProtection" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
getProtectedBranchRestrictions : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions" , { } , {
renamed : [ "repos" , "getAccessRestrictions" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
getPullRequestReviewProtection : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews" ] ,
getPunchCardStats : [ "GET /repos/{owner}/{repo}/stats/punch_card" ] ,
getReadme : [ "GET /repos/{owner}/{repo}/readme" ] ,
getRelease : [ "GET /repos/{owner}/{repo}/releases/{release_id}" ] ,
getReleaseAsset : [ "GET /repos/{owner}/{repo}/releases/assets/{asset_id}" ] ,
getReleaseByTag : [ "GET /repos/{owner}/{repo}/releases/tags/{tag}" ] ,
getStatusChecksProtection : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks" ] ,
getTeamsWithAccessToProtectedBranch : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams" ] ,
getTopPaths : [ "GET /repos/{owner}/{repo}/traffic/popular/paths" ] ,
getTopReferrers : [ "GET /repos/{owner}/{repo}/traffic/popular/referrers" ] ,
getUsersWithAccessToProtectedBranch : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users" ] ,
getViews : [ "GET /repos/{owner}/{repo}/traffic/views" ] ,
getWebhook : [ "GET /repos/{owner}/{repo}/hooks/{hook_id}" ] ,
list : [ "GET /user/repos" , { } , {
renamed : [ "repos" , "listForAuthenticatedUser" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
listAssetsForRelease : [ "GET /repos/{owner}/{repo}/releases/{release_id}/assets" , { } , {
renamed : [ "repos" , "listReleaseAssets" ]
} ] ,
listBranches : [ "GET /repos/{owner}/{repo}/branches" ] ,
listBranchesForHeadCommit : [ "GET /repos/{owner}/{repo}/commits/{commit_sha}/branches-where-head" , {
2021-12-01 13:39:57 +01:00
mediaType : {
2022-10-11 16:10:23 +02:00
previews : [ "groot" ]
2021-12-01 13:39:57 +01:00
}
} ] ,
2022-10-11 16:10:23 +02:00
listCollaborators : [ "GET /repos/{owner}/{repo}/collaborators" ] ,
listCommentsForCommit : [ "GET /repos/{owner}/{repo}/commits/{commit_sha}/comments" ] ,
listCommitComments : [ "GET /repos/{owner}/{repo}/comments" , { } , {
renamed : [ "repos" , "listCommitCommentsForRepo" ]
} ] ,
listCommitCommentsForRepo : [ "GET /repos/{owner}/{repo}/comments" ] ,
listCommitStatusesForRef : [ "GET /repos/{owner}/{repo}/commits/{ref}/statuses" ] ,
listCommits : [ "GET /repos/{owner}/{repo}/commits" ] ,
listContributors : [ "GET /repos/{owner}/{repo}/contributors" ] ,
listDeployKeys : [ "GET /repos/{owner}/{repo}/keys" ] ,
listDeploymentStatuses : [ "GET /repos/{owner}/{repo}/deployments/{deployment_id}/statuses" ] ,
listDeployments : [ "GET /repos/{owner}/{repo}/deployments" ] ,
listDownloads : [ "GET /repos/{owner}/{repo}/downloads" ] ,
listForAuthenticatedUser : [ "GET /user/repos" ] ,
listForOrg : [ "GET /orgs/{org}/repos" ] ,
listForUser : [ "GET /users/{username}/repos" ] ,
listForks : [ "GET /repos/{owner}/{repo}/forks" ] ,
listHooks : [ "GET /repos/{owner}/{repo}/hooks" , { } , {
renamed : [ "repos" , "listWebhooks" ]
} ] ,
listInvitations : [ "GET /repos/{owner}/{repo}/invitations" ] ,
listInvitationsForAuthenticatedUser : [ "GET /user/repository_invitations" ] ,
listLanguages : [ "GET /repos/{owner}/{repo}/languages" ] ,
listPagesBuilds : [ "GET /repos/{owner}/{repo}/pages/builds" ] ,
listProtectedBranchRequiredStatusChecksContexts : [ "GET /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts" , { } , {
renamed : [ "repos" , "getAllStatusCheckContexts" ]
} ] ,
listPublic : [ "GET /repositories" ] ,
listPullRequestsAssociatedWithCommit : [ "GET /repos/{owner}/{repo}/commits/{commit_sha}/pulls" , {
2021-12-01 13:39:57 +01:00
mediaType : {
2022-10-11 16:10:23 +02:00
previews : [ "groot" ]
2021-12-01 13:39:57 +01:00
}
} ] ,
2022-10-11 16:10:23 +02:00
listReleaseAssets : [ "GET /repos/{owner}/{repo}/releases/{release_id}/assets" ] ,
listReleases : [ "GET /repos/{owner}/{repo}/releases" ] ,
listStatusesForRef : [ "GET /repos/{owner}/{repo}/commits/{ref}/statuses" , { } , {
renamed : [ "repos" , "listCommitStatusesForRef" ]
} ] ,
listTags : [ "GET /repos/{owner}/{repo}/tags" ] ,
listTeams : [ "GET /repos/{owner}/{repo}/teams" ] ,
listTopics : [ "GET /repos/{owner}/{repo}/topics" , {
2021-12-01 13:39:57 +01:00
mediaType : {
2022-10-11 16:10:23 +02:00
previews : [ "mercy" ]
2021-12-01 13:39:57 +01:00
}
2022-10-11 16:10:23 +02:00
} , {
renamed : [ "repos" , "getAllTopics" ]
} ] ,
listWebhooks : [ "GET /repos/{owner}/{repo}/hooks" ] ,
merge : [ "POST /repos/{owner}/{repo}/merges" ] ,
pingHook : [ "POST /repos/{owner}/{repo}/hooks/{hook_id}/pings" , { } , {
renamed : [ "repos" , "pingWebhook" ]
} ] ,
pingWebhook : [ "POST /repos/{owner}/{repo}/hooks/{hook_id}/pings" ] ,
removeAppAccessRestrictions : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps" , { } , {
2021-12-01 13:39:57 +01:00
mapToData : "apps"
} ] ,
2022-10-11 16:10:23 +02:00
removeBranchProtection : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection" , { } , {
renamed : [ "repos" , "deleteBranchProtection" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
removeCollaborator : [ "DELETE /repos/{owner}/{repo}/collaborators/{username}" ] ,
removeDeployKey : [ "DELETE /repos/{owner}/{repo}/keys/{key_id}" , { } , {
renamed : [ "repos" , "deleteDeployKey" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
removeProtectedBranchAdminEnforcement : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins" , { } , {
renamed : [ "repos" , "deleteAdminBranchProtection" ]
} ] ,
removeProtectedBranchAppRestrictions : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps" , { } , {
2021-12-01 13:39:57 +01:00
mapToData : "apps" ,
2022-10-11 16:10:23 +02:00
renamed : [ "repos" , "removeAppAccessRestrictions" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
removeProtectedBranchPullRequestReviewEnforcement : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews" , { } , {
renamed : [ "repos" , "deletePullRequestReviewProtection" ]
} ] ,
removeProtectedBranchRequiredSignatures : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures" , {
2021-12-01 13:39:57 +01:00
mediaType : {
previews : [ "zzzax" ]
}
} , {
2022-10-11 16:10:23 +02:00
renamed : [ "repos" , "deleteCommitSignatureProtection" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
removeProtectedBranchRequiredStatusChecks : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks" , { } , {
renamed : [ "repos" , "removeStatusChecksProtection" ]
} ] ,
removeProtectedBranchRequiredStatusChecksContexts : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts" , { } , {
2021-12-01 13:39:57 +01:00
mapToData : "contexts" ,
2022-10-11 16:10:23 +02:00
renamed : [ "repos" , "removeStatusCheckContexts" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
removeProtectedBranchRestrictions : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions" , { } , {
renamed : [ "repos" , "deleteAccessRestrictions" ]
} ] ,
removeProtectedBranchTeamRestrictions : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams" , { } , {
2021-12-01 13:39:57 +01:00
mapToData : "teams" ,
2022-10-11 16:10:23 +02:00
renamed : [ "repos" , "removeTeamAccessRestrictions" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
removeProtectedBranchUserRestrictions : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users" , { } , {
2021-12-01 13:39:57 +01:00
mapToData : "users" ,
2022-10-11 16:10:23 +02:00
renamed : [ "repos" , "removeUserAccessRestrictions" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
removeStatusCheckContexts : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts" , { } , {
2021-12-01 13:39:57 +01:00
mapToData : "contexts"
} ] ,
2022-10-11 16:10:23 +02:00
removeStatusCheckProtection : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks" ] ,
removeTeamAccessRestrictions : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams" , { } , {
2021-12-01 13:39:57 +01:00
mapToData : "teams"
} ] ,
2022-10-11 16:10:23 +02:00
removeUserAccessRestrictions : [ "DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users" , { } , {
2021-12-01 13:39:57 +01:00
mapToData : "users"
} ] ,
2022-10-11 16:10:23 +02:00
replaceAllTopics : [ "PUT /repos/{owner}/{repo}/topics" , {
2021-12-01 13:39:57 +01:00
mediaType : {
2022-10-11 16:10:23 +02:00
previews : [ "mercy" ]
2021-12-01 13:39:57 +01:00
}
} ] ,
2022-10-11 16:10:23 +02:00
replaceProtectedBranchAppRestrictions : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps" , { } , {
mapToData : "apps" ,
renamed : [ "repos" , "setAppAccessRestrictions" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
replaceProtectedBranchRequiredStatusChecksContexts : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts" , { } , {
mapToData : "contexts" ,
renamed : [ "repos" , "setStatusCheckContexts" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
replaceProtectedBranchTeamRestrictions : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams" , { } , {
mapToData : "teams" ,
renamed : [ "repos" , "setTeamAccessRestrictions" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
replaceProtectedBranchUserRestrictions : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users" , { } , {
mapToData : "users" ,
renamed : [ "repos" , "setUserAccessRestrictions" ]
} ] ,
replaceTopics : [ "PUT /repos/{owner}/{repo}/topics" , {
2021-12-01 13:39:57 +01:00
mediaType : {
2022-10-11 16:10:23 +02:00
previews : [ "mercy" ]
2021-12-01 13:39:57 +01:00
}
2022-10-11 16:10:23 +02:00
} , {
renamed : [ "repos" , "replaceAllTopics" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
requestPageBuild : [ "POST /repos/{owner}/{repo}/pages/builds" , { } , {
renamed : [ "repos" , "requestPagesBuild" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
requestPagesBuild : [ "POST /repos/{owner}/{repo}/pages/builds" ] ,
retrieveCommunityProfileMetrics : [ "GET /repos/{owner}/{repo}/community/profile" , { } , {
renamed : [ "repos" , "getCommunityProfileMetrics" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
setAdminBranchProtection : [ "POST /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins" ] ,
setAppAccessRestrictions : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps" , { } , {
mapToData : "apps"
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
setStatusCheckContexts : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts" , { } , {
mapToData : "contexts"
} ] ,
setTeamAccessRestrictions : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams" , { } , {
mapToData : "teams"
} ] ,
setUserAccessRestrictions : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users" , { } , {
mapToData : "users"
} ] ,
testPushHook : [ "POST /repos/{owner}/{repo}/hooks/{hook_id}/tests" , { } , {
renamed : [ "repos" , "testPushWebhook" ]
} ] ,
testPushWebhook : [ "POST /repos/{owner}/{repo}/hooks/{hook_id}/tests" ] ,
transfer : [ "POST /repos/{owner}/{repo}/transfer" ] ,
update : [ "PATCH /repos/{owner}/{repo}" ] ,
updateBranchProtection : [ "PUT /repos/{owner}/{repo}/branches/{branch}/protection" ] ,
updateCommitComment : [ "PATCH /repos/{owner}/{repo}/comments/{comment_id}" ] ,
updateHook : [ "PATCH /repos/{owner}/{repo}/hooks/{hook_id}" , { } , {
renamed : [ "repos" , "updateWebhook" ]
} ] ,
updateInformationAboutPagesSite : [ "PUT /repos/{owner}/{repo}/pages" ] ,
updateInvitation : [ "PATCH /repos/{owner}/{repo}/invitations/{invitation_id}" ] ,
updateProtectedBranchPullRequestReviewEnforcement : [ "PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews" , { } , {
renamed : [ "repos" , "updatePullRequestReviewProtection" ]
} ] ,
updateProtectedBranchRequiredStatusChecks : [ "PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks" , { } , {
renamed : [ "repos" , "updateStatusChecksProtection" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
updatePullRequestReviewProtection : [ "PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews" ] ,
updateRelease : [ "PATCH /repos/{owner}/{repo}/releases/{release_id}" ] ,
updateReleaseAsset : [ "PATCH /repos/{owner}/{repo}/releases/assets/{asset_id}" ] ,
updateStatusCheckPotection : [ "PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks" ] ,
updateWebhook : [ "PATCH /repos/{owner}/{repo}/hooks/{hook_id}" ] ,
uploadReleaseAsset : [ "POST /repos/{owner}/{repo}/releases/{release_id}/assets{?name,label}" , {
baseUrl : "https://uploads.github.com"
} ]
} ,
search : {
code : [ "GET /search/code" ] ,
commits : [ "GET /search/commits" , {
2021-12-01 13:39:57 +01:00
mediaType : {
2022-10-11 16:10:23 +02:00
previews : [ "cloak" ]
2021-12-01 13:39:57 +01:00
}
} ] ,
2022-10-11 16:10:23 +02:00
issuesAndPullRequests : [ "GET /search/issues" ] ,
labels : [ "GET /search/labels" ] ,
repos : [ "GET /search/repositories" ] ,
topics : [ "GET /search/topics" ] ,
users : [ "GET /search/users" ]
} ,
teams : {
addOrUpdateMembershipForUserInOrg : [ "PUT /orgs/{org}/teams/{team_slug}/memberships/{username}" ] ,
addOrUpdateMembershipInOrg : [ "PUT /orgs/{org}/teams/{team_slug}/memberships/{username}" , { } , {
renamed : [ "teams" , "addOrUpdateMembershipForUserInOrg" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
addOrUpdateProjectInOrg : [ "PUT /orgs/{org}/teams/{team_slug}/projects/{project_id}" , {
2021-12-01 13:39:57 +01:00
mediaType : {
2022-10-11 16:10:23 +02:00
previews : [ "inertia" ]
2021-12-01 13:39:57 +01:00
}
} , {
2022-10-11 16:10:23 +02:00
renamed : [ "teams" , "addOrUpdateProjectPermissionsInOrg" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
addOrUpdateProjectPermissionsInOrg : [ "PUT /orgs/{org}/teams/{team_slug}/projects/{project_id}" , {
2021-12-01 13:39:57 +01:00
mediaType : {
2022-10-11 16:10:23 +02:00
previews : [ "inertia" ]
2021-12-01 13:39:57 +01:00
}
} ] ,
2022-10-11 16:10:23 +02:00
addOrUpdateRepoInOrg : [ "PUT /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}" , { } , {
renamed : [ "teams" , "addOrUpdateRepoPermissionsInOrg" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
addOrUpdateRepoPermissionsInOrg : [ "PUT /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}" ] ,
checkManagesRepoInOrg : [ "GET /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}" , { } , {
renamed : [ "teams" , "checkPermissionsForRepoInOrg" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
checkPermissionsForProjectInOrg : [ "GET /orgs/{org}/teams/{team_slug}/projects/{project_id}" , {
2021-12-01 13:39:57 +01:00
mediaType : {
2022-10-11 16:10:23 +02:00
previews : [ "inertia" ]
2021-12-01 13:39:57 +01:00
}
} ] ,
2022-10-11 16:10:23 +02:00
checkPermissionsForRepoInOrg : [ "GET /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}" ] ,
create : [ "POST /orgs/{org}/teams" ] ,
createDiscussionCommentInOrg : [ "POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments" ] ,
createDiscussionInOrg : [ "POST /orgs/{org}/teams/{team_slug}/discussions" ] ,
deleteDiscussionCommentInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}" ] ,
deleteDiscussionInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}" ] ,
deleteInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}" ] ,
getByName : [ "GET /orgs/{org}/teams/{team_slug}" ] ,
getDiscussionCommentInOrg : [ "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}" ] ,
getDiscussionInOrg : [ "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}" ] ,
getMembershipForUserInOrg : [ "GET /orgs/{org}/teams/{team_slug}/memberships/{username}" ] ,
getMembershipInOrg : [ "GET /orgs/{org}/teams/{team_slug}/memberships/{username}" , { } , {
renamed : [ "teams" , "getMembershipForUserInOrg" ]
} ] ,
list : [ "GET /orgs/{org}/teams" ] ,
listChildInOrg : [ "GET /orgs/{org}/teams/{team_slug}/teams" ] ,
listDiscussionCommentsInOrg : [ "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments" ] ,
listDiscussionsInOrg : [ "GET /orgs/{org}/teams/{team_slug}/discussions" ] ,
listForAuthenticatedUser : [ "GET /user/teams" ] ,
listMembersInOrg : [ "GET /orgs/{org}/teams/{team_slug}/members" ] ,
listPendingInvitationsInOrg : [ "GET /orgs/{org}/teams/{team_slug}/invitations" ] ,
listProjectsInOrg : [ "GET /orgs/{org}/teams/{team_slug}/projects" , {
2021-12-01 13:39:57 +01:00
mediaType : {
2022-10-11 16:10:23 +02:00
previews : [ "inertia" ]
2021-12-01 13:39:57 +01:00
}
} ] ,
2022-10-11 16:10:23 +02:00
listReposInOrg : [ "GET /orgs/{org}/teams/{team_slug}/repos" ] ,
removeMembershipForUserInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}/memberships/{username}" ] ,
removeMembershipInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}/memberships/{username}" , { } , {
renamed : [ "teams" , "removeMembershipForUserInOrg" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
removeProjectInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}/projects/{project_id}" ] ,
removeRepoInOrg : [ "DELETE /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}" ] ,
reviewProjectInOrg : [ "GET /orgs/{org}/teams/{team_slug}/projects/{project_id}" , {
2021-12-01 13:39:57 +01:00
mediaType : {
2022-10-11 16:10:23 +02:00
previews : [ "inertia" ]
2021-12-01 13:39:57 +01:00
}
2022-10-11 16:10:23 +02:00
} , {
renamed : [ "teams" , "checkPermissionsForProjectInOrg" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
updateDiscussionCommentInOrg : [ "PATCH /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}" ] ,
updateDiscussionInOrg : [ "PATCH /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}" ] ,
updateInOrg : [ "PATCH /orgs/{org}/teams/{team_slug}" ]
} ,
users : {
addEmailForAuthenticated : [ "POST /user/emails" ] ,
addEmails : [ "POST /user/emails" , { } , {
renamed : [ "users" , "addEmailsForAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
block : [ "PUT /user/blocks/{username}" ] ,
checkBlocked : [ "GET /user/blocks/{username}" ] ,
checkFollowing : [ "GET /user/following/{username}" , { } , {
renamed : [ "users" , "checkPersonIsFollowedByAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
checkFollowingForUser : [ "GET /users/{username}/following/{target_user}" ] ,
checkPersonIsFollowedByAuthenticated : [ "GET /user/following/{username}" ] ,
createGpgKey : [ "POST /user/gpg_keys" , { } , {
renamed : [ "users" , "createGpgKeyForAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
createGpgKeyForAuthenticated : [ "POST /user/gpg_keys" ] ,
createPublicKey : [ "POST /user/keys" , { } , {
renamed : [ "users" , "createPublicSshKeyForAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
createPublicSshKeyForAuthenticated : [ "POST /user/keys" ] ,
deleteEmailForAuthenticated : [ "DELETE /user/emails" ] ,
deleteEmails : [ "DELETE /user/emails" , { } , {
renamed : [ "users" , "deleteEmailsForAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
deleteGpgKey : [ "DELETE /user/gpg_keys/{gpg_key_id}" , { } , {
renamed : [ "users" , "deleteGpgKeyForAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
deleteGpgKeyForAuthenticated : [ "DELETE /user/gpg_keys/{gpg_key_id}" ] ,
deletePublicKey : [ "DELETE /user/keys/{key_id}" , { } , {
renamed : [ "users" , "deletePublicSshKeyForAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
deletePublicSshKeyForAuthenticated : [ "DELETE /user/keys/{key_id}" ] ,
follow : [ "PUT /user/following/{username}" ] ,
getAuthenticated : [ "GET /user" ] ,
getByUsername : [ "GET /users/{username}" ] ,
getContextForUser : [ "GET /users/{username}/hovercard" ] ,
getGpgKey : [ "GET /user/gpg_keys/{gpg_key_id}" , { } , {
renamed : [ "users" , "getGpgKeyForAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
getGpgKeyForAuthenticated : [ "GET /user/gpg_keys/{gpg_key_id}" ] ,
getPublicKey : [ "GET /user/keys/{key_id}" , { } , {
renamed : [ "users" , "getPublicSshKeyForAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
getPublicSshKeyForAuthenticated : [ "GET /user/keys/{key_id}" ] ,
list : [ "GET /users" ] ,
listBlocked : [ "GET /user/blocks" , { } , {
renamed : [ "users" , "listBlockedByAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
listBlockedByAuthenticated : [ "GET /user/blocks" ] ,
listEmails : [ "GET /user/emails" , { } , {
renamed : [ "users" , "listEmailsForAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
listEmailsForAuthenticated : [ "GET /user/emails" ] ,
listFollowedByAuthenticated : [ "GET /user/following" ] ,
listFollowersForAuthenticatedUser : [ "GET /user/followers" ] ,
listFollowersForUser : [ "GET /users/{username}/followers" ] ,
listFollowingForAuthenticatedUser : [ "GET /user/following" , { } , {
renamed : [ "users" , "listFollowedByAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
listFollowingForUser : [ "GET /users/{username}/following" ] ,
listGpgKeys : [ "GET /user/gpg_keys" , { } , {
renamed : [ "users" , "listGpgKeysForAuthenticated" ]
} ] ,
listGpgKeysForAuthenticated : [ "GET /user/gpg_keys" ] ,
listGpgKeysForUser : [ "GET /users/{username}/gpg_keys" ] ,
listPublicEmails : [ "GET /user/public_emails" , { } , {
renamed : [ "users" , "listPublicEmailsForAuthenticatedUser" ]
} ] ,
listPublicEmailsForAuthenticated : [ "GET /user/public_emails" ] ,
listPublicKeys : [ "GET /user/keys" , { } , {
renamed : [ "users" , "listPublicSshKeysForAuthenticated" ]
2021-12-01 13:39:57 +01:00
} ] ,
2022-10-11 16:10:23 +02:00
listPublicKeysForUser : [ "GET /users/{username}/keys" ] ,
listPublicSshKeysForAuthenticated : [ "GET /user/keys" ] ,
setPrimaryEmailVisibilityForAuthenticated : [ "PATCH /user/email/visibility" ] ,
togglePrimaryEmailVisibility : [ "PATCH /user/email/visibility" , { } , {
renamed : [ "users" , "setPrimaryEmailVisibilityForAuthenticated" ]
} ] ,
unblock : [ "DELETE /user/blocks/{username}" ] ,
unfollow : [ "DELETE /user/following/{username}" ] ,
updateAuthenticated : [ "PATCH /user" ]
}
} ;
const VERSION = "3.17.0" ;
function endpointsToMethods ( octokit , endpointsMap ) {
const newMethods = { } ;
for ( const [ scope , endpoints ] of Object . entries ( endpointsMap ) ) {
for ( const [ methodName , endpoint ] of Object . entries ( endpoints ) ) {
const [ route , defaults , decorations ] = endpoint ;
const [ method , url ] = route . split ( / / ) ;
const endpointDefaults = Object . assign ( {
method ,
url
} , defaults ) ;
if ( ! newMethods [ scope ] ) {
newMethods [ scope ] = { } ;
}
const scopeMethods = newMethods [ scope ] ;
if ( decorations ) {
scopeMethods [ methodName ] = decorate ( octokit , scope , methodName , endpointDefaults , decorations ) ;
continue ;
}
scopeMethods [ methodName ] = octokit . request . defaults ( endpointDefaults ) ;
}
}
return newMethods ;
}
function decorate ( octokit , scope , methodName , defaults , decorations ) {
const requestWithDefaults = octokit . request . defaults ( defaults ) ;
function withDecorations ( ... args ) {
// @ts-ignore https://github.com/microsoft/TypeScript/issues/25488
let options = requestWithDefaults . endpoint . merge ( ... args ) ; // There are currently no other decorations than `.mapToData`
if ( decorations . mapToData ) {
options = Object . assign ( { } , options , {
data : options [ decorations . mapToData ] ,
[ decorations . mapToData ] : undefined
} ) ;
return requestWithDefaults ( options ) ;
} // NOTE: there are currently no deprecations. But we keep the code
// below for future reference
if ( decorations . renamed ) {
const [ newScope , newMethodName ] = decorations . renamed ;
octokit . log . warn ( ` octokit. ${ scope } . ${ methodName } () has been renamed to octokit. ${ newScope } . ${ newMethodName } () ` ) ;
}
if ( decorations . deprecated ) {
octokit . log . warn ( decorations . deprecated ) ;
}
if ( decorations . renamedParameters ) {
// @ts-ignore https://github.com/microsoft/TypeScript/issues/25488
const options = requestWithDefaults . endpoint . merge ( ... args ) ;
for ( const [ name , alias ] of Object . entries ( decorations . renamedParameters ) ) {
// There is currently no deprecated parameter that is optional,
// so we never hit the else branch below at this point.
/* istanbul ignore else */
if ( name in options ) {
octokit . log . warn ( ` " ${ name } " parameter is deprecated for "octokit. ${ scope } . ${ methodName } ()". Use " ${ alias } " instead ` ) ;
if ( ! ( alias in options ) ) {
options [ alias ] = options [ name ] ;
}
delete options [ name ] ;
}
}
return requestWithDefaults ( options ) ;
} // @ts-ignore https://github.com/microsoft/TypeScript/issues/25488
return requestWithDefaults ( ... args ) ;
}
return Object . assign ( withDecorations , requestWithDefaults ) ;
}
/ * *
* This plugin is a 1 : 1 copy of internal @ octokit / rest plugins . The primary
* goal is to rebuild @ octokit / rest on top of @ octokit / core . Once that is
* done , we will remove the registerEndpoints methods and return the methods
* directly as with the other plugins . At that point we will also remove the
* legacy workarounds and deprecations .
*
* See the plan at
* https : //github.com/octokit/plugin-rest-endpoint-methods.js/pull/1
* /
function restEndpointMethods ( octokit ) {
return endpointsToMethods ( octokit , Endpoints ) ;
}
restEndpointMethods . VERSION = VERSION ;
exports . restEndpointMethods = restEndpointMethods ;
//# sourceMappingURL=index.js.map
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 5375 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var core = _ _nccwpck _require _ _ ( 4952 ) ;
var pluginRequestLog = _ _nccwpck _require _ _ ( 8883 ) ;
var pluginPaginateRest = _ _nccwpck _require _ _ ( 4193 ) ;
var pluginRestEndpointMethods = _ _nccwpck _require _ _ ( 3044 ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const VERSION = "17.11.2" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const Octokit = core . Octokit . plugin ( pluginRequestLog . requestLog , pluginRestEndpointMethods . restEndpointMethods , pluginPaginateRest . paginateRest ) . defaults ( {
userAgent : ` octokit-rest.js/ ${ VERSION } `
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . Octokit = Octokit ;
//# sourceMappingURL=index.js.map
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 7633 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const REGEX _IS _INSTALLATION _LEGACY = /^v1\./ ;
const REGEX _IS _INSTALLATION = /^ghs_/ ;
const REGEX _IS _USER _TO _SERVER = /^ghu_/ ;
async function auth ( token ) {
const isApp = token . split ( /\./ ) . length === 3 ;
const isInstallation = REGEX _IS _INSTALLATION _LEGACY . test ( token ) || REGEX _IS _INSTALLATION . test ( token ) ;
const isUserToServer = REGEX _IS _USER _TO _SERVER . test ( token ) ;
const tokenType = isApp ? "app" : isInstallation ? "installation" : isUserToServer ? "user-to-server" : "oauth" ;
return {
type : "token" ,
token : token ,
tokenType
} ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Prefix token for usage in the Authorization header
*
* @ param token OAuth token or JSON Web Token
* /
function withAuthorizationPrefix ( token ) {
if ( token . split ( /\./ ) . length === 3 ) {
return ` bearer ${ token } ` ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
return ` token ${ token } ` ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
async function hook ( token , request , route , parameters ) {
const endpoint = request . endpoint . merge ( route , parameters ) ;
endpoint . headers . authorization = withAuthorizationPrefix ( token ) ;
return request ( endpoint ) ;
}
const createTokenAuth = function createTokenAuth ( token ) {
if ( ! token ) {
throw new Error ( "[@octokit/auth-token] No token passed to createTokenAuth" ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( typeof token !== "string" ) {
throw new Error ( "[@octokit/auth-token] Token passed to createTokenAuth is not a string" ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
token = token . replace ( /^(token|bearer) +/i , "" ) ;
return Object . assign ( auth . bind ( null , token ) , {
hook : hook . bind ( null , token )
2022-10-11 16:10:23 +02:00
} ) ;
2024-05-19 08:24:38 +02:00
} ;
exports . createTokenAuth = createTokenAuth ;
//# sourceMappingURL=index.js.map
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 4952 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2022-10-12 17:48:05 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var universalUserAgent = _ _nccwpck _require _ _ ( 1251 ) ;
var beforeAfterHook = _ _nccwpck _require _ _ ( 3682 ) ;
var request = _ _nccwpck _require _ _ ( 6206 ) ;
var graphql = _ _nccwpck _require _ _ ( 7461 ) ;
var authToken = _ _nccwpck _require _ _ ( 7633 ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function _defineProperty ( obj , key , value ) {
if ( key in obj ) {
Object . defineProperty ( obj , key , {
value : value ,
enumerable : true ,
configurable : true ,
writable : true
} ) ;
} else {
obj [ key ] = value ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return obj ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function ownKeys ( object , enumerableOnly ) {
var keys = Object . keys ( object ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( Object . getOwnPropertySymbols ) {
var symbols = Object . getOwnPropertySymbols ( object ) ;
if ( enumerableOnly ) symbols = symbols . filter ( function ( sym ) {
return Object . getOwnPropertyDescriptor ( object , sym ) . enumerable ;
} ) ;
keys . push . apply ( keys , symbols ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return keys ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function _objectSpread2 ( target ) {
for ( var i = 1 ; i < arguments . length ; i ++ ) {
var source = arguments [ i ] != null ? arguments [ i ] : { } ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( i % 2 ) {
ownKeys ( Object ( source ) , true ) . forEach ( function ( key ) {
_defineProperty ( target , key , source [ key ] ) ;
} ) ;
} else if ( Object . getOwnPropertyDescriptors ) {
Object . defineProperties ( target , Object . getOwnPropertyDescriptors ( source ) ) ;
2022-10-11 16:10:23 +02:00
} else {
2024-05-19 08:24:38 +02:00
ownKeys ( Object ( source ) ) . forEach ( function ( key ) {
Object . defineProperty ( target , key , Object . getOwnPropertyDescriptor ( source , key ) ) ;
} ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return target ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
const VERSION = "2.5.4" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
class Octokit {
constructor ( options = { } ) {
const hook = new beforeAfterHook . Collection ( ) ;
const requestDefaults = {
baseUrl : request . request . endpoint . DEFAULTS . baseUrl ,
headers : { } ,
request : Object . assign ( { } , options . request , {
hook : hook . bind ( null , "request" )
} ) ,
mediaType : {
previews : [ ] ,
format : ""
}
} ; // prepend default user agent with `options.userAgent` if set
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
requestDefaults . headers [ "user-agent" ] = [ options . userAgent , ` octokit-core.js/ ${ VERSION } ${ universalUserAgent . getUserAgent ( ) } ` ] . filter ( Boolean ) . join ( " " ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( options . baseUrl ) {
requestDefaults . baseUrl = options . baseUrl ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( options . previews ) {
requestDefaults . mediaType . previews = options . previews ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( options . timeZone ) {
requestDefaults . headers [ "time-zone" ] = options . timeZone ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
this . request = request . request . defaults ( requestDefaults ) ;
this . graphql = graphql . withCustomRequest ( this . request ) . defaults ( _objectSpread2 ( _objectSpread2 ( { } , requestDefaults ) , { } , {
baseUrl : requestDefaults . baseUrl . replace ( /\/api\/v3$/ , "/api" )
} ) ) ;
this . log = Object . assign ( {
debug : ( ) => { } ,
info : ( ) => { } ,
warn : console . warn . bind ( console ) ,
error : console . error . bind ( console )
} , options . log ) ;
this . hook = hook ; // (1) If neither `options.authStrategy` nor `options.auth` are set, the `octokit` instance
// is unauthenticated. The `this.auth()` method is a no-op and no request hook is registred.
// (2) If only `options.auth` is set, use the default token authentication strategy.
// (3) If `options.authStrategy` is set then use it and pass in `options.auth`. Always pass own request as many strategies accept a custom request instance.
// TODO: type `options.auth` based on `options.authStrategy`.
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! options . authStrategy ) {
if ( ! options . auth ) {
// (1)
this . auth = async ( ) => ( {
type : "unauthenticated"
} ) ;
} else {
// (2)
const auth = authToken . createTokenAuth ( options . auth ) ; // @ts-ignore ¯\_(ツ)_/¯
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
hook . wrap ( "request" , auth . hook ) ;
this . auth = auth ;
}
} else {
const auth = options . authStrategy ( Object . assign ( {
request : this . request
} , options . auth ) ) ; // @ts-ignore ¯\_(ツ)_/¯
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
hook . wrap ( "request" , auth . hook ) ;
this . auth = auth ;
} // apply plugins
// https://stackoverflow.com/a/16345172
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const classConstructor = this . constructor ;
classConstructor . plugins . forEach ( plugin => {
Object . assign ( this , plugin ( this , options ) ) ;
} ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
static defaults ( defaults ) {
const OctokitWithDefaults = class extends this {
constructor ( ... args ) {
const options = args [ 0 ] || { } ;
super ( Object . assign ( { } , defaults , options , options . userAgent && defaults . userAgent ? {
userAgent : ` ${ options . userAgent } ${ defaults . userAgent } `
} : null ) ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
} ;
return OctokitWithDefaults ;
}
/ * *
* Attach a plugin ( or many ) to your Octokit instance .
*
* @ example
* const API = Octokit . plugin ( plugin1 , plugin2 , plugin3 , ... )
* /
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
static plugin ( p1 , ... p2 ) {
var _a ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( p1 instanceof Array ) {
console . warn ( [ "Passing an array of plugins to Octokit.plugin() has been deprecated." , "Instead of:" , " Octokit.plugin([plugin1, plugin2, ...])" , "Use:" , " Octokit.plugin(plugin1, plugin2, ...)" ] . join ( "\n" ) ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const currentPlugins = this . plugins ;
let newPlugins = [ ... ( p1 instanceof Array ? p1 : [ p1 ] ) , ... p2 ] ;
const NewOctokit = ( _a = class extends this { } , _a . plugins = currentPlugins . concat ( newPlugins . filter ( plugin => ! currentPlugins . includes ( plugin ) ) ) , _a ) ;
return NewOctokit ;
2022-10-12 17:48:05 +02:00
}
}
2024-05-19 08:24:38 +02:00
Octokit . VERSION = VERSION ;
Octokit . plugins = [ ] ;
exports . Octokit = Octokit ;
//# sourceMappingURL=index.js.map
2022-10-12 17:48:05 +02:00
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 1251 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function _interopDefault ( ex ) { return ( ex && ( typeof ex === 'object' ) && 'default' in ex ) ? ex [ 'default' ] : ex ; }
var osName = _interopDefault ( _ _nccwpck _require _ _ ( 4824 ) ) ;
function getUserAgent ( ) {
try {
return ` Node.js/ ${ process . version . substr ( 1 ) } ( ${ osName ( ) } ; ${ process . arch } ) ` ;
} catch ( error ) {
if ( /wmic os get Caption/ . test ( error . message ) ) {
return "Windows <version undetectable>" ;
}
return "<environment undetectable>" ;
}
}
exports . getUserAgent = getUserAgent ;
//# sourceMappingURL=index.js.map
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 6065 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
var isPlainObject = _ _nccwpck _require _ _ ( 3287 ) ;
var universalUserAgent = _ _nccwpck _require _ _ ( 5030 ) ;
function lowercaseKeys ( object ) {
if ( ! object ) {
return { } ;
}
return Object . keys ( object ) . reduce ( ( newObj , key ) => {
newObj [ key . toLowerCase ( ) ] = object [ key ] ;
return newObj ;
} , { } ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function mergeDeep ( defaults , options ) {
const result = Object . assign ( { } , defaults ) ;
Object . keys ( options ) . forEach ( key => {
if ( isPlainObject . isPlainObject ( options [ key ] ) ) {
if ( ! ( key in defaults ) ) Object . assign ( result , {
[ key ] : options [ key ]
} ) ; else result [ key ] = mergeDeep ( defaults [ key ] , options [ key ] ) ;
} else {
Object . assign ( result , {
[ key ] : options [ key ]
} ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
} ) ;
return result ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function removeUndefinedProperties ( obj ) {
for ( const key in obj ) {
if ( obj [ key ] === undefined ) {
delete obj [ key ] ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
}
return obj ;
}
function merge ( defaults , route , options ) {
if ( typeof route === "string" ) {
let [ method , url ] = route . split ( " " ) ;
options = Object . assign ( url ? {
method ,
url
} : {
url : method
} , options ) ;
} else {
options = Object . assign ( { } , route ) ;
} // lowercase header names before merging with defaults to avoid duplicates
options . headers = lowercaseKeys ( options . headers ) ; // remove properties with undefined values before merging
removeUndefinedProperties ( options ) ;
removeUndefinedProperties ( options . headers ) ;
const mergedOptions = mergeDeep ( defaults || { } , options ) ; // mediaType.previews arrays are merged, instead of overwritten
if ( defaults && defaults . mediaType . previews . length ) {
mergedOptions . mediaType . previews = defaults . mediaType . previews . filter ( preview => ! mergedOptions . mediaType . previews . includes ( preview ) ) . concat ( mergedOptions . mediaType . previews ) ;
}
mergedOptions . mediaType . previews = mergedOptions . mediaType . previews . map ( preview => preview . replace ( /-preview/ , "" ) ) ;
return mergedOptions ;
}
function addQueryParameters ( url , parameters ) {
const separator = /\?/ . test ( url ) ? "&" : "?" ;
const names = Object . keys ( parameters ) ;
if ( names . length === 0 ) {
return url ;
}
return url + separator + names . map ( name => {
if ( name === "q" ) {
return "q=" + parameters . q . split ( "+" ) . map ( encodeURIComponent ) . join ( "+" ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
return ` ${ name } = ${ encodeURIComponent ( parameters [ name ] ) } ` ;
} ) . join ( "&" ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
const urlVariableRegex = /\{[^}]+\}/g ;
function removeNonChars ( variableName ) {
return variableName . replace ( /^\W+|\W+$/g , "" ) . split ( /,/ ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function extractUrlVariableNames ( url ) {
const matches = url . match ( urlVariableRegex ) ;
if ( ! matches ) {
return [ ] ;
}
return matches . map ( removeNonChars ) . reduce ( ( a , b ) => a . concat ( b ) , [ ] ) ;
}
function omit ( object , keysToOmit ) {
return Object . keys ( object ) . filter ( option => ! keysToOmit . includes ( option ) ) . reduce ( ( obj , key ) => {
obj [ key ] = object [ key ] ;
return obj ;
} , { } ) ;
}
// Based on https://github.com/bramstein/url-template, licensed under BSD
// TODO: create separate package.
//
// Copyright (c) 2012-2014, Bram Stein
// All rights reserved.
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions
// are met:
// 1. Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// 2. Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
// 3. The name of the author may not be used to endorse or promote products
// derived from this software without specific prior written permission.
// THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED
// WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
// EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
// INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
// BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
/* istanbul ignore file */
function encodeReserved ( str ) {
return str . split ( /(%[0-9A-Fa-f]{2})/g ) . map ( function ( part ) {
if ( ! /%[0-9A-Fa-f]/ . test ( part ) ) {
part = encodeURI ( part ) . replace ( /%5B/g , "[" ) . replace ( /%5D/g , "]" ) ;
}
return part ;
} ) . join ( "" ) ;
}
function encodeUnreserved ( str ) {
return encodeURIComponent ( str ) . replace ( /[!'()*]/g , function ( c ) {
return "%" + c . charCodeAt ( 0 ) . toString ( 16 ) . toUpperCase ( ) ;
} ) ;
}
function encodeValue ( operator , value , key ) {
value = operator === "+" || operator === "#" ? encodeReserved ( value ) : encodeUnreserved ( value ) ;
if ( key ) {
return encodeUnreserved ( key ) + "=" + value ;
} else {
return value ;
}
}
function isDefined ( value ) {
return value !== undefined && value !== null ;
}
function isKeyOperator ( operator ) {
return operator === ";" || operator === "&" || operator === "?" ;
}
function getValues ( context , operator , key , modifier ) {
var value = context [ key ] ,
result = [ ] ;
if ( isDefined ( value ) && value !== "" ) {
if ( typeof value === "string" || typeof value === "number" || typeof value === "boolean" ) {
value = value . toString ( ) ;
if ( modifier && modifier !== "*" ) {
value = value . substring ( 0 , parseInt ( modifier , 10 ) ) ;
}
result . push ( encodeValue ( operator , value , isKeyOperator ( operator ) ? key : "" ) ) ;
} else {
if ( modifier === "*" ) {
if ( Array . isArray ( value ) ) {
value . filter ( isDefined ) . forEach ( function ( value ) {
result . push ( encodeValue ( operator , value , isKeyOperator ( operator ) ? key : "" ) ) ;
} ) ;
} else {
Object . keys ( value ) . forEach ( function ( k ) {
if ( isDefined ( value [ k ] ) ) {
result . push ( encodeValue ( operator , value [ k ] , k ) ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
} ) ;
}
} else {
const tmp = [ ] ;
if ( Array . isArray ( value ) ) {
value . filter ( isDefined ) . forEach ( function ( value ) {
tmp . push ( encodeValue ( operator , value ) ) ;
} ) ;
} else {
Object . keys ( value ) . forEach ( function ( k ) {
if ( isDefined ( value [ k ] ) ) {
tmp . push ( encodeUnreserved ( k ) ) ;
tmp . push ( encodeValue ( operator , value [ k ] . toString ( ) ) ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
} ) ;
}
if ( isKeyOperator ( operator ) ) {
result . push ( encodeUnreserved ( key ) + "=" + tmp . join ( "," ) ) ;
} else if ( tmp . length !== 0 ) {
result . push ( tmp . join ( "," ) ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
}
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
} else {
if ( operator === ";" ) {
if ( isDefined ( value ) ) {
result . push ( encodeUnreserved ( key ) ) ;
}
} else if ( value === "" && ( operator === "&" || operator === "?" ) ) {
result . push ( encodeUnreserved ( key ) + "=" ) ;
} else if ( value === "" ) {
result . push ( "" ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
}
return result ;
}
function parseUrl ( template ) {
return {
expand : expand . bind ( null , template )
} ;
}
function expand ( template , context ) {
var operators = [ "+" , "#" , "." , "/" , ";" , "?" , "&" ] ;
return template . replace ( /\{([^\{\}]+)\}|([^\{\}]+)/g , function ( _ , expression , literal ) {
if ( expression ) {
let operator = "" ;
const values = [ ] ;
if ( operators . indexOf ( expression . charAt ( 0 ) ) !== - 1 ) {
operator = expression . charAt ( 0 ) ;
expression = expression . substr ( 1 ) ;
}
expression . split ( /,/g ) . forEach ( function ( variable ) {
var tmp = /([^:\*]*)(?::(\d+)|(\*))?/ . exec ( variable ) ;
values . push ( getValues ( context , operator , tmp [ 1 ] , tmp [ 2 ] || tmp [ 3 ] ) ) ;
} ) ;
if ( operator && operator !== "+" ) {
var separator = "," ;
if ( operator === "?" ) {
separator = "&" ;
} else if ( operator !== "#" ) {
separator = operator ;
}
return ( values . length !== 0 ? operator : "" ) + values . join ( separator ) ;
} else {
return values . join ( "," ) ;
}
} else {
return encodeReserved ( literal ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
} ) ;
}
function parse ( options ) {
// https://fetch.spec.whatwg.org/#methods
let method = options . method . toUpperCase ( ) ; // replace :varname with {varname} to make it RFC 6570 compatible
let url = ( options . url || "/" ) . replace ( /:([a-z]\w+)/g , "{$1}" ) ;
let headers = Object . assign ( { } , options . headers ) ;
let body ;
let parameters = omit ( options , [ "method" , "baseUrl" , "url" , "headers" , "request" , "mediaType" ] ) ; // extract variable names from URL to calculate remaining variables later
const urlVariableNames = extractUrlVariableNames ( url ) ;
url = parseUrl ( url ) . expand ( parameters ) ;
if ( ! /^http/ . test ( url ) ) {
url = options . baseUrl + url ;
}
const omittedParameters = Object . keys ( options ) . filter ( option => urlVariableNames . includes ( option ) ) . concat ( "baseUrl" ) ;
const remainingParameters = omit ( parameters , omittedParameters ) ;
const isBinaryRequest = /application\/octet-stream/i . test ( headers . accept ) ;
if ( ! isBinaryRequest ) {
if ( options . mediaType . format ) {
// e.g. application/vnd.github.v3+json => application/vnd.github.v3.raw
headers . accept = headers . accept . split ( /,/ ) . map ( preview => preview . replace ( /application\/vnd(\.\w+)(\.v3)?(\.\w+)?(\+json)?$/ , ` application/vnd $ 1 $ 2. ${ options . mediaType . format } ` ) ) . join ( "," ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( options . mediaType . previews . length ) {
const previewsFromAcceptHeader = headers . accept . match ( /[\w-]+(?=-preview)/g ) || [ ] ;
headers . accept = previewsFromAcceptHeader . concat ( options . mediaType . previews ) . map ( preview => {
const format = options . mediaType . format ? ` . ${ options . mediaType . format } ` : "+json" ;
return ` application/vnd.github. ${ preview } -preview ${ format } ` ;
} ) . join ( "," ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
} // for GET/HEAD requests, set URL query parameters from remaining parameters
// for PATCH/POST/PUT/DELETE requests, set request body from remaining parameters
if ( [ "GET" , "HEAD" ] . includes ( method ) ) {
url = addQueryParameters ( url , remainingParameters ) ;
} else {
if ( "data" in remainingParameters ) {
body = remainingParameters . data ;
} else {
if ( Object . keys ( remainingParameters ) . length ) {
body = remainingParameters ;
} else {
headers [ "content-length" ] = 0 ;
}
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
} // default content-type for JSON if body is set
if ( ! headers [ "content-type" ] && typeof body !== "undefined" ) {
headers [ "content-type" ] = "application/json; charset=utf-8" ;
} // GitHub expects 'content-length: 0' header for PUT/PATCH requests without body.
// fetch does not allow to set `content-length` header, but we can set body to an empty string
if ( [ "PATCH" , "PUT" ] . includes ( method ) && typeof body === "undefined" ) {
body = "" ;
} // Only return body/request keys if present
return Object . assign ( {
method ,
url ,
headers
} , typeof body !== "undefined" ? {
body
} : null , options . request ? {
request : options . request
} : null ) ;
}
function endpointWithDefaults ( defaults , route , options ) {
return parse ( merge ( defaults , route , options ) ) ;
}
function withDefaults ( oldDefaults , newDefaults ) {
const DEFAULTS = merge ( oldDefaults , newDefaults ) ;
const endpoint = endpointWithDefaults . bind ( null , DEFAULTS ) ;
return Object . assign ( endpoint , {
DEFAULTS ,
defaults : withDefaults . bind ( null , DEFAULTS ) ,
merge : merge . bind ( null , DEFAULTS ) ,
parse
} ) ;
}
const VERSION = "6.0.12" ;
const userAgent = ` octokit-endpoint.js/ ${ VERSION } ${ universalUserAgent . getUserAgent ( ) } ` ; // DEFAULTS has all properties set that EndpointOptions has, except url.
// So we use RequestParameters and add method as additional required property.
const DEFAULTS = {
method : "GET" ,
baseUrl : "https://api.github.com" ,
headers : {
accept : "application/vnd.github.v3+json" ,
"user-agent" : userAgent
} ,
mediaType : {
format : "" ,
previews : [ ]
}
} ;
const endpoint = withDefaults ( null , DEFAULTS ) ;
exports . endpoint = endpoint ;
//# sourceMappingURL=index.js.map
/***/ } ) ,
/***/ 7461 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
var request = _ _nccwpck _require _ _ ( 6206 ) ;
var universalUserAgent = _ _nccwpck _require _ _ ( 5030 ) ;
const VERSION = "4.8.0" ;
function _buildMessageForResponseErrors ( data ) {
return ` Request failed due to following response errors: \n ` + data . errors . map ( e => ` - ${ e . message } ` ) . join ( "\n" ) ;
}
class GraphqlResponseError extends Error {
constructor ( request , headers , response ) {
super ( _buildMessageForResponseErrors ( response ) ) ;
this . request = request ;
this . headers = headers ;
this . response = response ;
this . name = "GraphqlResponseError" ; // Expose the errors and response data in their shorthand properties.
this . errors = response . errors ;
this . data = response . data ; // Maintains proper stack trace (only available on V8)
/* istanbul ignore next */
if ( Error . captureStackTrace ) {
Error . captureStackTrace ( this , this . constructor ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
}
}
const NON _VARIABLE _OPTIONS = [ "method" , "baseUrl" , "url" , "headers" , "request" , "query" , "mediaType" ] ;
const FORBIDDEN _VARIABLE _OPTIONS = [ "query" , "method" , "url" ] ;
const GHES _V3 _SUFFIX _REGEX = /\/api\/v3\/?$/ ;
function graphql ( request , query , options ) {
if ( options ) {
if ( typeof query === "string" && "query" in options ) {
return Promise . reject ( new Error ( ` [@octokit/graphql] "query" cannot be used as variable name ` ) ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
for ( const key in options ) {
if ( ! FORBIDDEN _VARIABLE _OPTIONS . includes ( key ) ) continue ;
return Promise . reject ( new Error ( ` [@octokit/graphql] " ${ key } " cannot be used as variable name ` ) ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
}
const parsedOptions = typeof query === "string" ? Object . assign ( {
query
} , options ) : query ;
const requestOptions = Object . keys ( parsedOptions ) . reduce ( ( result , key ) => {
if ( NON _VARIABLE _OPTIONS . includes ( key ) ) {
result [ key ] = parsedOptions [ key ] ;
return result ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
if ( ! result . variables ) {
result . variables = { } ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
result . variables [ key ] = parsedOptions [ key ] ;
return result ;
} , { } ) ; // workaround for GitHub Enterprise baseUrl set with /api/v3 suffix
// https://github.com/octokit/auth-app.js/issues/111#issuecomment-657610451
const baseUrl = parsedOptions . baseUrl || request . endpoint . DEFAULTS . baseUrl ;
if ( GHES _V3 _SUFFIX _REGEX . test ( baseUrl ) ) {
requestOptions . url = baseUrl . replace ( GHES _V3 _SUFFIX _REGEX , "/api/graphql" ) ;
}
return request ( requestOptions ) . then ( response => {
if ( response . data . errors ) {
const headers = { } ;
for ( const key of Object . keys ( response . headers ) ) {
headers [ key ] = response . headers [ key ] ;
}
throw new GraphqlResponseError ( requestOptions , headers , response . data ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
return response . data . data ;
} ) ;
}
function withDefaults ( request$1 , newDefaults ) {
const newRequest = request$1 . defaults ( newDefaults ) ;
const newApi = ( query , options ) => {
return graphql ( newRequest , query , options ) ;
} ;
return Object . assign ( newApi , {
defaults : withDefaults . bind ( null , newRequest ) ,
endpoint : request . request . endpoint
} ) ;
}
const graphql$1 = withDefaults ( request . request , {
headers : {
"user-agent" : ` octokit-graphql.js/ ${ VERSION } ${ universalUserAgent . getUserAgent ( ) } `
} ,
method : "POST" ,
url : "/graphql"
} ) ;
function withCustomRequest ( customRequest ) {
return withDefaults ( customRequest , {
method : "POST" ,
url : "/graphql"
} ) ;
}
exports . GraphqlResponseError = GraphqlResponseError ;
exports . graphql = graphql$1 ;
exports . withCustomRequest = withCustomRequest ;
//# sourceMappingURL=index.js.map
/***/ } ) ,
/***/ 6239 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
function _interopDefault ( ex ) { return ( ex && ( typeof ex === 'object' ) && 'default' in ex ) ? ex [ 'default' ] : ex ; }
var deprecation = _ _nccwpck _require _ _ ( 8932 ) ;
var once = _interopDefault ( _ _nccwpck _require _ _ ( 1223 ) ) ;
const logOnceCode = once ( deprecation => console . warn ( deprecation ) ) ;
const logOnceHeaders = once ( deprecation => console . warn ( deprecation ) ) ;
/ * *
* Error with extra properties to help with debugging
* /
class RequestError extends Error {
constructor ( message , statusCode , options ) {
super ( message ) ; // Maintains proper stack trace (only available on V8)
/* istanbul ignore next */
if ( Error . captureStackTrace ) {
Error . captureStackTrace ( this , this . constructor ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
this . name = "HttpError" ;
this . status = statusCode ;
let headers ;
if ( "headers" in options && typeof options . headers !== "undefined" ) {
headers = options . headers ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( "response" in options ) {
this . response = options . response ;
headers = options . response . headers ;
} // redact request credentials without mutating original request options
const requestCopy = Object . assign ( { } , options . request ) ;
if ( options . request . headers . authorization ) {
requestCopy . headers = Object . assign ( { } , options . request . headers , {
authorization : options . request . headers . authorization . replace ( / .*$/ , " [REDACTED]" )
} ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
requestCopy . url = requestCopy . url // client_id & client_secret can be passed as URL query parameters to increase rate limit
// see https://developer.github.com/v3/#increasing-the-unauthenticated-rate-limit-for-oauth-applications
. replace ( /\bclient_secret=\w+/g , "client_secret=[REDACTED]" ) // OAuth tokens can be passed as URL query parameters, although it is not recommended
// see https://developer.github.com/v3/#oauth2-token-sent-in-a-header
. replace ( /\baccess_token=\w+/g , "access_token=[REDACTED]" ) ;
this . request = requestCopy ; // deprecations
Object . defineProperty ( this , "code" , {
get ( ) {
logOnceCode ( new deprecation . Deprecation ( "[@octokit/request-error] `error.code` is deprecated, use `error.status`." ) ) ;
return statusCode ;
}
} ) ;
Object . defineProperty ( this , "headers" , {
get ( ) {
logOnceHeaders ( new deprecation . Deprecation ( "[@octokit/request-error] `error.headers` is deprecated, use `error.response.headers`." ) ) ;
return headers || { } ;
}
} ) ;
}
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
exports . RequestError = RequestError ;
2022-10-12 17:48:05 +02:00
//# sourceMappingURL=index.js.map
2024-05-19 08:24:38 +02:00
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 6206 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2022-10-12 17:48:05 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function _interopDefault ( ex ) { return ( ex && ( typeof ex === 'object' ) && 'default' in ex ) ? ex [ 'default' ] : ex ; }
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var endpoint = _ _nccwpck _require _ _ ( 6065 ) ;
var universalUserAgent = _ _nccwpck _require _ _ ( 5030 ) ;
var isPlainObject = _ _nccwpck _require _ _ ( 3287 ) ;
var nodeFetch = _interopDefault ( _ _nccwpck _require _ _ ( 467 ) ) ;
var requestError = _ _nccwpck _require _ _ ( 6239 ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const VERSION = "5.6.3" ;
function getBufferResponse ( response ) {
return response . arrayBuffer ( ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function fetchWrapper ( requestOptions ) {
const log = requestOptions . request && requestOptions . request . log ? requestOptions . request . log : console ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( isPlainObject . isPlainObject ( requestOptions . body ) || Array . isArray ( requestOptions . body ) ) {
requestOptions . body = JSON . stringify ( requestOptions . body ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
let headers = { } ;
let status ;
let url ;
const fetch = requestOptions . request && requestOptions . request . fetch || nodeFetch ;
return fetch ( requestOptions . url , Object . assign ( {
method : requestOptions . method ,
body : requestOptions . body ,
headers : requestOptions . headers ,
redirect : requestOptions . redirect
} , // `requestOptions.request.agent` type is incompatible
// see https://github.com/octokit/types.ts/pull/264
requestOptions . request ) ) . then ( async response => {
url = response . url ;
status = response . status ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
for ( const keyAndValue of response . headers ) {
headers [ keyAndValue [ 0 ] ] = keyAndValue [ 1 ] ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( "deprecation" in headers ) {
const matches = headers . link && headers . link . match ( /<([^>]+)>; rel="deprecation"/ ) ;
const deprecationLink = matches && matches . pop ( ) ;
log . warn ( ` [@octokit/request] " ${ requestOptions . method } ${ requestOptions . url } " is deprecated. It is scheduled to be removed on ${ headers . sunset } ${ deprecationLink ? ` . See ${ deprecationLink } ` : "" } ` ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( status === 204 || status === 205 ) {
return ;
} // GitHub API returns 200 for HEAD requests
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( requestOptions . method === "HEAD" ) {
if ( status < 400 ) {
return ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
throw new requestError . RequestError ( response . statusText , status , {
response : {
url ,
status ,
headers ,
data : undefined
} ,
request : requestOptions
} ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( status === 304 ) {
throw new requestError . RequestError ( "Not modified" , status , {
response : {
url ,
status ,
headers ,
data : await getResponseData ( response )
} ,
request : requestOptions
} ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
if ( status >= 400 ) {
const data = await getResponseData ( response ) ;
const error = new requestError . RequestError ( toErrorMessage ( data ) , status , {
response : {
url ,
status ,
headers ,
data
} ,
request : requestOptions
} ) ;
throw error ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
return getResponseData ( response ) ;
} ) . then ( data => {
return {
status ,
url ,
headers ,
data
} ;
} ) . catch ( error => {
if ( error instanceof requestError . RequestError ) throw error ;
throw new requestError . RequestError ( error . message , 500 , {
request : requestOptions
} ) ;
} ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
async function getResponseData ( response ) {
const contentType = response . headers . get ( "content-type" ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( /application\/json/ . test ( contentType ) ) {
return response . json ( ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( ! contentType || /^text\/|charset=utf-8$/ . test ( contentType ) ) {
return response . text ( ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return getBufferResponse ( response ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function toErrorMessage ( data ) {
if ( typeof data === "string" ) return data ; // istanbul ignore else - just in case
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( "message" in data ) {
if ( Array . isArray ( data . errors ) ) {
return ` ${ data . message } : ${ data . errors . map ( JSON . stringify ) . join ( ", " ) } ` ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return data . message ;
} // istanbul ignore next - just in case
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return ` Unknown error: ${ JSON . stringify ( data ) } ` ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function withDefaults ( oldEndpoint , newDefaults ) {
const endpoint = oldEndpoint . defaults ( newDefaults ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const newApi = function ( route , parameters ) {
const endpointOptions = endpoint . merge ( route , parameters ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( ! endpointOptions . request || ! endpointOptions . request . hook ) {
return fetchWrapper ( endpoint . parse ( endpointOptions ) ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const request = ( route , parameters ) => {
return fetchWrapper ( endpoint . parse ( endpoint . merge ( route , parameters ) ) ) ;
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
Object . assign ( request , {
endpoint ,
defaults : withDefaults . bind ( null , endpoint )
} ) ;
return endpointOptions . request . hook ( request , endpointOptions ) ;
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return Object . assign ( newApi , {
endpoint ,
defaults : withDefaults . bind ( null , endpoint )
} ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
const request = withDefaults ( endpoint . endpoint , {
headers : {
"user-agent" : ` octokit-request.js/ ${ VERSION } ${ universalUserAgent . getUserAgent ( ) } `
}
} ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
exports . request = request ;
//# sourceMappingURL=index.js.map
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 3682 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var register = _ _nccwpck _require _ _ ( 4670 )
var addHook = _ _nccwpck _require _ _ ( 5549 )
var removeHook = _ _nccwpck _require _ _ ( 6819 )
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// bind with array of arguments: https://stackoverflow.com/a/21792913
var bind = Function . bind
var bindable = bind . bind ( bind )
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function bindApi ( hook , state , name ) {
var removeHookRef = bindable ( removeHook , null ) . apply ( null , name ? [ state , name ] : [ state ] )
hook . api = { remove : removeHookRef }
hook . remove = removeHookRef
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
; [ 'before' , 'error' , 'after' , 'wrap' ] . forEach ( function ( kind ) {
var args = name ? [ state , kind , name ] : [ state , kind ]
hook [ kind ] = hook . api [ kind ] = bindable ( addHook , null ) . apply ( null , args )
} )
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function HookSingular ( ) {
var singularHookName = 'h'
var singularHookState = {
registry : { }
}
var singularHook = register . bind ( null , singularHookState , singularHookName )
bindApi ( singularHook , singularHookState , singularHookName )
return singularHook
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function HookCollection ( ) {
var state = {
registry : { }
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var hook = register . bind ( null , state )
bindApi ( hook , state )
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return hook
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var collectionHookDeprecationMessageDisplayed = false
function Hook ( ) {
if ( ! collectionHookDeprecationMessageDisplayed ) {
console . warn ( '[before-after-hook]: "Hook()" repurposing warning, use "Hook.Collection()". Read more: https://git.io/upgrade-before-after-hook-to-1.4' )
collectionHookDeprecationMessageDisplayed = true
}
return HookCollection ( )
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
Hook . Singular = HookSingular . bind ( )
Hook . Collection = HookCollection . bind ( )
module . exports = Hook
// expose constructors as a named property for TypeScript
module . exports . Hook = Hook
module . exports . Singular = Hook . Singular
module . exports . Collection = Hook . Collection
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 5549 :
/***/ ( ( module ) => {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
module . exports = addHook ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function addHook ( state , kind , name , hook ) {
var orig = hook ;
if ( ! state . registry [ name ] ) {
state . registry [ name ] = [ ] ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( kind === "before" ) {
hook = function ( method , options ) {
return Promise . resolve ( )
. then ( orig . bind ( null , options ) )
. then ( method . bind ( null , options ) ) ;
} ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( kind === "after" ) {
hook = function ( method , options ) {
var result ;
return Promise . resolve ( )
. then ( method . bind ( null , options ) )
. then ( function ( result _ ) {
result = result _ ;
return orig ( result , options ) ;
} )
. then ( function ( ) {
return result ;
} ) ;
} ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( kind === "error" ) {
hook = function ( method , options ) {
return Promise . resolve ( )
. then ( method . bind ( null , options ) )
. catch ( function ( error ) {
return orig ( error , options ) ;
} ) ;
} ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
state . registry [ name ] . push ( {
hook : hook ,
orig : orig ,
} ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 4670 :
/***/ ( ( module ) => {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
module . exports = register ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function register ( state , name , method , options ) {
if ( typeof method !== "function" ) {
throw new Error ( "method for before hook must be a function" ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( ! options ) {
options = { } ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( Array . isArray ( name ) ) {
return name . reverse ( ) . reduce ( function ( callback , name ) {
return register . bind ( null , state , name , callback , options ) ;
} , method ) ( ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return Promise . resolve ( ) . then ( function ( ) {
if ( ! state . registry [ name ] ) {
return method ( options ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return state . registry [ name ] . reduce ( function ( method , registered ) {
return registered . hook . bind ( null , method , options ) ;
} , method ) ( ) ;
} ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 6819 :
/***/ ( ( module ) => {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
module . exports = removeHook ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function removeHook ( state , name , method ) {
if ( ! state . registry [ name ] ) {
return ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var index = state . registry [ name ]
. map ( function ( registered ) {
return registered . orig ;
} )
. indexOf ( method ) ;
if ( index === - 1 ) {
return ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
state . registry [ name ] . splice ( index , 1 ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 7881 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const cp = _ _nccwpck _require _ _ ( 2081 ) ;
const parse = _ _nccwpck _require _ _ ( 6855 ) ;
const enoent = _ _nccwpck _require _ _ ( 4101 ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function spawn ( command , args , options ) {
// Parse the arguments
const parsed = parse ( command , args , options ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Spawn the child process
const spawned = cp . spawn ( parsed . command , parsed . args , parsed . options ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Hook into child process "exit" event to emit an error if the command
// does not exists, see: https://github.com/IndigoUnited/node-cross-spawn/issues/16
enoent . hookChildProcess ( spawned , parsed ) ;
return spawned ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function spawnSync ( command , args , options ) {
// Parse the arguments
const parsed = parse ( command , args , options ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Spawn the child process
const result = cp . spawnSync ( parsed . command , parsed . args , parsed . options ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Analyze if the command does not exist, see: https://github.com/IndigoUnited/node-cross-spawn/issues/16
result . error = result . error || enoent . verifyENOENTSync ( result . status , parsed ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return result ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
module . exports = spawn ;
module . exports . spawn = spawn ;
module . exports . sync = spawnSync ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
module . exports . _parse = parse ;
module . exports . _enoent = enoent ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 4101 :
/***/ ( ( module ) => {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const isWin = process . platform === 'win32' ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function notFoundError ( original , syscall ) {
return Object . assign ( new Error ( ` ${ syscall } ${ original . command } ENOENT ` ) , {
code : 'ENOENT' ,
errno : 'ENOENT' ,
syscall : ` ${ syscall } ${ original . command } ` ,
path : original . command ,
spawnargs : original . args ,
} ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function hookChildProcess ( cp , parsed ) {
if ( ! isWin ) {
return ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const originalEmit = cp . emit ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
cp . emit = function ( name , arg1 ) {
// If emitting "exit" event and exit code is 1, we need to check if
// the command exists and emit an "error" instead
// See https://github.com/IndigoUnited/node-cross-spawn/issues/16
if ( name === 'exit' ) {
const err = verifyENOENT ( arg1 , parsed , 'spawn' ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( err ) {
return originalEmit . call ( cp , 'error' , err ) ;
}
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return originalEmit . apply ( cp , arguments ) ; // eslint-disable-line prefer-rest-params
} ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function verifyENOENT ( status , parsed ) {
if ( isWin && status === 1 && ! parsed . file ) {
return notFoundError ( parsed . original , 'spawn' ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return null ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function verifyENOENTSync ( status , parsed ) {
if ( isWin && status === 1 && ! parsed . file ) {
return notFoundError ( parsed . original , 'spawnSync' ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return null ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
module . exports = {
hookChildProcess ,
verifyENOENT ,
verifyENOENTSync ,
notFoundError ,
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 6855 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const path = _ _nccwpck _require _ _ ( 1017 ) ;
const niceTry = _ _nccwpck _require _ _ ( 8560 ) ;
const resolveCommand = _ _nccwpck _require _ _ ( 7274 ) ;
const escape = _ _nccwpck _require _ _ ( 4274 ) ;
const readShebang = _ _nccwpck _require _ _ ( 1252 ) ;
const semver = _ _nccwpck _require _ _ ( 5911 ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const isWin = process . platform === 'win32' ;
const isExecutableRegExp = /\.(?:com|exe)$/i ;
const isCmdShimRegExp = /node_modules[\\/].bin[\\/][^\\/]+\.cmd$/i ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// `options.shell` is supported in Node ^4.8.0, ^5.7.0 and >= 6.0.0
const supportsShellOption = niceTry ( ( ) => semver . satisfies ( process . version , '^4.8.0 || ^5.7.0 || >= 6.0.0' , true ) ) || false ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function detectShebang ( parsed ) {
parsed . file = resolveCommand ( parsed ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const shebang = parsed . file && readShebang ( parsed . file ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( shebang ) {
parsed . args . unshift ( parsed . file ) ;
parsed . command = shebang ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return resolveCommand ( parsed ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return parsed . file ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function parseNonShell ( parsed ) {
if ( ! isWin ) {
return parsed ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Detect & add support for shebangs
const commandFile = detectShebang ( parsed ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// We don't need a shell if the command filename is an executable
const needsShell = ! isExecutableRegExp . test ( commandFile ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// If a shell is required, use cmd.exe and take care of escaping everything correctly
// Note that `forceShell` is an hidden option used only in tests
if ( parsed . options . forceShell || needsShell ) {
// Need to double escape meta chars if the command is a cmd-shim located in `node_modules/.bin/`
// The cmd-shim simply calls execute the package bin file with NodeJS, proxying any argument
// Because the escape of metachars with ^ gets interpreted when the cmd.exe is first called,
// we need to double escape them
const needsDoubleEscapeMetaChars = isCmdShimRegExp . test ( commandFile ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Normalize posix paths into OS compatible paths (e.g.: foo/bar -> foo\bar)
// This is necessary otherwise it will always fail with ENOENT in those cases
parsed . command = path . normalize ( parsed . command ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Escape command & arguments
parsed . command = escape . command ( parsed . command ) ;
parsed . args = parsed . args . map ( ( arg ) => escape . argument ( arg , needsDoubleEscapeMetaChars ) ) ;
const shellCommand = [ parsed . command ] . concat ( parsed . args ) . join ( ' ' ) ;
parsed . args = [ '/d' , '/s' , '/c' , ` " ${ shellCommand } " ` ] ;
parsed . command = process . env . comspec || 'cmd.exe' ;
parsed . options . windowsVerbatimArguments = true ; // Tell node's spawn that the arguments are already escaped
}
return parsed ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function parseShell ( parsed ) {
// If node supports the shell option, there's no need to mimic its behavior
if ( supportsShellOption ) {
return parsed ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Mimic node shell option
// See https://github.com/nodejs/node/blob/b9f6a2dc059a1062776133f3d4fd848c4da7d150/lib/child_process.js#L335
const shellCommand = [ parsed . command ] . concat ( parsed . args ) . join ( ' ' ) ;
if ( isWin ) {
parsed . command = typeof parsed . options . shell === 'string' ? parsed . options . shell : process . env . comspec || 'cmd.exe' ;
parsed . args = [ '/d' , '/s' , '/c' , ` " ${ shellCommand } " ` ] ;
parsed . options . windowsVerbatimArguments = true ; // Tell node's spawn that the arguments are already escaped
} else {
if ( typeof parsed . options . shell === 'string' ) {
parsed . command = parsed . options . shell ;
} else if ( process . platform === 'android' ) {
parsed . command = '/system/bin/sh' ;
} else {
parsed . command = '/bin/sh' ;
}
parsed . args = [ '-c' , shellCommand ] ;
}
return parsed ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function parse ( command , args , options ) {
// Normalize arguments, similar to nodejs
if ( args && ! Array . isArray ( args ) ) {
options = args ;
args = null ;
}
args = args ? args . slice ( 0 ) : [ ] ; // Clone array to avoid changing the original
options = Object . assign ( { } , options ) ; // Clone object to avoid changing the original
// Build our parsed object
const parsed = {
command ,
args ,
options ,
file : undefined ,
original : {
command ,
args ,
} ,
} ;
// Delegate further parsing to shell or non-shell
return options . shell ? parseShell ( parsed ) : parseNonShell ( parsed ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
module . exports = parse ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 4274 :
/***/ ( ( module ) => {
"use strict" ;
// See http://www.robvanderwoude.com/escapechars.php
const metaCharsRegExp = /([()\][%!^"`<>&|;, *?])/g ;
function escapeCommand ( arg ) {
// Escape meta chars
arg = arg . replace ( metaCharsRegExp , '^$1' ) ;
return arg ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function escapeArgument ( arg , doubleEscapeMetaChars ) {
// Convert to string
arg = ` ${ arg } ` ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Algorithm below is based on https://qntm.org/cmd
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Sequence of backslashes followed by a double quote:
// double up all the backslashes and escape the double quote
arg = arg . replace ( /(\\*)"/g , '$1$1\\"' ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Sequence of backslashes followed by the end of the string
// (which will become a double quote later):
// double up all the backslashes
arg = arg . replace ( /(\\*)$/ , '$1$1' ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// All other backslashes occur literally
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Quote the whole thing:
arg = ` " ${ arg } " ` ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Escape meta chars
arg = arg . replace ( metaCharsRegExp , '^$1' ) ;
// Double escape meta chars if necessary
if ( doubleEscapeMetaChars ) {
arg = arg . replace ( metaCharsRegExp , '^$1' ) ;
}
return arg ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
module . exports . command = escapeCommand ;
module . exports . argument = escapeArgument ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 1252 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const fs = _ _nccwpck _require _ _ ( 7147 ) ;
const shebangCommand = _ _nccwpck _require _ _ ( 7032 ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function readShebang ( command ) {
// Read the first 150 bytes from the file
const size = 150 ;
let buffer ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( Buffer . alloc ) {
// Node.js v4.5+ / v5.10+
buffer = Buffer . alloc ( size ) ;
} else {
// Old Node.js API
buffer = new Buffer ( size ) ;
buffer . fill ( 0 ) ; // zero-fill
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
let fd ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
try {
fd = fs . openSync ( command , 'r' ) ;
fs . readSync ( fd , buffer , 0 , size , 0 ) ;
fs . closeSync ( fd ) ;
} catch ( e ) { /* Empty */ }
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Attempt to extract shebang (null is returned if not a shebang)
return shebangCommand ( buffer . toString ( ) ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
module . exports = readShebang ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ 7274 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const path = _ _nccwpck _require _ _ ( 1017 ) ;
const which = _ _nccwpck _require _ _ ( 4207 ) ;
const pathKey = _ _nccwpck _require _ _ ( 539 ) ( ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function resolveCommandAttempt ( parsed , withoutPathExt ) {
const cwd = process . cwd ( ) ;
const hasCustomCwd = parsed . options . cwd != null ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// If a custom `cwd` was specified, we need to change the process cwd
// because `which` will do stat calls but does not support a custom cwd
if ( hasCustomCwd ) {
try {
process . chdir ( parsed . options . cwd ) ;
} catch ( err ) {
/* Empty */
}
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
let resolved ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
try {
resolved = which . sync ( parsed . command , {
path : ( parsed . options . env || process . env ) [ pathKey ] ,
pathExt : withoutPathExt ? path . delimiter : undefined ,
} ) ;
} catch ( e ) {
/* Empty */
} finally {
process . chdir ( cwd ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// If we successfully resolved, ensure that an absolute path is returned
// Note that when a custom `cwd` was used, we need to resolve to an absolute path based on it
if ( resolved ) {
resolved = path . resolve ( hasCustomCwd ? parsed . options . cwd : '' , resolved ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return resolved ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function resolveCommand ( parsed ) {
return resolveCommandAttempt ( parsed ) || resolveCommandAttempt ( parsed , true ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
module . exports = resolveCommand ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 8932 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
class Deprecation extends Error {
constructor ( message ) {
super ( message ) ; // Maintains proper stack trace (only available on V8)
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/* istanbul ignore next */
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( Error . captureStackTrace ) {
Error . captureStackTrace ( this , this . constructor ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
this . name = 'Deprecation' ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
exports . Deprecation = Deprecation ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 1205 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var once = _ _nccwpck _require _ _ ( 1223 ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var noop = function ( ) { } ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var isRequest = function ( stream ) {
return stream . setHeader && typeof stream . abort === 'function' ;
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var isChildProcess = function ( stream ) {
return stream . stdio && Array . isArray ( stream . stdio ) && stream . stdio . length === 3
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var eos = function ( stream , opts , callback ) {
if ( typeof opts === 'function' ) return eos ( stream , null , opts ) ;
if ( ! opts ) opts = { } ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
callback = once ( callback || noop ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var ws = stream . _writableState ;
var rs = stream . _readableState ;
var readable = opts . readable || ( opts . readable !== false && stream . readable ) ;
var writable = opts . writable || ( opts . writable !== false && stream . writable ) ;
var cancelled = false ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var onlegacyfinish = function ( ) {
if ( ! stream . writable ) onfinish ( ) ;
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var onfinish = function ( ) {
writable = false ;
if ( ! readable ) callback . call ( stream ) ;
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var onend = function ( ) {
readable = false ;
if ( ! writable ) callback . call ( stream ) ;
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var onexit = function ( exitCode ) {
callback . call ( stream , exitCode ? new Error ( 'exited with error code: ' + exitCode ) : null ) ;
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var onerror = function ( err ) {
callback . call ( stream , err ) ;
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var onclose = function ( ) {
process . nextTick ( onclosenexttick ) ;
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var onclosenexttick = function ( ) {
if ( cancelled ) return ;
if ( readable && ! ( rs && ( rs . ended && ! rs . destroyed ) ) ) return callback . call ( stream , new Error ( 'premature close' ) ) ;
if ( writable && ! ( ws && ( ws . ended && ! ws . destroyed ) ) ) return callback . call ( stream , new Error ( 'premature close' ) ) ;
} ;
var onrequest = function ( ) {
stream . req . on ( 'finish' , onfinish ) ;
} ;
if ( isRequest ( stream ) ) {
stream . on ( 'complete' , onfinish ) ;
stream . on ( 'abort' , onclose ) ;
if ( stream . req ) onrequest ( ) ;
else stream . on ( 'request' , onrequest ) ;
} else if ( writable && ! ws ) { // legacy streams
stream . on ( 'end' , onlegacyfinish ) ;
stream . on ( 'close' , onlegacyfinish ) ;
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( isChildProcess ( stream ) ) stream . on ( 'exit' , onexit ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
stream . on ( 'end' , onend ) ;
stream . on ( 'finish' , onfinish ) ;
if ( opts . error !== false ) stream . on ( 'error' , onerror ) ;
stream . on ( 'close' , onclose ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return function ( ) {
cancelled = true ;
stream . removeListener ( 'complete' , onfinish ) ;
stream . removeListener ( 'abort' , onclose ) ;
stream . removeListener ( 'request' , onrequest ) ;
if ( stream . req ) stream . req . removeListener ( 'finish' , onfinish ) ;
stream . removeListener ( 'end' , onlegacyfinish ) ;
stream . removeListener ( 'close' , onlegacyfinish ) ;
stream . removeListener ( 'finish' , onfinish ) ;
stream . removeListener ( 'exit' , onexit ) ;
stream . removeListener ( 'end' , onend ) ;
stream . removeListener ( 'error' , onerror ) ;
stream . removeListener ( 'close' , onclose ) ;
} ;
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
module . exports = eos ;
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 3440 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . _ _esModule = true ;
/** Object.keys() with types */
function objectKeys ( o ) {
return Object . keys ( o ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
exports . objectKeys = objectKeys ;
//# sourceMappingURL=objectKeys.js.map
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 5447 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const path = _ _nccwpck _require _ _ ( 1017 ) ;
const childProcess = _ _nccwpck _require _ _ ( 2081 ) ;
const crossSpawn = _ _nccwpck _require _ _ ( 7881 ) ;
const stripEof = _ _nccwpck _require _ _ ( 5515 ) ;
const npmRunPath = _ _nccwpck _require _ _ ( 502 ) ;
const isStream = _ _nccwpck _require _ _ ( 1554 ) ;
const _getStream = _ _nccwpck _require _ _ ( 1766 ) ;
const pFinally = _ _nccwpck _require _ _ ( 1330 ) ;
const onExit = _ _nccwpck _require _ _ ( 4931 ) ;
const errname = _ _nccwpck _require _ _ ( 4689 ) ;
const stdio = _ _nccwpck _require _ _ ( 166 ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const TEN _MEGABYTES = 1000 * 1000 * 10 ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function handleArgs ( cmd , args , opts ) {
let parsed ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
opts = Object . assign ( {
extendEnv : true ,
env : { }
} , opts ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( opts . extendEnv ) {
opts . env = Object . assign ( { } , process . env , opts . env ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( opts . _ _winShell === true ) {
delete opts . _ _winShell ;
parsed = {
command : cmd ,
args ,
options : opts ,
file : cmd ,
original : {
cmd ,
args
2022-10-12 17:48:05 +02:00
}
} ;
2024-05-19 08:24:38 +02:00
} else {
parsed = crossSpawn . _parse ( cmd , args , opts ) ;
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
opts = Object . assign ( {
maxBuffer : TEN _MEGABYTES ,
buffer : true ,
stripEof : true ,
preferLocal : true ,
localDir : parsed . options . cwd || process . cwd ( ) ,
encoding : 'utf8' ,
reject : true ,
cleanup : true
} , parsed . options ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
opts . stdio = stdio ( opts ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( opts . preferLocal ) {
opts . env = npmRunPath . env ( Object . assign ( { } , opts , { cwd : opts . localDir } ) ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
if ( opts . detached ) {
// #115
opts . cleanup = false ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
if ( process . platform === 'win32' && path . basename ( parsed . command ) === 'cmd.exe' ) {
// #116
parsed . args . unshift ( '/q' ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
return {
cmd : parsed . command ,
args : parsed . args ,
opts ,
parsed
} ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
function handleInput ( spawned , input ) {
if ( input === null || input === undefined ) {
return ;
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( isStream ( input ) ) {
input . pipe ( spawned . stdin ) ;
} else {
spawned . stdin . end ( input ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function handleOutput ( opts , val ) {
if ( val && opts . stripEof ) {
val = stripEof ( val ) ;
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return val ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function handleShell ( fn , cmd , opts ) {
let file = '/bin/sh' ;
let args = [ '-c' , cmd ] ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
opts = Object . assign ( { } , opts ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( process . platform === 'win32' ) {
opts . _ _winShell = true ;
file = process . env . comspec || 'cmd.exe' ;
args = [ '/s' , '/c' , ` " ${ cmd } " ` ] ;
opts . windowsVerbatimArguments = true ;
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( opts . shell ) {
file = opts . shell ;
delete opts . shell ;
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return fn ( file , args , opts ) ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
function getStream ( process , stream , { encoding , buffer , maxBuffer } ) {
if ( ! process [ stream ] ) {
return null ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
let ret ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! buffer ) {
// TODO: Use `ret = util.promisify(stream.finished)(process[stream]);` when targeting Node.js 10
ret = new Promise ( ( resolve , reject ) => {
process [ stream ]
. once ( 'end' , resolve )
. once ( 'error' , reject ) ;
} ) ;
} else if ( encoding ) {
ret = _getStream ( process [ stream ] , {
encoding ,
maxBuffer
} ) ;
} else {
ret = _getStream . buffer ( process [ stream ] , { maxBuffer } ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return ret . catch ( err => {
err . stream = stream ;
err . message = ` ${ stream } ${ err . message } ` ;
throw err ;
} ) ;
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function makeError ( result , options ) {
const { stdout , stderr } = result ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
let err = result . error ;
const { code , signal } = result ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const { parsed , joinedCmd } = options ;
const timedOut = options . timedOut || false ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! err ) {
let output = '' ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( Array . isArray ( parsed . opts . stdio ) ) {
if ( parsed . opts . stdio [ 2 ] !== 'inherit' ) {
output += output . length > 0 ? stderr : ` \n ${ stderr } ` ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( parsed . opts . stdio [ 1 ] !== 'inherit' ) {
output += ` \n ${ stdout } ` ;
}
} else if ( parsed . opts . stdio !== 'inherit' ) {
output = ` \n ${ stderr } ${ stdout } ` ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
err = new Error ( ` Command failed: ${ joinedCmd } ${ output } ` ) ;
err . code = code < 0 ? errname ( code ) : code ;
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
err . stdout = stdout ;
err . stderr = stderr ;
err . failed = true ;
err . signal = signal || null ;
err . cmd = joinedCmd ;
err . timedOut = timedOut ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return err ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function joinCmd ( cmd , args ) {
let joinedCmd = cmd ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( Array . isArray ( args ) && args . length > 0 ) {
joinedCmd += ' ' + args . join ( ' ' ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return joinedCmd ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
module . exports = ( cmd , args , opts ) => {
const parsed = handleArgs ( cmd , args , opts ) ;
const { encoding , buffer , maxBuffer } = parsed . opts ;
const joinedCmd = joinCmd ( cmd , args ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
let spawned ;
try {
spawned = childProcess . spawn ( parsed . cmd , parsed . args , parsed . opts ) ;
} catch ( err ) {
return Promise . reject ( err ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
let removeExitHandler ;
if ( parsed . opts . cleanup ) {
removeExitHandler = onExit ( ( ) => {
spawned . kill ( ) ;
} ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
let timeoutId = null ;
let timedOut = false ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const cleanup = ( ) => {
if ( timeoutId ) {
clearTimeout ( timeoutId ) ;
timeoutId = null ;
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( removeExitHandler ) {
removeExitHandler ( ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( parsed . opts . timeout > 0 ) {
timeoutId = setTimeout ( ( ) => {
timeoutId = null ;
timedOut = true ;
spawned . kill ( parsed . opts . killSignal ) ;
} , parsed . opts . timeout ) ;
}
const processDone = new Promise ( resolve => {
spawned . on ( 'exit' , ( code , signal ) => {
cleanup ( ) ;
resolve ( { code , signal } ) ;
2022-10-12 17:48:05 +02:00
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
spawned . on ( 'error' , err => {
cleanup ( ) ;
resolve ( { error : err } ) ;
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( spawned . stdin ) {
spawned . stdin . on ( 'error' , err => {
cleanup ( ) ;
resolve ( { error : err } ) ;
} ) ;
}
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function destroy ( ) {
if ( spawned . stdout ) {
spawned . stdout . destroy ( ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( spawned . stderr ) {
spawned . stderr . destroy ( ) ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const handlePromise = ( ) => pFinally ( Promise . all ( [
processDone ,
getStream ( spawned , 'stdout' , { encoding , buffer , maxBuffer } ) ,
getStream ( spawned , 'stderr' , { encoding , buffer , maxBuffer } )
] ) . then ( arr => {
const result = arr [ 0 ] ;
result . stdout = arr [ 1 ] ;
result . stderr = arr [ 2 ] ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( result . error || result . code !== 0 || result . signal !== null ) {
const err = makeError ( result , {
joinedCmd ,
parsed ,
timedOut
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// TODO: missing some timeout logic for killed
// https://github.com/nodejs/node/blob/master/lib/child_process.js#L203
// err.killed = spawned.killed || killed;
err . killed = err . killed || spawned . killed ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! parsed . opts . reject ) {
return err ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
throw err ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return {
stdout : handleOutput ( parsed . opts , result . stdout ) ,
stderr : handleOutput ( parsed . opts , result . stderr ) ,
code : 0 ,
failed : false ,
killed : false ,
signal : null ,
cmd : joinedCmd ,
timedOut : false
} ;
} ) , destroy ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
crossSpawn . _enoent . hookChildProcess ( spawned , parsed . parsed ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
handleInput ( spawned , parsed . opts . input ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
spawned . then = ( onfulfilled , onrejected ) => handlePromise ( ) . then ( onfulfilled , onrejected ) ;
spawned . catch = onrejected => handlePromise ( ) . catch ( onrejected ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return spawned ;
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// TODO: set `stderr: 'ignore'` when that option is implemented
module . exports . stdout = ( ... args ) => module . exports ( ... args ) . then ( x => x . stdout ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// TODO: set `stdout: 'ignore'` when that option is implemented
module . exports . stderr = ( ... args ) => module . exports ( ... args ) . then ( x => x . stderr ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
module . exports . shell = ( cmd , opts ) => handleShell ( module . exports , cmd , opts ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
module . exports . sync = ( cmd , args , opts ) => {
const parsed = handleArgs ( cmd , args , opts ) ;
const joinedCmd = joinCmd ( cmd , args ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( isStream ( parsed . opts . input ) ) {
throw new TypeError ( 'The `input` option cannot be a stream in sync mode' ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const result = childProcess . spawnSync ( parsed . cmd , parsed . args , parsed . opts ) ;
result . code = result . status ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( result . error || result . status !== 0 || result . signal !== null ) {
const err = makeError ( result , {
joinedCmd ,
parsed
2022-10-11 16:10:23 +02:00
} ) ;
2024-05-19 08:24:38 +02:00
if ( ! parsed . opts . reject ) {
return err ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
throw err ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return {
stdout : handleOutput ( parsed . opts , result . stdout ) ,
stderr : handleOutput ( parsed . opts , result . stderr ) ,
code : 0 ,
failed : false ,
signal : null ,
cmd : joinedCmd ,
timedOut : false
} ;
} ;
module . exports . shellSync = ( cmd , opts ) => handleShell ( module . exports . sync , cmd , opts ) ;
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 4689 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Older verions of Node.js might not have `util.getSystemErrorName()`.
// In that case, fall back to a deprecated internal.
const util = _ _nccwpck _require _ _ ( 3837 ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
let uv ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( typeof util . getSystemErrorName === 'function' ) {
module . exports = util . getSystemErrorName ;
} else {
try {
uv = process . binding ( 'uv' ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( typeof uv . errname !== 'function' ) {
throw new TypeError ( 'uv.errname is not a function' ) ;
}
} catch ( err ) {
console . error ( 'execa/lib/errname: unable to establish process.binding(\'uv\')' , err ) ;
uv = null ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
module . exports = code => errname ( uv , code ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Used for testing the fallback behavior
module . exports . _ _test _ _ = errname ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function errname ( uv , code ) {
if ( uv ) {
return uv . errname ( code ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! ( code < 0 ) ) {
throw new Error ( 'err >= 0' ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return ` Unknown system error ${ code } ` ;
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 166 :
/***/ ( ( module ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const alias = [ 'stdin' , 'stdout' , 'stderr' ] ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const hasAlias = opts => alias . some ( x => Boolean ( opts [ x ] ) ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
module . exports = opts => {
if ( ! opts ) {
return null ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( opts . stdio && hasAlias ( opts ) ) {
throw new Error ( ` It's not possible to provide \` stdio \` in combination with one of ${ alias . map ( x => ` \` ${ x } \` ` ) . join ( ', ' ) } ` ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( typeof opts . stdio === 'string' ) {
return opts . stdio ;
}
const stdio = opts . stdio || [ ] ;
if ( ! Array . isArray ( stdio ) ) {
throw new TypeError ( ` Expected \` stdio \` to be of type \` string \` or \` Array \` , got \` ${ typeof stdio } \` ` ) ;
}
const result = [ ] ;
const len = Math . max ( stdio . length , alias . length ) ;
for ( let i = 0 ; i < len ; i ++ ) {
let value = null ;
if ( stdio [ i ] !== undefined ) {
value = stdio [ i ] ;
} else if ( opts [ alias [ i ] ] !== undefined ) {
value = opts [ alias [ i ] ] ;
}
result [ i ] = value ;
}
return result ;
} ;
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 1585 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
const { PassThrough } = _ _nccwpck _require _ _ ( 2781 ) ;
module . exports = options => {
options = Object . assign ( { } , options ) ;
const { array } = options ;
let { encoding } = options ;
const buffer = encoding === 'buffer' ;
let objectMode = false ;
if ( array ) {
objectMode = ! ( encoding || buffer ) ;
} else {
encoding = encoding || 'utf8' ;
}
if ( buffer ) {
encoding = null ;
}
let len = 0 ;
const ret = [ ] ;
const stream = new PassThrough ( { objectMode } ) ;
if ( encoding ) {
stream . setEncoding ( encoding ) ;
}
stream . on ( 'data' , chunk => {
ret . push ( chunk ) ;
if ( objectMode ) {
len = ret . length ;
} else {
len += chunk . length ;
}
} ) ;
stream . getBufferedValue = ( ) => {
if ( array ) {
return ret ;
}
return buffer ? Buffer . concat ( ret , len ) : ret . join ( '' ) ;
} ;
stream . getBufferedLength = ( ) => len ;
return stream ;
2022-10-12 17:48:05 +02:00
} ;
2024-05-19 08:24:38 +02:00
/***/ } ) ,
/***/ 1766 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
const pump = _ _nccwpck _require _ _ ( 8341 ) ;
const bufferStream = _ _nccwpck _require _ _ ( 1585 ) ;
class MaxBufferError extends Error {
constructor ( ) {
super ( 'maxBuffer exceeded' ) ;
this . name = 'MaxBufferError' ;
}
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function getStream ( inputStream , options ) {
if ( ! inputStream ) {
return Promise . reject ( new Error ( 'Expected a stream' ) ) ;
}
options = Object . assign ( { maxBuffer : Infinity } , options ) ;
const { maxBuffer } = options ;
let stream ;
return new Promise ( ( resolve , reject ) => {
const rejectPromise = error => {
if ( error ) { // A null check
error . bufferedData = stream . getBufferedValue ( ) ;
}
reject ( error ) ;
} ;
stream = pump ( inputStream , bufferStream ( options ) , error => {
if ( error ) {
rejectPromise ( error ) ;
return ;
}
resolve ( ) ;
} ) ;
stream . on ( 'data' , ( ) => {
if ( stream . getBufferedLength ( ) > maxBuffer ) {
rejectPromise ( new MaxBufferError ( ) ) ;
}
} ) ;
} ) . then ( ( ) => stream . getBufferedValue ( ) ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
module . exports = getStream ;
module . exports . buffer = ( stream , options ) => getStream ( stream , Object . assign ( { } , options , { encoding : 'buffer' } ) ) ;
module . exports . array = ( stream , options ) => getStream ( stream , Object . assign ( { } , options , { array : true } ) ) ;
module . exports . MaxBufferError = MaxBufferError ;
/***/ } ) ,
/***/ 3287 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
/ * !
* is - plain - object < https : //github.com/jonschlinkert/is-plain-object>
2022-10-12 17:48:05 +02:00
*
2024-05-19 08:24:38 +02:00
* Copyright ( c ) 2014 - 2017 , Jon Schlinkert .
* Released under the MIT License .
2022-10-12 17:48:05 +02:00
* /
2024-05-19 08:24:38 +02:00
function isObject ( o ) {
return Object . prototype . toString . call ( o ) === '[object Object]' ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function isPlainObject ( o ) {
var ctor , prot ;
if ( isObject ( o ) === false ) return false ;
// If has modified constructor
ctor = o . constructor ;
if ( ctor === undefined ) return true ;
// If has modified prototype
prot = ctor . prototype ;
if ( isObject ( prot ) === false ) return false ;
// If constructor does not have an Object-specific method
if ( prot . hasOwnProperty ( 'isPrototypeOf' ) === false ) {
return false ;
}
// Most likely a plain Object
return true ;
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . isPlainObject = isPlainObject ;
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 1554 :
/***/ ( ( module ) => {
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var isStream = module . exports = function ( stream ) {
return stream !== null && typeof stream === 'object' && typeof stream . pipe === 'function' ;
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
isStream . writable = function ( stream ) {
return isStream ( stream ) && stream . writable !== false && typeof stream . _write === 'function' && typeof stream . _writableState === 'object' ;
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
isStream . readable = function ( stream ) {
return isStream ( stream ) && stream . readable !== false && typeof stream . _read === 'function' && typeof stream . _readableState === 'object' ;
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
isStream . duplex = function ( stream ) {
return isStream . writable ( stream ) && isStream . readable ( stream ) ;
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
isStream . transform = function ( stream ) {
return isStream . duplex ( stream ) && typeof stream . _transform === 'function' && typeof stream . _transformState === 'object' ;
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
/***/ 7126 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
var fs = _ _nccwpck _require _ _ ( 7147 )
var core
if ( process . platform === 'win32' || global . TESTING _WINDOWS ) {
core = _ _nccwpck _require _ _ ( 2001 )
} else {
core = _ _nccwpck _require _ _ ( 9728 )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
module . exports = isexe
isexe . sync = sync
function isexe ( path , options , cb ) {
if ( typeof options === 'function' ) {
cb = options
options = { }
}
if ( ! cb ) {
if ( typeof Promise !== 'function' ) {
throw new TypeError ( 'callback not provided' )
}
return new Promise ( function ( resolve , reject ) {
isexe ( path , options || { } , function ( er , is ) {
if ( er ) {
reject ( er )
} else {
resolve ( is )
}
} )
} )
}
core ( path , options || { } , function ( er , is ) {
// ignore EACCES because that just means we aren't allowed to run it
if ( er ) {
if ( er . code === 'EACCES' || options && options . ignoreErrors ) {
er = null
is = false
}
}
cb ( er , is )
} )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
function sync ( path , options ) {
// my kingdom for a filtered catch
try {
return core . sync ( path , options || { } )
} catch ( er ) {
if ( options && options . ignoreErrors || er . code === 'EACCES' ) {
return false
} else {
throw er
}
}
}
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 9728 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
module . exports = isexe
isexe . sync = sync
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var fs = _ _nccwpck _require _ _ ( 7147 )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function isexe ( path , options , cb ) {
fs . stat ( path , function ( er , stat ) {
cb ( er , er ? false : checkStat ( stat , options ) )
} )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function sync ( path , options ) {
return checkStat ( fs . statSync ( path ) , options )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function checkStat ( stat , options ) {
return stat . isFile ( ) && checkMode ( stat , options )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function checkMode ( stat , options ) {
var mod = stat . mode
var uid = stat . uid
var gid = stat . gid
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var myUid = options . uid !== undefined ?
options . uid : process . getuid && process . getuid ( )
var myGid = options . gid !== undefined ?
options . gid : process . getgid && process . getgid ( )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var u = parseInt ( '100' , 8 )
var g = parseInt ( '010' , 8 )
var o = parseInt ( '001' , 8 )
var ug = u | g
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var ret = ( mod & o ) ||
( mod & g ) && gid === myGid ||
( mod & u ) && uid === myUid ||
( mod & ug ) && myUid === 0
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return ret
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 2001 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
module . exports = isexe
isexe . sync = sync
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var fs = _ _nccwpck _require _ _ ( 7147 )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function checkPathExt ( path , options ) {
var pathext = options . pathExt !== undefined ?
options . pathExt : process . env . PATHEXT
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! pathext ) {
return true
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
pathext = pathext . split ( ';' )
if ( pathext . indexOf ( '' ) !== - 1 ) {
return true
}
for ( var i = 0 ; i < pathext . length ; i ++ ) {
var p = pathext [ i ] . toLowerCase ( )
if ( p && path . substr ( - p . length ) . toLowerCase ( ) === p ) {
return true
}
}
return false
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function checkStat ( stat , path , options ) {
if ( ! stat . isSymbolicLink ( ) && ! stat . isFile ( ) ) {
return false
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
return checkPathExt ( path , options )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function isexe ( path , options , cb ) {
fs . stat ( path , function ( er , stat ) {
cb ( er , er ? false : checkStat ( stat , path , options ) )
} )
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function sync ( path , options ) {
return checkStat ( fs . statSync ( path ) , path , options )
}
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 7493 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const os = _ _nccwpck _require _ _ ( 2037 ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const nameMap = new Map ( [
[ 21 , [ 'Monterey' , '12' ] ] ,
[ 20 , [ 'Big Sur' , '11' ] ] ,
[ 19 , [ 'Catalina' , '10.15' ] ] ,
[ 18 , [ 'Mojave' , '10.14' ] ] ,
[ 17 , [ 'High Sierra' , '10.13' ] ] ,
[ 16 , [ 'Sierra' , '10.12' ] ] ,
[ 15 , [ 'El Capitan' , '10.11' ] ] ,
[ 14 , [ 'Yosemite' , '10.10' ] ] ,
[ 13 , [ 'Mavericks' , '10.9' ] ] ,
[ 12 , [ 'Mountain Lion' , '10.8' ] ] ,
[ 11 , [ 'Lion' , '10.7' ] ] ,
[ 10 , [ 'Snow Leopard' , '10.6' ] ] ,
[ 9 , [ 'Leopard' , '10.5' ] ] ,
[ 8 , [ 'Tiger' , '10.4' ] ] ,
[ 7 , [ 'Panther' , '10.3' ] ] ,
[ 6 , [ 'Jaguar' , '10.2' ] ] ,
[ 5 , [ 'Puma' , '10.1' ] ]
] ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const macosRelease = release => {
release = Number ( ( release || os . release ( ) ) . split ( '.' ) [ 0 ] ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const [ name , version ] = nameMap . get ( release ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return {
name ,
version
} ;
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
module . exports = macosRelease ;
// TODO: remove this in the next major version
module . exports [ "default" ] = macosRelease ;
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 8560 :
/***/ ( ( module ) => {
2022-10-12 17:48:05 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
/ * *
* Tries to execute a function and discards any error that occurs .
* @ param { Function } fn - Function that might or might not throw an error .
* @ returns { ? * } Return - value of the function when no error occurred .
* /
module . exports = function ( fn ) {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
try { return fn ( ) } catch ( e ) { }
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 467 :
/***/ ( ( module , exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function _interopDefault ( ex ) { return ( ex && ( typeof ex === 'object' ) && 'default' in ex ) ? ex [ 'default' ] : ex ; }
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var Stream = _interopDefault ( _ _nccwpck _require _ _ ( 2781 ) ) ;
var http = _interopDefault ( _ _nccwpck _require _ _ ( 3685 ) ) ;
var Url = _interopDefault ( _ _nccwpck _require _ _ ( 7310 ) ) ;
var whatwgUrl = _interopDefault ( _ _nccwpck _require _ _ ( 8665 ) ) ;
var https = _interopDefault ( _ _nccwpck _require _ _ ( 5687 ) ) ;
var zlib = _interopDefault ( _ _nccwpck _require _ _ ( 9796 ) ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// Based on https://github.com/tmpvar/jsdom/blob/aa85b2abf07766ff7bf5c1f6daafb3726f2f2db5/lib/jsdom/living/blob.js
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// fix for "Readable" isn't a named export issue
const Readable = Stream . Readable ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const BUFFER = Symbol ( 'buffer' ) ;
const TYPE = Symbol ( 'type' ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
class Blob {
constructor ( ) {
this [ TYPE ] = '' ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const blobParts = arguments [ 0 ] ;
const options = arguments [ 1 ] ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const buffers = [ ] ;
let size = 0 ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( blobParts ) {
const a = blobParts ;
const length = Number ( a . length ) ;
for ( let i = 0 ; i < length ; i ++ ) {
const element = a [ i ] ;
let buffer ;
if ( element instanceof Buffer ) {
buffer = element ;
} else if ( ArrayBuffer . isView ( element ) ) {
buffer = Buffer . from ( element . buffer , element . byteOffset , element . byteLength ) ;
} else if ( element instanceof ArrayBuffer ) {
buffer = Buffer . from ( element ) ;
} else if ( element instanceof Blob ) {
buffer = element [ BUFFER ] ;
} else {
buffer = Buffer . from ( typeof element === 'string' ? element : String ( element ) ) ;
}
size += buffer . length ;
buffers . push ( buffer ) ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
this [ BUFFER ] = Buffer . concat ( buffers ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
let type = options && options . type !== undefined && String ( options . type ) . toLowerCase ( ) ;
if ( type && ! /[^\u0020-\u007E]/ . test ( type ) ) {
this [ TYPE ] = type ;
}
}
get size ( ) {
return this [ BUFFER ] . length ;
}
get type ( ) {
return this [ TYPE ] ;
}
text ( ) {
return Promise . resolve ( this [ BUFFER ] . toString ( ) ) ;
}
arrayBuffer ( ) {
const buf = this [ BUFFER ] ;
const ab = buf . buffer . slice ( buf . byteOffset , buf . byteOffset + buf . byteLength ) ;
return Promise . resolve ( ab ) ;
}
stream ( ) {
const readable = new Readable ( ) ;
readable . _read = function ( ) { } ;
readable . push ( this [ BUFFER ] ) ;
readable . push ( null ) ;
return readable ;
}
toString ( ) {
return '[object Blob]' ;
}
slice ( ) {
const size = this . size ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const start = arguments [ 0 ] ;
const end = arguments [ 1 ] ;
let relativeStart , relativeEnd ;
if ( start === undefined ) {
relativeStart = 0 ;
} else if ( start < 0 ) {
relativeStart = Math . max ( size + start , 0 ) ;
} else {
relativeStart = Math . min ( start , size ) ;
}
if ( end === undefined ) {
relativeEnd = size ;
} else if ( end < 0 ) {
relativeEnd = Math . max ( size + end , 0 ) ;
} else {
relativeEnd = Math . min ( end , size ) ;
}
const span = Math . max ( relativeEnd - relativeStart , 0 ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const buffer = this [ BUFFER ] ;
const slicedBuffer = buffer . slice ( relativeStart , relativeStart + span ) ;
const blob = new Blob ( [ ] , { type : arguments [ 2 ] } ) ;
blob [ BUFFER ] = slicedBuffer ;
return blob ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperties ( Blob . prototype , {
size : { enumerable : true } ,
type : { enumerable : true } ,
slice : { enumerable : true }
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( Blob . prototype , Symbol . toStringTag , {
value : 'Blob' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* fetch - error . js
*
* FetchError interface for operational errors
* /
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Create FetchError instance
*
* @ param String message Error message for human
* @ param String type Error type for machine
* @ param String systemError For Node . js system error
* @ return FetchError
* /
function FetchError ( message , type , systemError ) {
Error . call ( this , message ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
this . message = message ;
this . type = type ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// when err.type is `system`, err.code contains system error code
if ( systemError ) {
this . code = this . errno = systemError . code ;
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// hide custom error implementation details from end-users
Error . captureStackTrace ( this , this . constructor ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
FetchError . prototype = Object . create ( Error . prototype ) ;
FetchError . prototype . constructor = FetchError ;
FetchError . prototype . name = 'FetchError' ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
let convert ;
try {
convert = ( _ _nccwpck _require _ _ ( 2877 ) . convert ) ;
} catch ( e ) { }
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const INTERNALS = Symbol ( 'Body internals' ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// fix an issue where "PassThrough" isn't a named export for node <10
const PassThrough = Stream . PassThrough ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Body mixin
*
* Ref : https : //fetch.spec.whatwg.org/#body
*
* @ param Stream body Readable stream
* @ param Object opts Response options
* @ return Void
* /
function Body ( body ) {
var _this = this ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var _ref = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : { } ,
_ref$size = _ref . size ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
let size = _ref$size === undefined ? 0 : _ref$size ;
var _ref$timeout = _ref . timeout ;
let timeout = _ref$timeout === undefined ? 0 : _ref$timeout ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( body == null ) {
// body is undefined or null
body = null ;
} else if ( isURLSearchParams ( body ) ) {
// body is a URLSearchParams
body = Buffer . from ( body . toString ( ) ) ;
} else if ( isBlob ( body ) ) ; else if ( Buffer . isBuffer ( body ) ) ; else if ( Object . prototype . toString . call ( body ) === '[object ArrayBuffer]' ) {
// body is ArrayBuffer
body = Buffer . from ( body ) ;
} else if ( ArrayBuffer . isView ( body ) ) {
// body is ArrayBufferView
body = Buffer . from ( body . buffer , body . byteOffset , body . byteLength ) ;
} else if ( body instanceof Stream ) ; else {
// none of the above
// coerce to string then buffer
body = Buffer . from ( String ( body ) ) ;
}
this [ INTERNALS ] = {
body ,
disturbed : false ,
error : null
} ;
this . size = size ;
this . timeout = timeout ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( body instanceof Stream ) {
body . on ( 'error' , function ( err ) {
const error = err . name === 'AbortError' ? err : new FetchError ( ` Invalid response body while trying to fetch ${ _this . url } : ${ err . message } ` , 'system' , err ) ;
_this [ INTERNALS ] . error = error ;
} ) ;
}
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
Body . prototype = {
get body ( ) {
return this [ INTERNALS ] . body ;
} ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
get bodyUsed ( ) {
return this [ INTERNALS ] . disturbed ;
} ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Decode response as ArrayBuffer
*
* @ return Promise
* /
arrayBuffer ( ) {
return consumeBody . call ( this ) . then ( function ( buf ) {
return buf . buffer . slice ( buf . byteOffset , buf . byteOffset + buf . byteLength ) ;
} ) ;
} ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Return raw response as Blob
*
* @ return Promise
* /
blob ( ) {
let ct = this . headers && this . headers . get ( 'content-type' ) || '' ;
return consumeBody . call ( this ) . then ( function ( buf ) {
return Object . assign (
// Prevent copying
new Blob ( [ ] , {
type : ct . toLowerCase ( )
} ) , {
[ BUFFER ] : buf
} ) ;
} ) ;
} ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Decode response as json
*
* @ return Promise
* /
json ( ) {
var _this2 = this ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return consumeBody . call ( this ) . then ( function ( buffer ) {
try {
return JSON . parse ( buffer . toString ( ) ) ;
} catch ( err ) {
return Body . Promise . reject ( new FetchError ( ` invalid json response body at ${ _this2 . url } reason: ${ err . message } ` , 'invalid-json' ) ) ;
}
} ) ;
} ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Decode response as text
*
* @ return Promise
* /
text ( ) {
return consumeBody . call ( this ) . then ( function ( buffer ) {
return buffer . toString ( ) ;
} ) ;
} ,
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Decode response as buffer ( non - spec api )
*
* @ return Promise
* /
buffer ( ) {
return consumeBody . call ( this ) ;
} ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Decode response as text , while automatically detecting the encoding and
* trying to decode to UTF - 8 ( non - spec api )
*
* @ return Promise
* /
textConverted ( ) {
var _this3 = this ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return consumeBody . call ( this ) . then ( function ( buffer ) {
return convertBody ( buffer , _this3 . headers ) ;
} ) ;
}
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// In browsers, all properties are enumerable.
Object . defineProperties ( Body . prototype , {
body : { enumerable : true } ,
bodyUsed : { enumerable : true } ,
arrayBuffer : { enumerable : true } ,
blob : { enumerable : true } ,
json : { enumerable : true } ,
text : { enumerable : true }
} ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
Body . mixIn = function ( proto ) {
for ( const name of Object . getOwnPropertyNames ( Body . prototype ) ) {
// istanbul ignore else: future proof
if ( ! ( name in proto ) ) {
const desc = Object . getOwnPropertyDescriptor ( Body . prototype , name ) ;
Object . defineProperty ( proto , name , desc ) ;
}
}
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Consume and convert an entire Body to a Buffer .
*
* Ref : https : //fetch.spec.whatwg.org/#concept-body-consume-body
*
* @ return Promise
* /
function consumeBody ( ) {
var _this4 = this ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( this [ INTERNALS ] . disturbed ) {
return Body . Promise . reject ( new TypeError ( ` body used already for: ${ this . url } ` ) ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
this [ INTERNALS ] . disturbed = true ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( this [ INTERNALS ] . error ) {
return Body . Promise . reject ( this [ INTERNALS ] . error ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
let body = this . body ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// body is null
if ( body === null ) {
return Body . Promise . resolve ( Buffer . alloc ( 0 ) ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// body is blob
if ( isBlob ( body ) ) {
body = body . stream ( ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// body is buffer
if ( Buffer . isBuffer ( body ) ) {
return Body . Promise . resolve ( body ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// istanbul ignore if: should never happen
if ( ! ( body instanceof Stream ) ) {
return Body . Promise . resolve ( Buffer . alloc ( 0 ) ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// body is stream
// get ready to actually consume the body
let accum = [ ] ;
let accumBytes = 0 ;
let abort = false ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return new Body . Promise ( function ( resolve , reject ) {
let resTimeout ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// allow timeout on slow response body
if ( _this4 . timeout ) {
resTimeout = setTimeout ( function ( ) {
abort = true ;
reject ( new FetchError ( ` Response timeout while trying to fetch ${ _this4 . url } (over ${ _this4 . timeout } ms) ` , 'body-timeout' ) ) ;
} , _this4 . timeout ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// handle stream errors
body . on ( 'error' , function ( err ) {
if ( err . name === 'AbortError' ) {
// if the request was aborted, reject with this Error
abort = true ;
reject ( err ) ;
} else {
// other errors, such as incorrect content-encoding
reject ( new FetchError ( ` Invalid response body while trying to fetch ${ _this4 . url } : ${ err . message } ` , 'system' , err ) ) ;
}
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
body . on ( 'data' , function ( chunk ) {
if ( abort || chunk === null ) {
return ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( _this4 . size && accumBytes + chunk . length > _this4 . size ) {
abort = true ;
reject ( new FetchError ( ` content size at ${ _this4 . url } over limit: ${ _this4 . size } ` , 'max-size' ) ) ;
return ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
accumBytes += chunk . length ;
accum . push ( chunk ) ;
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
body . on ( 'end' , function ( ) {
if ( abort ) {
return ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
clearTimeout ( resTimeout ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
try {
resolve ( Buffer . concat ( accum , accumBytes ) ) ;
} catch ( err ) {
// handle streams that have accumulated too much data (issue #414)
reject ( new FetchError ( ` Could not create Buffer from response body for ${ _this4 . url } : ${ err . message } ` , 'system' , err ) ) ;
}
} ) ;
} ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Detect buffer encoding and convert to target encoding
* ref : http : //www.w3.org/TR/2011/WD-html5-20110113/parsing.html#determining-the-character-encoding
*
* @ param Buffer buffer Incoming buffer
* @ param String encoding Target encoding
* @ return String
* /
function convertBody ( buffer , headers ) {
if ( typeof convert !== 'function' ) {
throw new Error ( 'The package `encoding` must be installed to use the textConverted() function' ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const ct = headers . get ( 'content-type' ) ;
let charset = 'utf-8' ;
let res , str ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// header
if ( ct ) {
res = /charset=([^;]*)/i . exec ( ct ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// no charset in content type, peek at response body for at most 1024 bytes
str = buffer . slice ( 0 , 1024 ) . toString ( ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// html5
if ( ! res && str ) {
res = /<meta.+?charset=(['"])(.+?)\1/i . exec ( str ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// html4
if ( ! res && str ) {
res = /<meta[\s]+?http-equiv=(['"])content-type\1[\s]+?content=(['"])(.+?)\2/i . exec ( str ) ;
if ( ! res ) {
res = /<meta[\s]+?content=(['"])(.+?)\1[\s]+?http-equiv=(['"])content-type\3/i . exec ( str ) ;
if ( res ) {
res . pop ( ) ; // drop last quote
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( res ) {
res = /charset=(.*)/i . exec ( res . pop ( ) ) ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// xml
if ( ! res && str ) {
res = /<\?xml.+?encoding=(['"])(.+?)\1/i . exec ( str ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// found charset
if ( res ) {
charset = res . pop ( ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// prevent decode issues when sites use incorrect encoding
// ref: https://hsivonen.fi/encoding-menu/
if ( charset === 'gb2312' || charset === 'gbk' ) {
charset = 'gb18030' ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// turn raw buffers into a single utf-8 buffer
return convert ( buffer , 'UTF-8' , charset ) . toString ( ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Detect a URLSearchParams object
* ref : https : //github.com/bitinn/node-fetch/issues/296#issuecomment-307598143
*
* @ param Object obj Object to detect by type or brand
* @ return String
* /
function isURLSearchParams ( obj ) {
// Duck-typing as a necessary condition.
if ( typeof obj !== 'object' || typeof obj . append !== 'function' || typeof obj . delete !== 'function' || typeof obj . get !== 'function' || typeof obj . getAll !== 'function' || typeof obj . has !== 'function' || typeof obj . set !== 'function' ) {
return false ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Brand-checking and more duck-typing as optional condition.
return obj . constructor . name === 'URLSearchParams' || Object . prototype . toString . call ( obj ) === '[object URLSearchParams]' || typeof obj . sort === 'function' ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Check if ` obj ` is a W3C ` Blob ` object ( which ` File ` inherits from )
* @ param { * } obj
* @ return { boolean }
* /
function isBlob ( obj ) {
return typeof obj === 'object' && typeof obj . arrayBuffer === 'function' && typeof obj . type === 'string' && typeof obj . stream === 'function' && typeof obj . constructor === 'function' && typeof obj . constructor . name === 'string' && /^(Blob|File)$/ . test ( obj . constructor . name ) && /^(Blob|File)$/ . test ( obj [ Symbol . toStringTag ] ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Clone body given Res / Req instance
*
* @ param Mixed instance Response or Request instance
* @ return Mixed
* /
function clone ( instance ) {
let p1 , p2 ;
let body = instance . body ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// don't allow cloning a used body
if ( instance . bodyUsed ) {
throw new Error ( 'cannot clone body after it is used' ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// check that body is a stream and not form-data object
// note: we can't clone the form-data object without having it as a dependency
if ( body instanceof Stream && typeof body . getBoundary !== 'function' ) {
// tee instance body
p1 = new PassThrough ( ) ;
p2 = new PassThrough ( ) ;
body . pipe ( p1 ) ;
body . pipe ( p2 ) ;
// set instance body to teed body and return the other teed body
instance [ INTERNALS ] . body = p1 ;
body = p2 ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return body ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Performs the operation "extract a `Content-Type` value from |object|" as
* specified in the specification :
* https : //fetch.spec.whatwg.org/#concept-bodyinit-extract
*
* This function assumes that instance . body is present .
*
* @ param Mixed instance Any options . body input
* /
function extractContentType ( body ) {
if ( body === null ) {
// body is null
return null ;
} else if ( typeof body === 'string' ) {
// body is string
return 'text/plain;charset=UTF-8' ;
} else if ( isURLSearchParams ( body ) ) {
// body is a URLSearchParams
return 'application/x-www-form-urlencoded;charset=UTF-8' ;
} else if ( isBlob ( body ) ) {
// body is blob
return body . type || null ;
} else if ( Buffer . isBuffer ( body ) ) {
// body is buffer
return null ;
} else if ( Object . prototype . toString . call ( body ) === '[object ArrayBuffer]' ) {
// body is ArrayBuffer
return null ;
} else if ( ArrayBuffer . isView ( body ) ) {
// body is ArrayBufferView
return null ;
} else if ( typeof body . getBoundary === 'function' ) {
// detect form data input from form-data module
return ` multipart/form-data;boundary= ${ body . getBoundary ( ) } ` ;
} else if ( body instanceof Stream ) {
// body is stream
// can't really do much about this
return null ;
} else {
// Body constructor defaults other things to string
return 'text/plain;charset=UTF-8' ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* The Fetch Standard treats this as if "total bytes" is a property on the body .
* For us , we have to explicitly get it with a function .
*
* ref : https : //fetch.spec.whatwg.org/#concept-body-total-bytes
*
* @ param Body instance Instance of Body
* @ return Number ? Number of bytes , or null if not possible
* /
function getTotalBytes ( instance ) {
const body = instance . body ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( body === null ) {
// body is null
return 0 ;
} else if ( isBlob ( body ) ) {
return body . size ;
} else if ( Buffer . isBuffer ( body ) ) {
// body is buffer
return body . length ;
} else if ( body && typeof body . getLengthSync === 'function' ) {
// detect form data input from form-data module
if ( body . _lengthRetrievers && body . _lengthRetrievers . length == 0 || // 1.x
body . hasKnownLength && body . hasKnownLength ( ) ) {
// 2.x
return body . getLengthSync ( ) ;
}
return null ;
} else {
// body is stream
return null ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Write a Body to a Node . js WritableStream ( e . g . http . Request ) object .
*
* @ param Body instance Instance of Body
* @ return Void
* /
function writeToStream ( dest , instance ) {
const body = instance . body ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( body === null ) {
// body is null
dest . end ( ) ;
} else if ( isBlob ( body ) ) {
body . stream ( ) . pipe ( dest ) ;
} else if ( Buffer . isBuffer ( body ) ) {
// body is buffer
dest . write ( body ) ;
dest . end ( ) ;
} else {
// body is stream
body . pipe ( dest ) ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// expose Promise
Body . Promise = global . Promise ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* headers . js
*
* Headers class offers convenient helpers
* /
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const invalidTokenRegex = /[^\^_`a-zA-Z\-0-9!#$%&'*+.|~]/ ;
const invalidHeaderCharRegex = /[^\t\x20-\x7e\x80-\xff]/ ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function validateName ( name ) {
name = ` ${ name } ` ;
if ( invalidTokenRegex . test ( name ) || name === '' ) {
throw new TypeError ( ` ${ name } is not a legal HTTP header name ` ) ;
}
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function validateValue ( value ) {
value = ` ${ value } ` ;
if ( invalidHeaderCharRegex . test ( value ) ) {
throw new TypeError ( ` ${ value } is not a legal HTTP header value ` ) ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Find the key in the map object given a header name .
*
* Returns undefined if not found .
*
* @ param String name Header name
* @ return String | Undefined
* /
function find ( map , name ) {
name = name . toLowerCase ( ) ;
for ( const key in map ) {
if ( key . toLowerCase ( ) === name ) {
return key ;
}
}
return undefined ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const MAP = Symbol ( 'map' ) ;
class Headers {
/ * *
* Headers class
*
* @ param Object headers Response headers
* @ return Void
* /
constructor ( ) {
let init = arguments . length > 0 && arguments [ 0 ] !== undefined ? arguments [ 0 ] : undefined ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
this [ MAP ] = Object . create ( null ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( init instanceof Headers ) {
const rawHeaders = init . raw ( ) ;
const headerNames = Object . keys ( rawHeaders ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
for ( const headerName of headerNames ) {
for ( const value of rawHeaders [ headerName ] ) {
this . append ( headerName , value ) ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// We don't worry about converting prop to ByteString here as append()
// will handle it.
if ( init == null ) ; else if ( typeof init === 'object' ) {
const method = init [ Symbol . iterator ] ;
if ( method != null ) {
if ( typeof method !== 'function' ) {
throw new TypeError ( 'Header pairs must be iterable' ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// sequence<sequence<ByteString>>
// Note: per spec we have to first exhaust the lists then process them
const pairs = [ ] ;
for ( const pair of init ) {
if ( typeof pair !== 'object' || typeof pair [ Symbol . iterator ] !== 'function' ) {
throw new TypeError ( 'Each header pair must be iterable' ) ;
}
pairs . push ( Array . from ( pair ) ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
for ( const pair of pairs ) {
if ( pair . length !== 2 ) {
throw new TypeError ( 'Each header pair must be a name/value tuple' ) ;
}
this . append ( pair [ 0 ] , pair [ 1 ] ) ;
}
} else {
// record<ByteString, ByteString>
for ( const key of Object . keys ( init ) ) {
const value = init [ key ] ;
this . append ( key , value ) ;
}
}
} else {
throw new TypeError ( 'Provided initializer must be an object' ) ;
}
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Return combined header value given name
*
* @ param String name Header name
* @ return Mixed
* /
get ( name ) {
name = ` ${ name } ` ;
validateName ( name ) ;
const key = find ( this [ MAP ] , name ) ;
if ( key === undefined ) {
return null ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return this [ MAP ] [ key ] . join ( ', ' ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Iterate over all headers
*
* @ param Function callback Executed for each item with parameters ( value , name , thisArg )
* @ param Boolean thisArg ` this ` context for callback function
* @ return Void
* /
forEach ( callback ) {
let thisArg = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : undefined ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
let pairs = getHeaders ( this ) ;
let i = 0 ;
while ( i < pairs . length ) {
var _pairs$i = pairs [ i ] ;
const name = _pairs$i [ 0 ] ,
value = _pairs$i [ 1 ] ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
callback . call ( thisArg , value , name , this ) ;
pairs = getHeaders ( this ) ;
i ++ ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Overwrite header values given name
*
* @ param String name Header name
* @ param String value Header value
* @ return Void
* /
set ( name , value ) {
name = ` ${ name } ` ;
value = ` ${ value } ` ;
validateName ( name ) ;
validateValue ( value ) ;
const key = find ( this [ MAP ] , name ) ;
this [ MAP ] [ key !== undefined ? key : name ] = [ value ] ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Append a value onto existing header
*
* @ param String name Header name
* @ param String value Header value
* @ return Void
* /
append ( name , value ) {
name = ` ${ name } ` ;
value = ` ${ value } ` ;
validateName ( name ) ;
validateValue ( value ) ;
const key = find ( this [ MAP ] , name ) ;
if ( key !== undefined ) {
this [ MAP ] [ key ] . push ( value ) ;
} else {
this [ MAP ] [ name ] = [ value ] ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Check for header name existence
*
* @ param String name Header name
* @ return Boolean
* /
has ( name ) {
name = ` ${ name } ` ;
validateName ( name ) ;
return find ( this [ MAP ] , name ) !== undefined ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Delete all header values given name
*
* @ param String name Header name
* @ return Void
* /
delete ( name ) {
name = ` ${ name } ` ;
validateName ( name ) ;
const key = find ( this [ MAP ] , name ) ;
if ( key !== undefined ) {
delete this [ MAP ] [ key ] ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Return raw headers ( non - spec api )
*
* @ return Object
* /
raw ( ) {
return this [ MAP ] ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Get an iterator on keys .
*
* @ return Iterator
* /
keys ( ) {
return createHeadersIterator ( this , 'key' ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Get an iterator on values .
*
* @ return Iterator
* /
values ( ) {
return createHeadersIterator ( this , 'value' ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Get an iterator on entries .
*
* This is the default iterator of the Headers object .
*
* @ return Iterator
* /
[ Symbol . iterator ] ( ) {
return createHeadersIterator ( this , 'key+value' ) ;
}
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
Headers . prototype . entries = Headers . prototype [ Symbol . iterator ] ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( Headers . prototype , Symbol . toStringTag , {
value : 'Headers' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperties ( Headers . prototype , {
get : { enumerable : true } ,
forEach : { enumerable : true } ,
set : { enumerable : true } ,
append : { enumerable : true } ,
has : { enumerable : true } ,
delete : { enumerable : true } ,
keys : { enumerable : true } ,
values : { enumerable : true } ,
entries : { enumerable : true }
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function getHeaders ( headers ) {
let kind = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : 'key+value' ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const keys = Object . keys ( headers [ MAP ] ) . sort ( ) ;
return keys . map ( kind === 'key' ? function ( k ) {
return k . toLowerCase ( ) ;
} : kind === 'value' ? function ( k ) {
return headers [ MAP ] [ k ] . join ( ', ' ) ;
} : function ( k ) {
return [ k . toLowerCase ( ) , headers [ MAP ] [ k ] . join ( ', ' ) ] ;
} ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const INTERNAL = Symbol ( 'internal' ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function createHeadersIterator ( target , kind ) {
const iterator = Object . create ( HeadersIteratorPrototype ) ;
iterator [ INTERNAL ] = {
target ,
kind ,
index : 0
} ;
return iterator ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const HeadersIteratorPrototype = Object . setPrototypeOf ( {
next ( ) {
// istanbul ignore if
if ( ! this || Object . getPrototypeOf ( this ) !== HeadersIteratorPrototype ) {
throw new TypeError ( 'Value of `this` is not a HeadersIterator' ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var _INTERNAL = this [ INTERNAL ] ;
const target = _INTERNAL . target ,
kind = _INTERNAL . kind ,
index = _INTERNAL . index ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const values = getHeaders ( target , kind ) ;
const len = values . length ;
if ( index >= len ) {
return {
value : undefined ,
done : true
} ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
this [ INTERNAL ] . index = index + 1 ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return {
value : values [ index ] ,
done : false
} ;
}
} , Object . getPrototypeOf ( Object . getPrototypeOf ( [ ] [ Symbol . iterator ] ( ) ) ) ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( HeadersIteratorPrototype , Symbol . toStringTag , {
value : 'HeadersIterator' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Export the Headers object in a form that Node . js can consume .
*
* @ param Headers headers
* @ return Object
* /
function exportNodeCompatibleHeaders ( headers ) {
const obj = Object . assign ( { _ _proto _ _ : null } , headers [ MAP ] ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// http.request() only supports string as Host header. This hack makes
// specifying custom Host header possible.
const hostHeaderKey = find ( headers [ MAP ] , 'Host' ) ;
if ( hostHeaderKey !== undefined ) {
obj [ hostHeaderKey ] = obj [ hostHeaderKey ] [ 0 ] ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return obj ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Create a Headers object from an object of headers , ignoring those that do
* not conform to HTTP grammar productions .
*
* @ param Object obj Object of headers
* @ return Headers
* /
function createHeadersLenient ( obj ) {
const headers = new Headers ( ) ;
for ( const name of Object . keys ( obj ) ) {
if ( invalidTokenRegex . test ( name ) ) {
continue ;
}
if ( Array . isArray ( obj [ name ] ) ) {
for ( const val of obj [ name ] ) {
if ( invalidHeaderCharRegex . test ( val ) ) {
continue ;
}
if ( headers [ MAP ] [ name ] === undefined ) {
headers [ MAP ] [ name ] = [ val ] ;
} else {
headers [ MAP ] [ name ] . push ( val ) ;
}
}
} else if ( ! invalidHeaderCharRegex . test ( obj [ name ] ) ) {
headers [ MAP ] [ name ] = [ obj [ name ] ] ;
}
}
return headers ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const INTERNALS$1 = Symbol ( 'Response internals' ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// fix an issue where "STATUS_CODES" aren't a named export for node <10
const STATUS _CODES = http . STATUS _CODES ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Response class
*
* @ param Stream body Readable stream
* @ param Object opts Response options
* @ return Void
* /
class Response {
constructor ( ) {
let body = arguments . length > 0 && arguments [ 0 ] !== undefined ? arguments [ 0 ] : null ;
let opts = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : { } ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Body . call ( this , body , opts ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const status = opts . status || 200 ;
const headers = new Headers ( opts . headers ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( body != null && ! headers . has ( 'Content-Type' ) ) {
const contentType = extractContentType ( body ) ;
if ( contentType ) {
headers . append ( 'Content-Type' , contentType ) ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
this [ INTERNALS$1 ] = {
url : opts . url ,
status ,
statusText : opts . statusText || STATUS _CODES [ status ] ,
headers ,
counter : opts . counter
} ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
get url ( ) {
return this [ INTERNALS$1 ] . url || '' ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
get status ( ) {
return this [ INTERNALS$1 ] . status ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Convenience property representing if the request ended normally
* /
get ok ( ) {
return this [ INTERNALS$1 ] . status >= 200 && this [ INTERNALS$1 ] . status < 300 ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
get redirected ( ) {
return this [ INTERNALS$1 ] . counter > 0 ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
get statusText ( ) {
return this [ INTERNALS$1 ] . statusText ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
get headers ( ) {
return this [ INTERNALS$1 ] . headers ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Clone this response
*
* @ return Response
* /
clone ( ) {
return new Response ( clone ( this ) , {
url : this . url ,
status : this . status ,
statusText : this . statusText ,
headers : this . headers ,
ok : this . ok ,
redirected : this . redirected
} ) ;
}
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
Body . mixIn ( Response . prototype ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperties ( Response . prototype , {
url : { enumerable : true } ,
status : { enumerable : true } ,
ok : { enumerable : true } ,
redirected : { enumerable : true } ,
statusText : { enumerable : true } ,
headers : { enumerable : true } ,
clone : { enumerable : true }
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( Response . prototype , Symbol . toStringTag , {
value : 'Response' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const INTERNALS$2 = Symbol ( 'Request internals' ) ;
const URL = Url . URL || whatwgUrl . URL ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// fix an issue where "format", "parse" aren't a named export for node <10
const parse _url = Url . parse ;
const format _url = Url . format ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Wrapper around ` new URL ` to handle arbitrary URLs
*
* @ param { string } urlStr
* @ return { void }
* /
function parseURL ( urlStr ) {
/ *
Check whether the URL is absolute or not
Scheme : https : //tools.ietf.org/html/rfc3986#section-3.1
Absolute URL : https : //tools.ietf.org/html/rfc3986#section-4.3
* /
if ( /^[a-zA-Z][a-zA-Z\d+\-.]*:/ . exec ( urlStr ) ) {
urlStr = new URL ( urlStr ) . toString ( ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Fallback to old implementation for arbitrary URLs
return parse _url ( urlStr ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const streamDestructionSupported = 'destroy' in Stream . Readable . prototype ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Check if a value is an instance of Request .
*
* @ param Mixed input
* @ return Boolean
* /
function isRequest ( input ) {
return typeof input === 'object' && typeof input [ INTERNALS$2 ] === 'object' ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function isAbortSignal ( signal ) {
const proto = signal && typeof signal === 'object' && Object . getPrototypeOf ( signal ) ;
return ! ! ( proto && proto . constructor . name === 'AbortSignal' ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Request class
*
* @ param Mixed input Url or Request instance
* @ param Object init Custom options
* @ return Void
* /
class Request {
constructor ( input ) {
let init = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : { } ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
let parsedURL ;
// normalize input
if ( ! isRequest ( input ) ) {
if ( input && input . href ) {
// in order to support Node.js' Url objects; though WHATWG's URL objects
// will fall into this branch also (since their `toString()` will return
// `href` property anyway)
parsedURL = parseURL ( input . href ) ;
} else {
// coerce input to a string before attempting to parse
parsedURL = parseURL ( ` ${ input } ` ) ;
}
input = { } ;
} else {
parsedURL = parseURL ( input . url ) ;
}
let method = init . method || input . method || 'GET' ;
method = method . toUpperCase ( ) ;
if ( ( init . body != null || isRequest ( input ) && input . body !== null ) && ( method === 'GET' || method === 'HEAD' ) ) {
throw new TypeError ( 'Request with GET/HEAD method cannot have body' ) ;
}
let inputBody = init . body != null ? init . body : isRequest ( input ) && input . body !== null ? clone ( input ) : null ;
Body . call ( this , inputBody , {
timeout : init . timeout || input . timeout || 0 ,
size : init . size || input . size || 0
} ) ;
const headers = new Headers ( init . headers || input . headers || { } ) ;
if ( inputBody != null && ! headers . has ( 'Content-Type' ) ) {
const contentType = extractContentType ( inputBody ) ;
if ( contentType ) {
headers . append ( 'Content-Type' , contentType ) ;
}
}
let signal = isRequest ( input ) ? input . signal : null ;
if ( 'signal' in init ) signal = init . signal ;
if ( signal != null && ! isAbortSignal ( signal ) ) {
throw new TypeError ( 'Expected signal to be an instanceof AbortSignal' ) ;
}
this [ INTERNALS$2 ] = {
method ,
redirect : init . redirect || input . redirect || 'follow' ,
headers ,
parsedURL ,
signal
} ;
// node-fetch-only options
this . follow = init . follow !== undefined ? init . follow : input . follow !== undefined ? input . follow : 20 ;
this . compress = init . compress !== undefined ? init . compress : input . compress !== undefined ? input . compress : true ;
this . counter = init . counter || input . counter || 0 ;
this . agent = init . agent || input . agent ;
}
get method ( ) {
return this [ INTERNALS$2 ] . method ;
}
get url ( ) {
return format _url ( this [ INTERNALS$2 ] . parsedURL ) ;
}
get headers ( ) {
return this [ INTERNALS$2 ] . headers ;
}
get redirect ( ) {
return this [ INTERNALS$2 ] . redirect ;
}
get signal ( ) {
return this [ INTERNALS$2 ] . signal ;
}
/ * *
* Clone this request
*
* @ return Request
* /
clone ( ) {
return new Request ( this ) ;
}
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
Body . mixIn ( Request . prototype ) ;
Object . defineProperty ( Request . prototype , Symbol . toStringTag , {
value : 'Request' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
Object . defineProperties ( Request . prototype , {
method : { enumerable : true } ,
url : { enumerable : true } ,
headers : { enumerable : true } ,
redirect : { enumerable : true } ,
clone : { enumerable : true } ,
signal : { enumerable : true }
} ) ;
/ * *
* Convert a Request to Node . js http request options .
*
* @ param Request A Request instance
* @ return Object The options object to be passed to http . request
* /
function getNodeRequestOptions ( request ) {
const parsedURL = request [ INTERNALS$2 ] . parsedURL ;
const headers = new Headers ( request [ INTERNALS$2 ] . headers ) ;
// fetch step 1.3
if ( ! headers . has ( 'Accept' ) ) {
headers . set ( 'Accept' , '*/*' ) ;
}
// Basic fetch
if ( ! parsedURL . protocol || ! parsedURL . hostname ) {
throw new TypeError ( 'Only absolute URLs are supported' ) ;
}
if ( ! /^https?:$/ . test ( parsedURL . protocol ) ) {
throw new TypeError ( 'Only HTTP(S) protocols are supported' ) ;
}
if ( request . signal && request . body instanceof Stream . Readable && ! streamDestructionSupported ) {
throw new Error ( 'Cancellation of streamed requests with AbortSignal is not supported in node < 8' ) ;
}
// HTTP-network-or-cache fetch steps 2.4-2.7
let contentLengthValue = null ;
if ( request . body == null && /^(POST|PUT)$/i . test ( request . method ) ) {
contentLengthValue = '0' ;
}
if ( request . body != null ) {
const totalBytes = getTotalBytes ( request ) ;
if ( typeof totalBytes === 'number' ) {
contentLengthValue = String ( totalBytes ) ;
}
}
if ( contentLengthValue ) {
headers . set ( 'Content-Length' , contentLengthValue ) ;
}
// HTTP-network-or-cache fetch step 2.11
if ( ! headers . has ( 'User-Agent' ) ) {
headers . set ( 'User-Agent' , 'node-fetch/1.0 (+https://github.com/bitinn/node-fetch)' ) ;
}
// HTTP-network-or-cache fetch step 2.15
if ( request . compress && ! headers . has ( 'Accept-Encoding' ) ) {
headers . set ( 'Accept-Encoding' , 'gzip,deflate' ) ;
}
let agent = request . agent ;
if ( typeof agent === 'function' ) {
agent = agent ( parsedURL ) ;
}
if ( ! headers . has ( 'Connection' ) && ! agent ) {
headers . set ( 'Connection' , 'close' ) ;
}
// HTTP-network fetch step 4.2
// chunked encoding is handled by Node.js
return Object . assign ( { } , parsedURL , {
method : request . method ,
headers : exportNodeCompatibleHeaders ( headers ) ,
agent
} ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* abort - error . js
*
* AbortError interface for cancelled requests
* /
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/ * *
* Create AbortError instance
*
* @ param String message Error message for human
* @ return AbortError
* /
function AbortError ( message ) {
Error . call ( this , message ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
this . type = 'aborted' ;
this . message = message ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// hide custom error implementation details from end-users
Error . captureStackTrace ( this , this . constructor ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
AbortError . prototype = Object . create ( Error . prototype ) ;
AbortError . prototype . constructor = AbortError ;
AbortError . prototype . name = 'AbortError' ;
const URL$1 = Url . URL || whatwgUrl . URL ;
// fix an issue where "PassThrough", "resolve" aren't a named export for node <10
const PassThrough$1 = Stream . PassThrough ;
const isDomainOrSubdomain = function isDomainOrSubdomain ( destination , original ) {
const orig = new URL$1 ( original ) . hostname ;
const dest = new URL$1 ( destination ) . hostname ;
return orig === dest || orig [ orig . length - dest . length - 1 ] === '.' && orig . endsWith ( dest ) ;
2022-10-11 16:10:23 +02:00
} ;
2024-05-19 08:24:38 +02:00
2022-10-12 17:48:05 +02:00
/ * *
2024-05-19 08:24:38 +02:00
* Fetch function
*
* @ param Mixed url Absolute url or Request instance
* @ param Object opts Fetch options
* @ return Promise
2022-10-12 17:48:05 +02:00
* /
2024-05-19 08:24:38 +02:00
function fetch ( url , opts ) {
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// allow custom promise
if ( ! fetch . Promise ) {
throw new Error ( 'native promise missing, set fetch.Promise to your favorite alternative' ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
Body . Promise = fetch . Promise ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// wrap http.request into fetch
return new fetch . Promise ( function ( resolve , reject ) {
// build request object
const request = new Request ( url , opts ) ;
const options = getNodeRequestOptions ( request ) ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const send = ( options . protocol === 'https:' ? https : http ) . request ;
const signal = request . signal ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
let response = null ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const abort = function abort ( ) {
let error = new AbortError ( 'The user aborted a request.' ) ;
reject ( error ) ;
if ( request . body && request . body instanceof Stream . Readable ) {
request . body . destroy ( error ) ;
}
if ( ! response || ! response . body ) return ;
response . body . emit ( 'error' , error ) ;
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( signal && signal . aborted ) {
abort ( ) ;
return ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const abortAndFinalize = function abortAndFinalize ( ) {
abort ( ) ;
finalize ( ) ;
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// send request
const req = send ( options ) ;
let reqTimeout ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( signal ) {
signal . addEventListener ( 'abort' , abortAndFinalize ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function finalize ( ) {
req . abort ( ) ;
if ( signal ) signal . removeEventListener ( 'abort' , abortAndFinalize ) ;
clearTimeout ( reqTimeout ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( request . timeout ) {
req . once ( 'socket' , function ( socket ) {
reqTimeout = setTimeout ( function ( ) {
reject ( new FetchError ( ` network timeout at: ${ request . url } ` , 'request-timeout' ) ) ;
finalize ( ) ;
} , request . timeout ) ;
} ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
req . on ( 'error' , function ( err ) {
reject ( new FetchError ( ` request to ${ request . url } failed, reason: ${ err . message } ` , 'system' , err ) ) ;
finalize ( ) ;
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
req . on ( 'response' , function ( res ) {
clearTimeout ( reqTimeout ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const headers = createHeadersLenient ( res . headers ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// HTTP fetch step 5
if ( fetch . isRedirect ( res . statusCode ) ) {
// HTTP fetch step 5.2
const location = headers . get ( 'Location' ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// HTTP fetch step 5.3
let locationURL = null ;
try {
locationURL = location === null ? null : new URL$1 ( location , request . url ) . toString ( ) ;
} catch ( err ) {
// error here can only be invalid URL in Location: header
// do not throw when options.redirect == manual
// let the user extract the errorneous redirect URL
if ( request . redirect !== 'manual' ) {
reject ( new FetchError ( ` uri requested responds with an invalid redirect URL: ${ location } ` , 'invalid-redirect' ) ) ;
finalize ( ) ;
return ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// HTTP fetch step 5.5
switch ( request . redirect ) {
case 'error' :
reject ( new FetchError ( ` uri requested responds with a redirect, redirect mode is set to error: ${ request . url } ` , 'no-redirect' ) ) ;
finalize ( ) ;
return ;
case 'manual' :
// node-fetch-specific step: make manual redirect a bit easier to use by setting the Location header value to the resolved URL.
if ( locationURL !== null ) {
// handle corrupted header
try {
headers . set ( 'Location' , locationURL ) ;
} catch ( err ) {
// istanbul ignore next: nodejs server prevent invalid response headers, we can't test this through normal request
reject ( err ) ;
}
}
break ;
case 'follow' :
// HTTP-redirect fetch step 2
if ( locationURL === null ) {
break ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// HTTP-redirect fetch step 5
if ( request . counter >= request . follow ) {
reject ( new FetchError ( ` maximum redirect reached at: ${ request . url } ` , 'max-redirect' ) ) ;
finalize ( ) ;
return ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// HTTP-redirect fetch step 6 (counter increment)
// Create a new Request object.
const requestOpts = {
headers : new Headers ( request . headers ) ,
follow : request . follow ,
counter : request . counter + 1 ,
agent : request . agent ,
compress : request . compress ,
method : request . method ,
body : request . body ,
signal : request . signal ,
timeout : request . timeout ,
size : request . size
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! isDomainOrSubdomain ( request . url , locationURL ) ) {
for ( const name of [ 'authorization' , 'www-authenticate' , 'cookie' , 'cookie2' ] ) {
requestOpts . headers . delete ( name ) ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// HTTP-redirect fetch step 9
if ( res . statusCode !== 303 && request . body && getTotalBytes ( request ) === null ) {
reject ( new FetchError ( 'Cannot follow redirect with body being a readable stream' , 'unsupported-redirect' ) ) ;
finalize ( ) ;
return ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// HTTP-redirect fetch step 11
if ( res . statusCode === 303 || ( res . statusCode === 301 || res . statusCode === 302 ) && request . method === 'POST' ) {
requestOpts . method = 'GET' ;
requestOpts . body = undefined ;
requestOpts . headers . delete ( 'content-length' ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// HTTP-redirect fetch step 15
resolve ( fetch ( new Request ( locationURL , requestOpts ) ) ) ;
finalize ( ) ;
return ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// prepare response
res . once ( 'end' , function ( ) {
if ( signal ) signal . removeEventListener ( 'abort' , abortAndFinalize ) ;
} ) ;
let body = res . pipe ( new PassThrough$1 ( ) ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const response _options = {
url : request . url ,
status : res . statusCode ,
statusText : res . statusMessage ,
headers : headers ,
size : request . size ,
timeout : request . timeout ,
counter : request . counter
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// HTTP-network fetch step 12.1.1.3
const codings = headers . get ( 'Content-Encoding' ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// HTTP-network fetch step 12.1.1.4: handle content codings
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// in following scenarios we ignore compression support
// 1. compression support is disabled
// 2. HEAD request
// 3. no Content-Encoding header
// 4. no content response (204)
// 5. content not modified response (304)
if ( ! request . compress || request . method === 'HEAD' || codings === null || res . statusCode === 204 || res . statusCode === 304 ) {
response = new Response ( body , response _options ) ;
resolve ( response ) ;
return ;
}
// For Node v6+
// Be less strict when decoding compressed responses, since sometimes
// servers send slightly invalid responses that are still accepted
// by common browsers.
// Always using Z_SYNC_FLUSH is what cURL does.
const zlibOptions = {
flush : zlib . Z _SYNC _FLUSH ,
finishFlush : zlib . Z _SYNC _FLUSH
} ;
// for gzip
if ( codings == 'gzip' || codings == 'x-gzip' ) {
body = body . pipe ( zlib . createGunzip ( zlibOptions ) ) ;
response = new Response ( body , response _options ) ;
resolve ( response ) ;
return ;
}
// for deflate
if ( codings == 'deflate' || codings == 'x-deflate' ) {
// handle the infamous raw deflate response from old servers
// a hack for old IIS and Apache servers
const raw = res . pipe ( new PassThrough$1 ( ) ) ;
raw . once ( 'data' , function ( chunk ) {
// see http://stackoverflow.com/questions/37519828
if ( ( chunk [ 0 ] & 0x0F ) === 0x08 ) {
body = body . pipe ( zlib . createInflate ( ) ) ;
} else {
body = body . pipe ( zlib . createInflateRaw ( ) ) ;
}
response = new Response ( body , response _options ) ;
resolve ( response ) ;
} ) ;
return ;
}
// for br
if ( codings == 'br' && typeof zlib . createBrotliDecompress === 'function' ) {
body = body . pipe ( zlib . createBrotliDecompress ( ) ) ;
response = new Response ( body , response _options ) ;
resolve ( response ) ;
return ;
}
// otherwise, use response as-is
response = new Response ( body , response _options ) ;
resolve ( response ) ;
} ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
writeToStream ( req , request ) ;
} ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
/ * *
* Redirect code matching
*
* @ param Number code Status code
* @ return Boolean
* /
fetch . isRedirect = function ( code ) {
return code === 301 || code === 302 || code === 303 || code === 307 || code === 308 ;
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// expose Promise
fetch . Promise = global . Promise ;
module . exports = exports = fetch ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports [ "default" ] = exports ;
exports . Headers = Headers ;
exports . Request = Request ;
exports . Response = Response ;
exports . FetchError = FetchError ;
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 502 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
2022-10-12 17:48:05 +02:00
"use strict" ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
const path = _ _nccwpck _require _ _ ( 1017 ) ;
const pathKey = _ _nccwpck _require _ _ ( 539 ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
module . exports = opts => {
opts = Object . assign ( {
cwd : process . cwd ( ) ,
path : process . env [ pathKey ( ) ]
} , opts ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
let prev ;
let pth = path . resolve ( opts . cwd ) ;
const ret = [ ] ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
while ( prev !== pth ) {
ret . push ( path . join ( pth , 'node_modules/.bin' ) ) ;
prev = pth ;
pth = path . resolve ( pth , '..' ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// ensure the running `node` binary is used
ret . push ( path . dirname ( process . execPath ) ) ;
return ret . concat ( opts . path ) . join ( path . delimiter ) ;
} ;
module . exports . env = opts => {
opts = Object . assign ( {
env : process . env
} , opts ) ;
const env = Object . assign ( { } , opts . env ) ;
const path = pathKey ( { env } ) ;
opts . path = env [ path ] ;
env [ path ] = module . exports ( opts ) ;
return env ;
} ;
/***/ } ) ,
/***/ 1223 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
var wrappy = _ _nccwpck _require _ _ ( 2940 )
module . exports = wrappy ( once )
module . exports . strict = wrappy ( onceStrict )
once . proto = once ( function ( ) {
Object . defineProperty ( Function . prototype , 'once' , {
value : function ( ) {
return once ( this )
} ,
configurable : true
} )
Object . defineProperty ( Function . prototype , 'onceStrict' , {
value : function ( ) {
return onceStrict ( this )
} ,
configurable : true
} )
} )
function once ( fn ) {
var f = function ( ) {
if ( f . called ) return f . value
f . called = true
return f . value = fn . apply ( this , arguments )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
f . called = false
return f
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function onceStrict ( fn ) {
var f = function ( ) {
if ( f . called )
throw new Error ( f . onceError )
f . called = true
return f . value = fn . apply ( this , arguments )
}
var name = fn . name || 'Function wrapped with `once`'
f . onceError = name + " shouldn't be called more than once"
f . called = false
return f
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 4824 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
const os = _ _nccwpck _require _ _ ( 2037 ) ;
const macosRelease = _ _nccwpck _require _ _ ( 7493 ) ;
const winRelease = _ _nccwpck _require _ _ ( 3515 ) ;
const osName = ( platform , release ) => {
if ( ! platform && release ) {
throw new Error ( 'You can\'t specify a `release` without specifying `platform`' ) ;
}
platform = platform || os . platform ( ) ;
let id ;
if ( platform === 'darwin' ) {
if ( ! release && os . platform ( ) === 'darwin' ) {
release = os . release ( ) ;
}
const prefix = release ? ( Number ( release . split ( '.' ) [ 0 ] ) > 15 ? 'macOS' : 'OS X' ) : 'macOS' ;
id = release ? macosRelease ( release ) . name : '' ;
return prefix + ( id ? ' ' + id : '' ) ;
}
if ( platform === 'linux' ) {
if ( ! release && os . platform ( ) === 'linux' ) {
release = os . release ( ) ;
}
id = release ? release . replace ( /^(\d+\.\d+).*/ , '$1' ) : '' ;
return 'Linux' + ( id ? ' ' + id : '' ) ;
}
if ( platform === 'win32' ) {
if ( ! release && os . platform ( ) === 'win32' ) {
release = os . release ( ) ;
}
id = release ? winRelease ( release ) : '' ;
return 'Windows' + ( id ? ' ' + id : '' ) ;
}
return platform ;
} ;
module . exports = osName ;
/***/ } ) ,
/***/ 1330 :
/***/ ( ( module ) => {
2022-10-12 17:48:05 +02:00
"use strict" ;
module . exports = ( promise , onFinally ) => {
onFinally = onFinally || ( ( ) => { } ) ;
return promise . then (
val => new Promise ( resolve => {
resolve ( onFinally ( ) ) ;
} ) . then ( ( ) => val ) ,
err => new Promise ( resolve => {
resolve ( onFinally ( ) ) ;
} ) . then ( ( ) => {
throw err ;
} )
) ;
} ;
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 539 :
/***/ ( ( module ) => {
2022-10-11 16:10:23 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
module . exports = opts => {
opts = opts || { } ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const env = opts . env || process . env ;
const platform = opts . platform || process . platform ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( platform !== 'win32' ) {
return 'PATH' ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return Object . keys ( env ) . find ( x => x . toUpperCase ( ) === 'PATH' ) || 'Path' ;
} ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
/***/ 8341 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
var once = _ _nccwpck _require _ _ ( 1223 )
var eos = _ _nccwpck _require _ _ ( 1205 )
var fs = _ _nccwpck _require _ _ ( 7147 ) // we only need fs to get the ReadStream and WriteStream prototypes
var noop = function ( ) { }
var ancient = /^v?\.0/ . test ( process . version )
var isFn = function ( fn ) {
return typeof fn === 'function'
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
var isFS = function ( stream ) {
if ( ! ancient ) return false // newer node version do not need to care about fs is a special way
if ( ! fs ) return false // browser
return ( stream instanceof ( fs . ReadStream || noop ) || stream instanceof ( fs . WriteStream || noop ) ) && isFn ( stream . close )
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
var isRequest = function ( stream ) {
return stream . setHeader && isFn ( stream . abort )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var destroyer = function ( stream , reading , writing , callback ) {
callback = once ( callback )
var closed = false
stream . on ( 'close' , function ( ) {
closed = true
} )
eos ( stream , { readable : reading , writable : writing } , function ( err ) {
if ( err ) return callback ( err )
closed = true
callback ( )
} )
var destroyed = false
return function ( err ) {
if ( closed ) return
if ( destroyed ) return
destroyed = true
if ( isFS ( stream ) ) return stream . close ( noop ) // use close for fs streams to avoid fd leaks
if ( isRequest ( stream ) ) return stream . abort ( ) // request.destroy just do .end - .abort is what we want
if ( isFn ( stream . destroy ) ) return stream . destroy ( )
callback ( err || new Error ( 'stream was destroyed' ) )
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var call = function ( fn ) {
fn ( )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var pipe = function ( from , to ) {
return from . pipe ( to )
}
var pump = function ( ) {
var streams = Array . prototype . slice . call ( arguments )
var callback = isFn ( streams [ streams . length - 1 ] || noop ) && streams . pop ( ) || noop
if ( Array . isArray ( streams [ 0 ] ) ) streams = streams [ 0 ]
if ( streams . length < 2 ) throw new Error ( 'pump requires two streams per minimum' )
var error
var destroys = streams . map ( function ( stream , i ) {
var reading = i < streams . length - 1
var writing = i > 0
return destroyer ( stream , reading , writing , function ( err ) {
if ( ! error ) error = err
if ( err ) destroys . forEach ( call )
if ( reading ) return
destroys . forEach ( call )
callback ( error )
} )
} )
return streams . reduce ( pipe )
}
module . exports = pump
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 6303 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
2022-10-11 16:10:23 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
/ * *
*
* Let ' s say we have this function declared somewhere .
*
* function get _ _filename ( ) {
* return get _caller _file _path ( ) ;
* }
*
* Then we can assert that :
*
* get _ _filename ( ) === _ _filename
*
*
* /
function get _caller _file _path ( ) {
//NOTE: Cannot be move to the index file.
//The function can't be declared and used
//in the same file.
var prepareStackTraceBackup = Error . prepareStackTrace ;
var callerFile = "" ;
try {
var error = new Error ( ) ;
Error . prepareStackTrace = function ( _ , stack ) { return stack ; } ;
error . stack . shift ( ) . getFileName ( ) ;
var fileImportedFrom = error . stack . shift ( ) . getFileName ( ) ;
while ( error . stack . length ) {
var fileName = error . stack . shift ( ) . getFileName ( ) ;
if ( fileName === callerFile ) {
break ;
}
callerFile = fileName ;
if ( fileImportedFrom !== callerFile ) {
break ;
}
}
}
catch ( _a ) { }
Error . prepareStackTrace = prepareStackTraceBackup ;
return callerFile ;
}
exports . get _caller _file _path = get _caller _file _path ;
/***/ } ) ,
/***/ 8804 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _extends = ( this && this . _ _extends ) || ( function ( ) {
var extendStatics = function ( d , b ) {
extendStatics = Object . setPrototypeOf ||
( { _ _proto _ _ : [ ] } instanceof Array && function ( d , b ) { d . _ _proto _ _ = b ; } ) ||
function ( d , b ) { for ( var p in b ) if ( b . hasOwnProperty ( p ) ) d [ p ] = b [ p ] ; } ;
return extendStatics ( d , b ) ;
} ;
return function ( d , b ) {
extendStatics ( d , b ) ;
function _ _ ( ) { this . constructor = d ; }
d . prototype = b === null ? Object . create ( b ) : ( _ _ . prototype = b . prototype , new _ _ ( ) ) ;
} ;
} ) ( ) ;
var _ _assign = ( this && this . _ _assign ) || function ( ) {
_ _assign = Object . assign || function ( t ) {
for ( var s , i = 1 , n = arguments . length ; i < n ; i ++ ) {
s = arguments [ i ] ;
for ( var p in s ) if ( Object . prototype . hasOwnProperty . call ( s , p ) )
t [ p ] = s [ p ] ;
}
return t ;
} ;
return _ _assign . apply ( this , arguments ) ;
2022-10-11 16:10:23 +02:00
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
2024-05-19 08:24:38 +02:00
function step ( result ) { result . done ? resolve ( result . value ) : new P ( function ( resolve ) { resolve ( result . value ) ; } ) . then ( fulfilled , rejected ) ; }
2022-10-11 16:10:23 +02:00
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
2024-05-19 08:24:38 +02:00
var _ _generator = ( this && this . _ _generator ) || function ( thisArg , body ) {
var _ = { label : 0 , sent : function ( ) { if ( t [ 0 ] & 1 ) throw t [ 1 ] ; return t [ 1 ] ; } , trys : [ ] , ops : [ ] } , f , y , t , g ;
return g = { next : verb ( 0 ) , "throw" : verb ( 1 ) , "return" : verb ( 2 ) } , typeof Symbol === "function" && ( g [ Symbol . iterator ] = function ( ) { return this ; } ) , g ;
function verb ( n ) { return function ( v ) { return step ( [ n , v ] ) ; } ; }
function step ( op ) {
if ( f ) throw new TypeError ( "Generator is already executing." ) ;
while ( _ ) try {
if ( f = 1 , y && ( t = op [ 0 ] & 2 ? y [ "return" ] : op [ 0 ] ? y [ "throw" ] || ( ( t = y [ "return" ] ) && t . call ( y ) , 0 ) : y . next ) && ! ( t = t . call ( y , op [ 1 ] ) ) . done ) return t ;
if ( y = 0 , t ) op = [ op [ 0 ] & 2 , t . value ] ;
switch ( op [ 0 ] ) {
case 0 : case 1 : t = op ; break ;
case 4 : _ . label ++ ; return { value : op [ 1 ] , done : false } ;
case 5 : _ . label ++ ; y = op [ 1 ] ; op = [ 0 ] ; continue ;
case 7 : op = _ . ops . pop ( ) ; _ . trys . pop ( ) ; continue ;
default :
if ( ! ( t = _ . trys , t = t . length > 0 && t [ t . length - 1 ] ) && ( op [ 0 ] === 6 || op [ 0 ] === 2 ) ) { _ = 0 ; continue ; }
if ( op [ 0 ] === 3 && ( ! t || ( op [ 1 ] > t [ 0 ] && op [ 1 ] < t [ 3 ] ) ) ) { _ . label = op [ 1 ] ; break ; }
if ( op [ 0 ] === 6 && _ . label < t [ 1 ] ) { _ . label = t [ 1 ] ; t = op ; break ; }
if ( t && _ . label < t [ 2 ] ) { _ . label = t [ 2 ] ; _ . ops . push ( op ) ; break ; }
if ( t [ 2 ] ) _ . ops . pop ( ) ;
_ . trys . pop ( ) ; continue ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
op = body . call ( thisArg , _ ) ;
} catch ( e ) { op = [ 6 , e ] ; y = 0 ; } finally { f = t = 0 ; }
if ( op [ 0 ] & 5 ) throw op [ 1 ] ; return { value : op [ 0 ] ? op [ 1 ] : void 0 , done : true } ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
} ;
var _ _read = ( this && this . _ _read ) || function ( o , n ) {
var m = typeof Symbol === "function" && o [ Symbol . iterator ] ;
if ( ! m ) return o ;
var i = m . call ( o ) , r , ar = [ ] , e ;
try {
while ( ( n === void 0 || n -- > 0 ) && ! ( r = i . next ( ) ) . done ) ar . push ( r . value ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
catch ( error ) { e = { error : error } ; }
finally {
try {
if ( r && ! r . done && ( m = i [ "return" ] ) ) m . call ( i ) ;
}
finally { if ( e ) throw e . error ; }
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
return ar ;
} ;
var _ _values = ( this && this . _ _values ) || function ( o ) {
var m = typeof Symbol === "function" && o [ Symbol . iterator ] , i = 0 ;
if ( m ) return m . call ( o ) ;
return {
next : function ( ) {
if ( o && i >= o . length ) o = void 0 ;
return { value : o && o [ i ++ ] , done : ! o } ;
}
} ;
} ;
var _ _spread = ( this && this . _ _spread ) || function ( ) {
for ( var ar = [ ] , i = 0 ; i < arguments . length ; i ++ ) ar = ar . concat ( _ _read ( arguments [ i ] ) ) ;
return ar ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
var child _process = _ _nccwpck _require _ _ ( 2081 ) ;
var readline = _ _nccwpck _require _ _ ( 4521 ) ;
var fs = _ _nccwpck _require _ _ ( 7147 ) ;
var path = _ _nccwpck _require _ _ ( 1017 ) ;
var https = _ _nccwpck _require _ _ ( 5687 ) ;
var http = _ _nccwpck _require _ _ ( 3685 ) ;
var util = _ _nccwpck _require _ _ ( 3837 ) ;
var os = _ _nccwpck _require _ _ ( 2037 ) ;
var crypto = _ _nccwpck _require _ _ ( 6113 ) ;
/ * *
* After this function is called every call to execSync
* or exec will print the unix commands being executed .
* * /
function enableCmdTrace ( ) {
traceCmdIfEnabled . enabled = true ;
}
exports . enableCmdTrace = enableCmdTrace ;
function traceCmdIfEnabled ( cmd , options ) {
if ( ! traceCmdIfEnabled . enabled ) {
return ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
console . log ( colorize ( "$ " + cmd + " " , "YELLOW" ) + ( ! ! options ? JSON . stringify ( options ) + "\n" : "" ) ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
( function ( traceCmdIfEnabled ) {
traceCmdIfEnabled . enabled = false ;
} ) ( traceCmdIfEnabled || ( traceCmdIfEnabled = { } ) ) ;
function get _uid ( unix _user ) {
return parseInt ( sh _eval ( "id -u " + unix _user ) ) ;
}
exports . get _uid = get _uid ;
function get _gid ( unix _user ) {
return parseInt ( sh _eval ( "id -g " + unix _user ) ) ;
}
exports . get _gid = get _gid ;
function colorize ( str , color ) {
var color _code = ( function ( ) {
switch ( color ) {
case "GREEN" : return "\x1b[32m" ;
case "RED" : return "\x1b[31m" ;
case "YELLOW" : return "\x1b[33m" ;
}
} ) ( ) ;
return "" + color _code + str + "\u001B[0m" ;
}
exports . colorize = colorize ;
/ * *
*
* The stderr is forwarded to the console realtime .
*
* The returned value is the concatenated data received on stdout .
*
* If the return code of the cmd is not 0 an exception is thrown
* and the message cmd + the concatenated data received on stderr .
*
* If enableTrace ( ) have been called the command called will be printed .
*
* /
function execSync ( cmd , options ) {
traceCmdIfEnabled ( cmd , options ) ;
return child _process . execSync ( cmd , _ _assign ( { } , ( options || { } ) , { "encoding" : "utf8" } ) ) ;
}
exports . execSync = execSync ;
/ * *
*
* The cmd is printed before execution
* stdout and stderr are forwarded to the console realtime .
* Return nothing .
*
* stdio is set to "inherit" and thus should not be redefined .
*
* /
function execSyncTrace ( cmd , options ) {
traceCmdIfEnabled ( cmd , options ) ;
child _process . execSync ( cmd , _ _assign ( { } , ( options || { } ) , { "stdio" : "inherit" } ) ) ;
}
exports . execSyncTrace = execSyncTrace ;
/** Same as execSync except that it dose not print cmd even if cmdTrace have been enabled */
var execSyncNoCmdTrace = function ( ) {
var args = [ ] ;
for ( var _i = 0 ; _i < arguments . length ; _i ++ ) {
args [ _i ] = arguments [ _i ] ;
}
var enabled _back = traceCmdIfEnabled . enabled ;
traceCmdIfEnabled . enabled = false ;
2022-10-11 16:10:23 +02:00
try {
2022-10-12 17:48:05 +02:00
var out = execSync . apply ( null , args ) ;
traceCmdIfEnabled . enabled = enabled _back ;
return out ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
catch ( error ) {
traceCmdIfEnabled . enabled = enabled _back ;
throw error ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
} ;
/ * *
*
* Like execSync but stderr is not forwarded .
* WARNING : If mean that when the cmd return 0
* all data that may have been wrote on stderr
* are lost into oblivion .
*
* stdio is set to "pipe" and thus should not be redefined .
*
* /
function execSyncQuiet ( cmd , options ) {
return execSync ( cmd , _ _assign ( { } , ( options || { } ) , { "stdio" : "pipe" } ) ) ;
}
exports . execSyncQuiet = execSyncQuiet ;
/** Same as execSync but async */
function exec ( cmd , options ) {
var _this = this ;
traceCmdIfEnabled ( cmd , options ) ;
return new Promise ( function ( resolve , reject ) { return _ _awaiter ( _this , void 0 , void 0 , function ( ) {
return _ _generator ( this , function ( _a ) {
child _process . exec ( cmd , _ _assign ( { } , ( options || { } ) , { "encoding" : "utf8" } ) , function ( error , stdout , stderr ) {
if ( ! ! error ) {
error [ "stderr" ] = stderr ;
reject ( error ) ;
}
else {
resolve ( stdout ) ;
}
} ) ;
return [ 2 /*return*/ ] ;
} ) ;
} ) ; } ) ;
}
exports . exec = exec ;
/ * *
* Spawn a process that continue running after current process exit .
* This process will be ignored by stopSubProcessesAsapSync .
* If a logfile _path if provided stdout and stderr will be redirected to this file .
*
* detached , and stdio options should not be set as they are set internally .
* * /
function spawnAndDetach ( command , args , options , logfile _path ) {
var out = ! ! logfile _path ? fs . openSync ( logfile _path , "a" ) : "ignore" ;
var subprocess = child _process . spawn ( command , args , _ _assign ( { } , ( options || { } ) , { "detached" : true , "stdio" : [ "ignore" , out , out ] } ) ) ;
stopProcessSync . stopSubProcessesAsapSync . ignorePids . add ( subprocess . pid ) ;
subprocess . unref ( ) ;
return subprocess ;
}
exports . spawnAndDetach = spawnAndDetach ;
/ * *
*
* Print a message and enable a moving loading bar .
* WARNING : Nothing should be printed to stdout until we stop showing the moving loading .
*
* returns :
* - exec : A proxy to the exec fnc that will call onError before it throw the error .
* - onSuccess : Stop showing the moving loading and pretty print a success message ( "ok" by default )
* - onError : Stop showing the moving loading and pretty print error message .
*
* /
function start _long _running _process ( message ) {
process . stdout . write ( message + "... " ) ;
var moveBack = ( function ( ) {
var cp = message . length + 3 ;
return function ( ) { return readline . cursorTo ( process . stdout , cp ) ; } ;
} ) ( ) ;
var p = [ "\\" , "|" , "/" , "-" ] . map ( function ( i ) { return colorize ( i , "GREEN" ) ; } ) ;
var x = 0 ;
var timer = setInterval ( function ( ) {
moveBack ( ) ;
process . stdout . write ( p [ x ++ ] ) ;
x = x % p . length ;
} , 250 ) ;
var onComplete = function ( message ) {
clearInterval ( timer ) ;
moveBack ( ) ;
process . stdout . write ( message + "\n" ) ;
} ;
var onError = function ( errorMessage ) { return onComplete ( colorize ( errorMessage , "RED" ) ) ; } ;
var onSuccess = function ( message ) { return onComplete ( colorize ( message || "ok" , "GREEN" ) ) ; } ;
if ( traceCmdIfEnabled . enabled ) {
onComplete ( "" ) ;
onComplete = function ( message ) { return console . log ( message ) ; } ;
}
return {
onError : onError ,
onSuccess : onSuccess ,
"exec" : function ( ) {
var args = [ ] ;
for ( var _i = 0 ; _i < arguments . length ; _i ++ ) {
args [ _i ] = arguments [ _i ] ;
}
return _ _awaiter ( this , void 0 , void 0 , function ( ) {
var error _1 ;
return _ _generator ( this , function ( _a ) {
switch ( _a . label ) {
case 0 :
_a . trys . push ( [ 0 , 2 , , 3 ] ) ;
return [ 4 /*yield*/ , exec . apply ( null , args ) ] ;
case 1 : return [ 2 /*return*/ , _a . sent ( ) ] ;
case 2 :
error _1 = _a . sent ( ) ;
onError ( error _1 . message ) ;
throw error _1 ;
case 3 : return [ 2 /*return*/ ] ;
}
} ) ;
} ) ;
}
} ;
}
exports . start _long _running _process = start _long _running _process ;
;
/ * *
* Apt package if not already installed ,
* if prog is provided and prog is in the PATH the package will not be installed
* * /
function apt _get _install _if _missing ( package _name , prog ) {
return _ _awaiter ( this , void 0 , void 0 , function ( ) {
return _ _generator ( this , function ( _a ) {
switch ( _a . label ) {
case 0 :
process . stdout . write ( "Looking for " + package _name + " ... " ) ;
if ( ! ! prog && apt _get _install _if _missing . doesHaveProg ( prog ) ) {
console . log ( prog + " executable found. " + colorize ( "OK" , "GREEN" ) ) ;
return [ 2 /*return*/ ] ;
}
if ( apt _get _install _if _missing . isPkgInstalled ( package _name ) ) {
console . log ( package _name + " is installed. " + colorize ( "OK" , "GREEN" ) ) ;
return [ 2 /*return*/ ] ;
}
readline . clearLine ( process . stdout , 0 ) ;
process . stdout . write ( "\r" ) ;
return [ 4 /*yield*/ , apt _get _install ( package _name ) ] ;
case 1 : return [ 2 /*return*/ , _a . sent ( ) ] ;
}
} ) ;
} ) ;
}
exports . apt _get _install _if _missing = apt _get _install _if _missing ;
( function ( apt _get _install _if _missing ) {
function isPkgInstalled ( package _name ) {
try {
console . assert ( ! ! execSyncNoCmdTrace ( "dpkg-query -W -f='${Status}' " + package _name , { "stdio" : "pipe" } )
. match ( /^install ok installed$/ ) ) ;
}
catch ( _a ) {
return false ;
}
return true ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
apt _get _install _if _missing . isPkgInstalled = isPkgInstalled ;
function doesHaveProg ( prog ) {
try {
execSyncNoCmdTrace ( "which " + prog ) ;
}
catch ( _a ) {
return false ;
}
return true ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
apt _get _install _if _missing . doesHaveProg = doesHaveProg ;
} ) ( apt _get _install _if _missing = exports . apt _get _install _if _missing || ( exports . apt _get _install _if _missing = { } ) ) ;
/** Install or upgrade package via APT */
function apt _get _install ( package _name ) {
return _ _awaiter ( this , void 0 , void 0 , function ( ) {
var _a , onSuccess , exec , was _installed _before , error _2 ;
return _ _generator ( this , function ( _b ) {
switch ( _b . label ) {
case 0 :
_a = start _long _running _process ( "Installing or upgrading " + package _name + " package" ) , onSuccess = _a . onSuccess , exec = _a . exec ;
_b . label = 1 ;
case 1 :
_b . trys . push ( [ 1 , 5 , , 6 ] ) ;
if ( ! apt _get _install . isFirst ) return [ 3 /*break*/ , 3 ] ;
return [ 4 /*yield*/ , exec ( "apt-get update || true" ) ] ;
case 2 :
_b . sent ( ) ;
apt _get _install . isFirst = false ;
_b . label = 3 ;
case 3 :
was _installed _before = apt _get _install _if _missing . isPkgInstalled ( package _name ) ;
return [ 4 /*yield*/ , exec ( "apt-get -y install " + package _name ) ] ;
case 4 :
_b . sent ( ) ;
if ( ! was _installed _before ) {
apt _get _install . onInstallSuccess ( package _name ) ;
}
return [ 3 /*break*/ , 6 ] ;
case 5 :
error _2 = _b . sent ( ) ;
apt _get _install . onError ( error _2 ) ;
return [ 3 /*break*/ , 6 ] ;
case 6 :
onSuccess ( "DONE" ) ;
return [ 2 /*return*/ ] ;
}
} ) ;
} ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
exports . apt _get _install = apt _get _install ;
( function ( apt _get _install ) {
apt _get _install . isFirst = true ;
function record _installed _package ( file _json _path , package _name ) {
execSyncNoCmdTrace ( "touch " + file _json _path ) ;
var raw = fs . readFileSync ( file _json _path ) . toString ( "utf8" ) ;
var list = raw === "" ? [ ] : JSON . parse ( raw ) ;
if ( ! list . find ( function ( p ) { return p === package _name ; } ) ) {
list . push ( package _name ) ;
fs . writeFileSync ( file _json _path , Buffer . from ( JSON . stringify ( list , null , 2 ) , "utf8" ) ) ;
}
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
apt _get _install . record _installed _package = record _installed _package ;
apt _get _install . onError = function ( error ) { throw error ; } ;
apt _get _install . onInstallSuccess = function ( package _name ) { } ;
} ) ( apt _get _install = exports . apt _get _install || ( exports . apt _get _install = { } ) ) ;
function exit _if _not _root ( ) {
if ( process . getuid ( ) !== 0 ) {
console . log ( colorize ( "Error: root privilege required " , "RED" ) ) ;
process . exit ( 1 ) ;
2022-10-11 16:10:23 +02:00
}
}
2022-10-12 17:48:05 +02:00
exports . exit _if _not _root = exit _if _not _root ;
/ * *
*
* Locate a given module in a node _modules directory .
* If the module is required in different version and thus
* present multiple times will be returned the shorter path .
* This ensure that if a given module is in package . json ' s dependencies
* section the returned path will be the one we looking for .
*
* @ param module _name The name of the module .
* @ param module _dir _path Path to the root of the module ( will search in . / node _modules ) .
*
* Throw if the module is not found .
*
* /
function find _module _path ( module _name , module _dir _path ) {
if ( path . basename ( module _dir _path ) === module _name ) {
return module _dir _path ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
var node _module _path = path . join ( module _dir _path , "node_modules" ) ;
if ( ! fs . existsSync ( node _module _path ) ) {
throw new Error ( "No node_modules in " + module _dir _path ) ;
}
var _a = _ _read ( fs . readdirSync ( node _module _path )
. map ( function ( file _name ) { return path . join ( node _module _path , file _name ) ; } )
. filter ( function ( file _or _dir _path ) { return fs . existsSync ( path . join ( file _or _dir _path , "package.json" ) ) ; } )
. map ( function ( module _dir _path ) {
try {
return find _module _path ( module _name , module _dir _path ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
catch ( _a ) {
return "" ;
}
} )
. filter ( function ( module _dir _path ) { return ! ! module _dir _path ; } )
. sort ( function ( a , b ) { return a . length - b . length ; } ) , 1 ) , out = _a [ 0 ] ;
if ( out === undefined ) {
throw new Error ( "module " + module _name + " not installed in " + module _dir _path ) ;
}
return out ;
}
exports . find _module _path = find _module _path ;
/ * *
*
* Test if two file of folder are same .
* Does not consider stat ( ownership and permission ) .
* transparent handling of symlinks .
*
* Example
*
* / f o o 1 / b a r / f i l e . t x t
* / f o o 2 / b a r / f i l e . t x t
*
* to compare the two version of file . txt
* call with "/foo1" , "/foo2" , "./bar/file.txt" ;
* or with "/foo1/bar/file.txt" , "/foo2/bar/file.txt"
*
* @ param relative _from _path1 absolute path ex : '/foo1'
* @ param relative _from _path2 absolute path ex : '/foo2'
* @ param relative _to _path relative path ex : './bar/file.txt" or ' bar / file . txt '
* for convenience relative _to _path can be absolute as long as it has relative _from _path1
* or relative _from _path2 as parent .
*
* /
function fs _areSame ( relative _from _path1 , relative _from _path2 , relative _to _path ) {
if ( relative _to _path === void 0 ) { relative _to _path = "." ; }
relative _to _path = fs _areSame . get _relative _to _path ( relative _from _path1 , relative _from _path2 , relative _to _path ) ;
try {
execSyncNoCmdTrace ( [
"diff -r" ,
path . join ( relative _from _path1 , relative _to _path ) ,
path . join ( relative _from _path2 , relative _to _path )
] . join ( " " ) , { "stdio" : "pipe" } ) ;
}
catch ( _a ) {
return false ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
return true ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
exports . fs _areSame = fs _areSame ;
( function ( fs _areSame ) {
function get _relative _to _path ( dir _path1 , dir _path2 , to _path ) {
if ( path . isAbsolute ( to _path ) ) {
var dir _path = [ dir _path1 , dir _path2 ]
. filter ( function ( v ) { return to _path . startsWith ( v ) ; } )
. sort ( function ( a , b ) { return b . length - a . length ; } ) [ 0 ] ;
if ( ! dir _path ) {
throw new Error ( "Not relative!" ) ;
}
return path . relative ( dir _path , to _path ) ;
}
else {
return to _path ;
}
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
fs _areSame . get _relative _to _path = get _relative _to _path ;
} ) ( fs _areSame = exports . fs _areSame || ( exports . fs _areSame = { } ) ) ;
/ * *
*
* Move or copy file of folder .
* - If dest is identical to source nothing is copied nor moved .
* - If dest exist and is different of source it will be deleted prior to proceeding with action .
* - In move mode if dest identical to source source will be removed .
* - When copy is effectively performed the stat are conserved .
* - If dirname of dest does not exist in fs , it will be created .
* - Unlike cp or mv "/src/file.txt" "/dest" will NOT place file . txt in dest but dest will become file . txt
*
* calling [ action ] "/src/foo" "/dst/foo" is equivalent
* to calling [ action ] "/src" "/dst" "./foo" ( or "foo" )
* or [ action ] "/src" "/dst" "src/foo"
* or [ action ] "/src" "/dst" "dst/foo"
*
* /
function fs _move ( action , relative _from _path _src , relative _from _path _dest , relative _to _path ) {
if ( relative _to _path === void 0 ) { relative _to _path = "." ; }
relative _to _path = fs _areSame . get _relative _to _path ( relative _from _path _src , relative _from _path _dest , relative _to _path ) ;
var src _path = path . join ( relative _from _path _src , relative _to _path ) ;
var dst _path = path . join ( relative _from _path _dest , relative _to _path ) ;
if ( ! fs _areSame ( src _path , dst _path ) ) {
if ( ! fs . existsSync ( dst _path ) ) {
execSyncNoCmdTrace ( "mkdir -p " + dst _path ) ;
}
execSyncNoCmdTrace ( "rm -rf " + dst _path ) ;
execSyncNoCmdTrace ( [
action === "COPY" ? "cp -rp" : "mv" ,
src _path ,
dst _path
] . join ( " " ) ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
else {
if ( action === "MOVE" ) {
execSyncNoCmdTrace ( "rm -r " + src _path ) ;
2022-10-11 16:10:23 +02:00
}
}
2022-10-12 17:48:05 +02:00
}
exports . fs _move = fs _move ;
/ * *
* Download and extract a tarball . throws web _get . DownloadError and Error
*
* Example
*
* website . com / rel . tar . gz
* . / file1 . txt
* . / dir / file2 . txt
*
* /foo/
* . / file3 . txt
* . / dir / file4 . txt
*
* calling with "website.com/rel.tar.gz" , "MERGE" will result in :
*
* /foo/
* . / file1 . txt
* . / file3 . txt
* . / dir / file4 . txt
*
* calling with "website.com/rel.tar.gz" , "OVERWRITE IF EXIST" will result in :
*
* /foo/
* . / file1 . txt
* . / dir / file2 . txt
*
* /
function download _and _extract _tarball ( url , dest _dir _path , mode ) {
return _ _awaiter ( this , void 0 , void 0 , function ( ) {
var _a , exec , onSuccess , onError , tarball _dir _path , tarball _path , error _3 , _b , _c , name ;
var e _1 , _d ;
return _ _generator ( this , function ( _e ) {
switch ( _e . label ) {
case 0 :
_a = start _long _running _process ( "Downloading " + url + " and extracting to " + dest _dir _path ) , exec = _a . exec , onSuccess = _a . onSuccess , onError = _a . onError ;
tarball _dir _path = ( function ( ) {
var hash = crypto . createHash ( "sha1" ) ;
hash . write ( url ) ;
hash . end ( ) ;
return "/tmp/_" + hash . read ( ) . toString ( "hex" ) ;
} ) ( ) ;
tarball _path = tarball _dir _path + ".tar.gz" ;
if ( ! ( fs . existsSync ( tarball _dir _path ) || fs . existsSync ( tarball _path ) ) ) return [ 3 /*break*/ , 2 ] ;
return [ 4 /*yield*/ , exec ( "rm -rf " + tarball _dir _path + " " + tarball _path ) ] ;
case 1 :
_e . sent ( ) ;
_e . label = 2 ;
case 2 :
_e . trys . push ( [ 2 , 4 , , 5 ] ) ;
return [ 4 /*yield*/ , web _get ( url , tarball _path ) ] ;
case 3 :
_e . sent ( ) ;
return [ 3 /*break*/ , 5 ] ;
case 4 :
error _3 = _e . sent ( ) ;
onError ( error _3 . message ) ;
throw error _3 ;
case 5 : return [ 4 /*yield*/ , exec ( "mkdir " + tarball _dir _path ) ] ;
case 6 :
_e . sent ( ) ;
return [ 4 /*yield*/ , exec ( "tar -xzf " + tarball _path + " -C " + tarball _dir _path ) ] ;
case 7 :
_e . sent ( ) ;
return [ 4 /*yield*/ , exec ( "rm " + tarball _path ) ] ;
case 8 :
_e . sent ( ) ;
if ( ! ( mode === "MERGE" ) ) return [ 3 /*break*/ , 10 ] ;
try {
for ( _b = _ _values ( fs _ls ( tarball _dir _path ) ) , _c = _b . next ( ) ; ! _c . done ; _c = _b . next ( ) ) {
name = _c . value ;
fs _move ( "MOVE" , tarball _dir _path , dest _dir _path , name ) ;
}
}
catch ( e _1 _1 ) { e _1 = { error : e _1 _1 } ; }
finally {
try {
if ( _c && ! _c . done && ( _d = _b . return ) ) _d . call ( _b ) ;
}
finally { if ( e _1 ) throw e _1 . error ; }
}
return [ 4 /*yield*/ , exec ( "rm -r " + tarball _dir _path ) ] ;
case 9 :
_e . sent ( ) ;
return [ 3 /*break*/ , 11 ] ;
case 10 :
fs _move ( "MOVE" , tarball _dir _path , dest _dir _path ) ;
_e . label = 11 ;
case 11 :
onSuccess ( ) ;
return [ 2 /*return*/ ] ;
}
} ) ;
} ) ;
}
exports . download _and _extract _tarball = download _and _extract _tarball ;
function web _get ( url , file _path ) {
if ( ! url . startsWith ( "http" ) ) {
url = "http://" + url ;
}
return new Promise ( function ( resolve , reject ) {
var get = url . startsWith ( "https" ) ?
https . get . bind ( https ) : http . get . bind ( http ) ;
var timer = setTimeout ( function ( ) {
clientRequest . abort ( ) ;
reject ( new web _get . DownloadError ( url , "CONNECTION ERROR" , "web_get connection error: timeout" ) ) ;
} , 20000 ) ;
var clientRequest = get ( url , function ( res ) {
clearTimeout ( timer ) ;
if ( ( "" + res . statusCode ) . startsWith ( "30" ) ) {
var url _redirect = res . headers . location ;
if ( ! ! url _redirect ) {
web _get ( url _redirect , file _path )
. then ( function ( out ) { return resolve ( out ) ; } )
. catch ( function ( error ) { return reject ( error ) ; } ) ;
return ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
}
if ( ! ( "" + res . statusCode ) . startsWith ( "2" ) ) {
reject ( new web _get . DownloadErrorHttpErrorCode ( url , res . statusCode ) ) ;
return ;
}
var contentLength = undefined ;
var receivedBytes = 0 ;
if ( res . headers [ "content-length" ] !== undefined ) {
contentLength = parseInt ( res . headers [ "content-length" ] ) ;
res . on ( "data" , function ( chunk ) { return receivedBytes += chunk . length ; } ) ;
( function ( ) {
var resolve _src = resolve ;
resolve = function ( ) {
var args = [ ] ;
for ( var _i = 0 ; _i < arguments . length ; _i ++ ) {
args [ _i ] = arguments [ _i ] ;
}
if ( receivedBytes !== contentLength ) {
reject ( new web _get . DownloadErrorIncomplete ( url , contentLength , receivedBytes ) ) ;
return ;
}
resolve _src . apply ( null , args ) ;
} ;
} ) ( ) ;
}
res . socket . setTimeout ( 60000 , function ( ) { return res . socket . destroy ( new web _get . DownloadErrorIncomplete ( url , contentLength , receivedBytes , "socket timeout" ) ) ; } ) ;
if ( ! ! file _path ) {
( function ( ) {
var reject _src = reject ;
reject = function ( ) {
var args = [ ] ;
for ( var _i = 0 ; _i < arguments . length ; _i ++ ) {
args [ _i ] = arguments [ _i ] ;
}
return fs . unlink ( file _path , function ( ) { return reject _src . apply ( null , args ) ; } ) ;
} ;
} ) ( ) ;
fs . writeFileSync ( file _path , new Buffer ( 0 ) ) ;
var fsWriteStream = fs . createWriteStream ( file _path ) ;
res . pipe ( fsWriteStream ) ;
fsWriteStream . once ( "finish" , function ( ) { return resolve ( ) ; } ) ;
res . once ( "error" , function ( error ) { return reject ( new web _get . DownloadErrorIncomplete ( url , contentLength , receivedBytes , error . message ) ) ; } ) ;
fsWriteStream . once ( "error" , function ( error ) { return reject ( new web _get . DownloadErrorIncomplete ( url , contentLength , receivedBytes , error . message ) ) ; } ) ;
}
else {
var data _1 = new Buffer ( 0 ) ;
res . on ( "data" , function ( chunk ) { return data _1 = Buffer . concat ( [ data _1 , chunk ] ) ; } ) ;
res . once ( "end" , function ( ) { return resolve ( data _1 . toString ( "utf8" ) ) ; } ) ;
}
} ) ;
clientRequest . once ( "error" , function ( error ) {
clearTimeout ( timer ) ;
reject ( new web _get . DownloadError ( url , "CONNECTION ERROR" , error . message ) ) ;
} ) ;
} ) ;
}
exports . web _get = web _get ;
( function ( web _get ) {
var DownloadError = /** @class */ ( function ( _super ) {
_ _extends ( DownloadError , _super ) ;
function DownloadError ( url , cause , message ) {
var _newTarget = this . constructor ;
var _this = _super . call ( this , message ) || this ;
_this . url = url ;
_this . cause = cause ;
Object . setPrototypeOf ( _this , _newTarget . prototype ) ;
return _this ;
}
return DownloadError ;
} ( Error ) ) ;
web _get . DownloadError = DownloadError ;
var DownloadErrorIncomplete = /** @class */ ( function ( _super ) {
_ _extends ( DownloadErrorIncomplete , _super ) ;
function DownloadErrorIncomplete ( url , contentLength , receivedBytes , info ) {
var _newTarget = this . constructor ;
var _this = _super . call ( this , url , "INCOMPLETE" , "web_get failed, download incomplete " + receivedBytes + "/" + contentLength + ", " + ( ! ! info ? info : "" ) ) || this ;
_this . contentLength = contentLength ;
_this . receivedBytes = receivedBytes ;
Object . setPrototypeOf ( _this , _newTarget . prototype ) ;
return _this ;
}
return DownloadErrorIncomplete ;
} ( DownloadError ) ) ;
web _get . DownloadErrorIncomplete = DownloadErrorIncomplete ;
var DownloadErrorHttpErrorCode = /** @class */ ( function ( _super ) {
_ _extends ( DownloadErrorHttpErrorCode , _super ) ;
function DownloadErrorHttpErrorCode ( url , code ) {
var _newTarget = this . constructor ;
var _this = _super . call ( this , url , "HTTP ERROR CODE" , "web_get failed, HTTP error code: " + code ) || this ;
_this . code = code ;
Object . setPrototypeOf ( _this , _newTarget . prototype ) ;
return _this ;
}
return DownloadErrorHttpErrorCode ;
} ( DownloadError ) ) ;
web _get . DownloadErrorHttpErrorCode = DownloadErrorHttpErrorCode ;
} ) ( web _get = exports . web _get || ( exports . web _get = { } ) ) ;
function fs _ls ( dir _path , mode , showHidden ) {
if ( mode === void 0 ) { mode = "FILENAME" ; }
if ( showHidden === void 0 ) { showHidden = false ; }
return execSyncNoCmdTrace ( "ls" + ( showHidden ? " -a" : "" ) , { "cwd" : dir _path } )
. slice ( 0 , - 1 )
. split ( "\n" )
. map ( function ( name ) { return mode === "ABSOLUTE PATH" ? path . join ( dir _path , name ) : name ; } ) ;
}
exports . fs _ls = fs _ls ;
/ * *
*
* Create a symbolic link .
* If dst exist it is removed .
* directories leading to dest are created if necessary .
*
* /
function createSymlink ( src _path , dst _path ) {
if ( ! fs . existsSync ( dst _path ) ) {
execSyncNoCmdTrace ( "mkdir -p " + dst _path ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
execSyncNoCmdTrace ( "rm -rf " + dst _path ) ;
execSync ( "ln -s " + src _path + " " + dst _path ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
exports . createSymlink = createSymlink ;
/** Create a executable file */
function createScript ( file _path , content ) {
if ( traceCmdIfEnabled . enabled ) {
console . log ( "Creating script " + file _path ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
fs . writeFileSync ( file _path , Buffer . from ( content , "utf8" ) ) ;
execSyncNoCmdTrace ( "chmod +x " + file _path ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
exports . createScript = createScript ;
var unixUser ;
( function ( unixUser ) {
function create ( unix _user , home _dir _path ) {
if ( home _dir _path === void 0 ) { home _dir _path = "/tmp" ; }
execSyncNoCmdTrace ( "useradd -M " + unix _user + " -s /bin/false -d " + home _dir _path ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
unixUser . create = create ;
function remove ( unix _user ) {
execSyncNoCmdTrace ( "userdel " + unix _user , { "stdio" : "pipe" } ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
unixUser . remove = remove ;
} ) ( unixUser = exports . unixUser || ( exports . unixUser = { } ) ) ;
2024-05-19 08:24:38 +02:00
var get _caller _file _path _1 = _ _nccwpck _require _ _ ( 6303 ) ;
2022-10-12 17:48:05 +02:00
exports . get _caller _file _path = get _caller _file _path _1 . get _caller _file _path ;
2024-05-19 08:24:38 +02:00
var get _caller _file _path _2 = _ _nccwpck _require _ _ ( 6303 ) ;
2022-10-12 17:48:05 +02:00
/ * *
*
* DO NOT USE TEST PURPOSE ONLY
*
* return _ _filename
*
* /
function get _ _filename ( ) {
return get _caller _file _path _2 . get _caller _file _path ( ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
exports . get _ _filename = get _ _filename ;
/ * *
*
* Equivalent to the pattern $ ( ) in bash .
* Strip final LF if present .
* If cmd fail no error is thrown , an empty string is returned .
* Does not print to stdout .
*
* Typical usage : uname - r or which pkill
*
* /
function sh _eval ( cmd ) {
var res ;
try {
res = execSyncNoCmdTrace ( cmd , { "stdio" : "pipe" } ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
catch ( _a ) {
return "" ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
return res . replace ( /\n$/ , "" ) ;
}
exports . sh _eval = sh _eval ;
/ * *
* Run a command and return true if the return code was 0.
* Does not print to stdout .
* /
function sh _if ( cmd ) {
try {
execSyncNoCmdTrace ( cmd , { "stdio" : "pipe" } ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
catch ( _a ) {
return false ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
return true ;
}
exports . sh _if = sh _if ;
/ * *
* Return a promise that resolve as the source promise when fulfilled
* or resolve with the error when reject .
* If a timeout is specified the returned promise resolve with an error after [ timeout ] ms
* if the source promise did not completed before .
* The message of the timeout error is safePr . timeoutErrorMessage
* /
function safePr ( pr , timeout ) {
var prSafe = pr . then ( function ( val ) { return val ; } , function ( error ) { return error ; } ) ;
if ( timeout !== undefined ) {
var timer _1 ;
return Promise . race ( [
new Promise ( function ( resolve ) { return timer _1 = setTimeout ( function ( ) { return resolve ( new Error ( safePr . timeoutErrorMessage ) ) ; } , timeout ) ; } ) ,
prSafe . then ( function ( val ) {
clearTimeout ( timer _1 ) ;
return val ;
} )
] ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
else {
return prSafe ;
}
}
exports . safePr = safePr ;
;
( function ( safePr ) {
safePr . timeoutErrorMessage = "safePr timeout" ;
} ) ( safePr = exports . safePr || ( exports . safePr = { } ) ) ;
/ * *
*
* Allow to schedule action function to perform before exiting .
*
* The task function will always be called before the process stop
* unless process . exit is explicitly called somewhere or
* if the process receive any signal other than the ones specified
* in the ExitCause . Signal [ "signal" ] type .
*
* The process may stop for tree reasons :
* 1 ) If there is no more work scheduled ( natural termination ) .
* 2 ) If an uncaught exception it thrown ( or a unhandled promise rejection )
* 3 ) If a signal ( one of the handled ) is sent to the process .
*
* To manually exit the process there is two option :
* - Call process . exit ( X ) but the task function will not be called .
* - Emit "beforeExit" on process object ( process . emit ( " beforeExit , process . exitCode = X ) ) ;
* Doing so you simulate 1 st stop condition ( natural termination ) .
*
* To define the return code set process . exitCode . The exit code can be set
* before emitting "beforeExit" or in the task function .
* If exitCode has not be defined the process will exit with 0 if
* there was nothing else to do and 1 otherwise .
*
* The task function can be synchronous or asynchronous .
* The task function has [ timeout ] ms to complete .
* If it has not completed within this delay the process will
* be terminated anyway . ( Default 4000 ms )
* Setting [ timeout ] to a negative value will disable the timer .
* WARNING : It is important not to perform sync operation that can
* hang for a long time in the task function ( e . g . execSync ( "sleep 1000" ) ; )
* because while the sync operation are performed the timeout can ' t be triggered .
*
* As soon as the task function is called all the other exitCause that
* may auccur will be ignored so that the task function have time to complete .
* Anyway the task function is called only once .
*
* Whether the task function complete by successfully or throw
* an exception the process will terminate with exit code set
* in process . exitCode at the time of the completion .
*
* Provide shouldExitIf function to filter what should be
* considered a case to terminate the process .
* Only exception and supported signals can be bypassed ,
* Nothing else to do will always terminate the process .
* By default exiting on any signal or uncaught errors .
*
* Before exiting all subprocess will be killed .
*
*
* /
function setProcessExitHandler ( task , timeout , shouldExitIf ) {
var e _2 , _a , e _3 , _b ;
var _this = this ;
if ( timeout === void 0 ) { timeout = 4000 ; }
if ( shouldExitIf === void 0 ) { shouldExitIf = function ( ) { return true ; } ; }
var log = function ( ) {
var args = [ ] ;
for ( var _i = 0 ; _i < arguments . length ; _i ++ ) {
args [ _i ] = arguments [ _i ] ;
}
return setProcessExitHandler . log ( "[ exit handler ] " + util . format . apply ( util , args ) ) ;
} ;
var handler = function ( exitCause ) { return _ _awaiter ( _this , void 0 , void 0 , function ( ) {
var process _exit , actionOut , error _4 ;
return _ _generator ( this , function ( _a ) {
switch ( _a . label ) {
case 0 :
if ( exitCause . type !== "NOTHING ELSE TO DO" && ! shouldExitIf ( exitCause ) ) {
log ( "Choosing ( c.f shouldExitIf ) not to terminate the process despite: " , exitCause ) ;
return [ 2 /*return*/ ] ;
}
handler = function ( exitCause ) { return log ( "Ignored extra exit cause" , exitCause ) ; } ;
process _exit = function ( ) {
if ( typeof process . exitCode !== "number" || isNaN ( process . exitCode ) ) {
if ( exitCause . type === "NOTHING ELSE TO DO" ) {
process . exitCode = 0 ;
}
else {
log ( "Exit cause " + exitCause . type + " and not exitCode have been set, using exit code 1" ) ;
process . exitCode = 1 ;
}
}
else {
log ( "Exit code have been set to " + process . exitCode ) ;
}
log ( "Stopping subprocess asap if any..." ) ;
stopProcessSync . stopSubProcessesAsapSync ( ) ;
log ( "exiting now with code " + process . exitCode ) ;
process . exit ( ) ;
} ;
log ( "Cause of process termination: " , exitCause ) ;
if ( timeout >= 0 ) {
setTimeout ( function ( ) {
log ( "Exit task timeout" ) ;
process . exitCode = 1 ;
process _exit ( ) ;
} , timeout ) ;
}
try {
actionOut = task ( exitCause ) ;
}
catch ( error ) {
log ( "Exit task thrown error" , error ) ;
process _exit ( ) ;
return [ 2 /*return*/ ] ;
}
if ( ! ( actionOut instanceof Promise ) ) return [ 3 /*break*/ , 4 ] ;
_a . label = 1 ;
case 1 :
_a . trys . push ( [ 1 , 3 , , 4 ] ) ;
return [ 4 /*yield*/ , actionOut ] ;
case 2 :
_a . sent ( ) ;
return [ 3 /*break*/ , 4 ] ;
case 3 :
error _4 = _a . sent ( ) ;
log ( "Exit task returned a promise that rejected" , error _4 ) ;
process _exit ( ) ;
return [ 2 /*return*/ ] ;
case 4 :
log ( "Exit task complete successfully." ) ;
process _exit ( ) ;
return [ 2 /*return*/ ] ;
}
} ) ;
} ) ; } ;
var _loop _1 = function ( signal ) {
process . on ( signal , function ( ) { return handler ( { "type" : "SIGNAL" , signal : signal } ) ; } ) ;
} ;
try {
for ( var _c = _ _values ( setProcessExitHandler . ExitCause . Signal . list ) , _d = _c . next ( ) ; ! _d . done ; _d = _c . next ( ) ) {
var signal = _d . value ;
_loop _1 ( signal ) ;
}
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
catch ( e _2 _1 ) { e _2 = { error : e _2 _1 } ; }
finally {
try {
if ( _d && ! _d . done && ( _a = _c . return ) ) _a . call ( _c ) ;
}
finally { if ( e _2 ) throw e _2 . error ; }
}
try {
for ( var _e = _ _values ( [ "uncaughtException" , "unhandledRejection" ] ) , _f = _e . next ( ) ; ! _f . done ; _f = _e . next ( ) ) {
var eventName = _f . value ;
process . on ( eventName , function ( error ) { return handler ( { "type" : "EXCEPTION" , error : error } ) ; } ) ;
}
}
catch ( e _3 _1 ) { e _3 = { error : e _3 _1 } ; }
finally {
try {
if ( _f && ! _f . done && ( _b = _e . return ) ) _b . call ( _e ) ;
}
finally { if ( e _3 ) throw e _3 . error ; }
}
process . on ( "beforeExit" , function ( ) { return handler ( { "type" : "NOTHING ELSE TO DO" } ) ; } ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
exports . setProcessExitHandler = setProcessExitHandler ;
( function ( setProcessExitHandler ) {
var ExitCause ;
( function ( ExitCause ) {
var Signal ;
( function ( Signal ) {
Signal . _obj = { "SIGINT" : null , "SIGUSR2" : null , "SIGHUP" : null } ;
Signal . list = Object . keys ( Signal . _obj ) ;
} ) ( Signal = ExitCause . Signal || ( ExitCause . Signal = { } ) ) ;
} ) ( ExitCause = setProcessExitHandler . ExitCause || ( setProcessExitHandler . ExitCause = { } ) ) ;
setProcessExitHandler . log = function ( ) { } ;
} ) ( setProcessExitHandler = exports . setProcessExitHandler || ( exports . setProcessExitHandler = { } ) ) ;
2022-10-11 16:10:23 +02:00
/ * *
*
2022-10-12 17:48:05 +02:00
* Stop a process by sending a specific signal to a target process .
* When the function return the main process and all it ' s descendent processes are terminated .
*
* The default signal is SIGUSR2 which is the signal used to gracefully terminate
* Process created by the createService function .
*
* Optionally runfiles _path can be provided to define a set of files
* that should be suppressed before returning .
*
* If pid is provided under the form of a pidfile path it will
* be added to the runfiles set .
*
* If all the processes does not terminate within [ delay _before _sigkill ] ms
* ( default 50000 ) then KILL signal will be sent to all processes still alive .
*
* If the PID provided is the same that the PID of the process running the function
* PidMatchCurrentProcessError will be thrown .
*
2022-10-11 16:10:23 +02:00
* /
2022-10-12 17:48:05 +02:00
function stopProcessSync ( pidfile _path _or _pid , signal , delay _before _sigkill , runfiles _path ) {
if ( signal === void 0 ) { signal = "SIGUSR2" ; }
if ( delay _before _sigkill === void 0 ) { delay _before _sigkill = 5000 ; }
if ( runfiles _path === void 0 ) { runfiles _path = [ ] ; }
var log = function ( ) {
var args = [ ] ;
for ( var _i = 0 ; _i < arguments . length ; _i ++ ) {
args [ _i ] = arguments [ _i ] ;
}
return stopProcessSync . log ( "[ stop process sync ] " + util . format . apply ( util , args ) ) ;
} ;
var cleanupRunfiles = function ( ) {
var e _4 , _a ;
try {
for ( var runfiles _path _1 = _ _values ( runfiles _path ) , runfiles _path _1 _1 = runfiles _path _1 . next ( ) ; ! runfiles _path _1 _1 . done ; runfiles _path _1 _1 = runfiles _path _1 . next ( ) ) {
var runfile _path = runfiles _path _1 _1 . value ;
if ( fs . existsSync ( runfile _path ) ) {
try {
fs . unlinkSync ( runfile _path ) ;
log ( path . basename ( runfile _path ) + " runfile manually cleaned up." ) ;
}
catch ( _b ) {
log ( colorize ( "Could not remove runfile " + runfile _path , "RED" ) ) ;
}
}
}
}
catch ( e _4 _1 ) { e _4 = { error : e _4 _1 } ; }
finally {
try {
if ( runfiles _path _1 _1 && ! runfiles _path _1 _1 . done && ( _a = runfiles _path _1 . return ) ) _a . call ( runfiles _path _1 ) ;
}
finally { if ( e _4 ) throw e _4 . error ; }
}
} ;
var pid ;
if ( typeof pidfile _path _or _pid === "number" ) {
pid = pidfile _path _or _pid ;
}
else {
var pidfile _path = pidfile _path _or _pid ;
runfiles _path = _ _spread ( [ pidfile _path ] , runfiles _path ) ;
if ( ! fs . existsSync ( pidfile _path ) ) {
log ( "Pidfile does not exist, assuming process not running" ) ;
cleanupRunfiles ( ) ;
2022-10-11 16:10:23 +02:00
return ;
}
2022-10-12 17:48:05 +02:00
try {
pid = parseInt ( fs . readFileSync ( pidfile _path ) . toString ( "utf8" ) . replace ( /\n$/ , "" ) ) ;
if ( isNaN ( pid ) ) {
throw new Error ( "pid is NaN" ) ;
}
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
catch ( _a ) {
log ( "Pidfile does does not contain pid" ) ;
cleanupRunfiles ( ) ;
2022-10-11 16:10:23 +02:00
return ;
}
2022-10-12 17:48:05 +02:00
}
if ( pid === process . pid ) {
throw new stopProcessSync . PidMatchCurrentProcessError ( cleanupRunfiles ) ;
}
var pids = _ _spread ( stopProcessSync . getSubProcesses ( pid , "FULL PROCESS TREE" ) , [
pid
] ) ;
var startTime = Date . now ( ) ;
if ( stopProcessSync . isProcessRunning ( pid ) ) {
log ( "Sending " + signal + " to target process (" + pid + ")" ) ;
stopProcessSync . kill ( pid , signal ) ;
}
else {
log ( "Target process (" + pid + ") is not running" ) ;
}
var _loop _2 = function ( ) {
var e _5 , _a ;
var runningPids = pids . filter ( function ( pid ) { return stopProcessSync . isProcessRunning ( pid ) ; } ) ;
if ( runningPids . length === 0 ) {
log ( "Target process (" + pid + ") and all it's sub processes are now terminated" ) ;
return "break" ;
}
else if ( Date . now ( ) >= startTime + delay _before _sigkill ) {
log ( ( function ( ) {
if ( delay _before _sigkill === 0 ) {
return "Immediately sending SIGKILL to " + runningPids . length + " remaining sub processes of target process (" + pid + ")" ;
}
else {
return [
! ! runningPids . find ( function ( _pid ) { return _pid === pid ; } ) ?
"Target process (" + pid + ") and " + ( runningPids . length - 1 ) + " of it's sub processes" :
runningPids . length + " sub processes of the target process (" + pid + ")" ,
"did not terminate in time, sending KILL signals."
] . join ( " " ) ;
}
} ) ( ) ) ;
try {
for ( var runningPids _1 = ( e _5 = void 0 , _ _values ( runningPids ) ) , runningPids _1 _1 = runningPids _1 . next ( ) ; ! runningPids _1 _1 . done ; runningPids _1 _1 = runningPids _1 . next ( ) ) {
var pid _1 = runningPids _1 _1 . value ;
stopProcessSync . kill ( pid _1 , "SIGKILL" ) ;
}
}
catch ( e _5 _1 ) { e _5 = { error : e _5 _1 } ; }
finally {
try {
if ( runningPids _1 _1 && ! runningPids _1 _1 . done && ( _a = runningPids _1 . return ) ) _a . call ( runningPids _1 ) ;
}
finally { if ( e _5 ) throw e _5 . error ; }
}
return "continue" ;
}
execSyncNoCmdTrace ( "sleep 0.1" ) ;
} ;
while ( true ) {
var state _1 = _loop _2 ( ) ;
if ( state _1 === "break" )
break ;
}
cleanupRunfiles ( ) ;
}
exports . stopProcessSync = stopProcessSync ;
( function ( stopProcessSync ) {
var PidMatchCurrentProcessError = /** @class */ ( function ( _super ) {
_ _extends ( PidMatchCurrentProcessError , _super ) ;
function PidMatchCurrentProcessError ( cleanupRunfiles ) {
var _newTarget = this . constructor ;
var _this = _super . call ( this , "StopProcessSync error, provided PID is the PID of the current process" ) || this ;
_this . cleanupRunfiles = cleanupRunfiles ;
Object . setPrototypeOf ( _this , _newTarget . prototype ) ;
return _this ;
}
return PidMatchCurrentProcessError ;
} ( Error ) ) ;
stopProcessSync . PidMatchCurrentProcessError = PidMatchCurrentProcessError ;
/ * *
* Stopping process As Soon As Possible ,
* stopProcessSync with signal SIGKILL and timeout 0
* * /
function stopProcessAsapSync ( pidfile _path _or _pid , runfiles _path ) {
if ( runfiles _path === void 0 ) { runfiles _path = [ ] ; }
stopProcessSync ( pidfile _path _or _pid , "SIGKILL" , 0 , runfiles _path ) ;
}
stopProcessSync . stopProcessAsapSync = stopProcessAsapSync ;
/ * *
* Terminate all child process of current process ASAP .
*
* NOTE : Directly after this function ( in the current tick )
* direct parents process that had sub processes will be Zombies .
* However they will be reaped by the current process on next tick .
*
* /
function stopSubProcessesAsapSync ( ) {
var e _6 , _a ;
try {
for ( var _b = _ _values ( getSubProcesses ( process . pid , "DIRECT SUB PROCESSES ONLY" ) ) , _c = _b . next ( ) ; ! _c . done ; _c = _b . next ( ) ) {
var pid = _c . value ;
if ( stopSubProcessesAsapSync . ignorePids . has ( pid ) ) {
continue ;
}
stopProcessSync ( pid , "SIGKILL" , 0 ) ;
}
}
catch ( e _6 _1 ) { e _6 = { error : e _6 _1 } ; }
finally {
try {
if ( _c && ! _c . done && ( _a = _b . return ) ) _a . call ( _b ) ;
}
finally { if ( e _6 ) throw e _6 . error ; }
}
}
stopProcessSync . stopSubProcessesAsapSync = stopSubProcessesAsapSync ;
( function ( stopSubProcessesAsapSync ) {
stopSubProcessesAsapSync . ignorePids = new Set ( ) ;
} ) ( stopSubProcessesAsapSync = stopProcessSync . stopSubProcessesAsapSync || ( stopProcessSync . stopSubProcessesAsapSync = { } ) ) ;
/** Invoke kill, can't throw */
function kill ( pid , signal ) {
try {
execSyncNoCmdTrace ( "kill -" + signal + " " + pid , { "stdio" : "pipe" , "shell" : "/bin/bash" } ) ;
}
catch ( _a ) {
}
}
stopProcessSync . kill = kill ;
/ * *
* Get the list of subprocess of a process ( return a list of pid )
* /
function getSubProcesses ( pid , depth ) {
var _a = child _process . spawnSync ( "/bin/ps" , [ "--ppid" , "" + pid , "-o" , "pid,state" ] , { "shell" : false } ) , stdout = _a . stdout , ps _pid = _a . pid , ps _exitCode = _a . status ;
if ( ps _exitCode !== 0 ) {
return [ ] ;
}
var pids = stdout
. toString ( "utf8" )
. split ( "\n" )
. filter ( function ( v ) { return ! v . match ( /Z/ ) ; } )
. map ( function ( v ) { return v . replace ( /[^0-9]/g , "" ) ; } )
. filter ( function ( v ) { return ! ! v ; } )
. map ( function ( v ) { return parseInt ( v ) ; } )
. filter ( function ( pid ) { return pid !== ps _pid ; } ) ;
switch ( depth ) {
case "DIRECT SUB PROCESSES ONLY" : return pids ;
case "FULL PROCESS TREE" : return ( function ( ) {
var e _7 , _a ;
var out = [ ] ;
try {
for ( var pids _1 = _ _values ( pids ) , pids _1 _1 = pids _1 . next ( ) ; ! pids _1 _1 . done ; pids _1 _1 = pids _1 . next ( ) ) {
var pid _2 = pids _1 _1 . value ;
out = _ _spread ( out , getSubProcesses ( pid _2 , "FULL PROCESS TREE" ) , [ pid _2 ] ) ;
}
}
catch ( e _7 _1 ) { e _7 = { error : e _7 _1 } ; }
finally {
try {
if ( pids _1 _1 && ! pids _1 _1 . done && ( _a = pids _1 . return ) ) _a . call ( pids _1 ) ;
}
finally { if ( e _7 ) throw e _7 . error ; }
}
return out ;
} ) ( ) ;
}
}
stopProcessSync . getSubProcesses = getSubProcesses ;
/** Return true only if exist and is not a daemon */
function isProcessRunning ( pid ) {
var psCmdOut ;
try {
psCmdOut = execSyncNoCmdTrace ( "ps --pid " + pid + " -o state" ) ;
}
catch ( _a ) {
return false ;
}
return ! psCmdOut . match ( /Z/ ) ;
}
stopProcessSync . isProcessRunning = isProcessRunning ;
/** Debug function to print the process tree of the current process. */
function _printProcessTree ( log ) {
if ( log === void 0 ) { log = console . log . bind ( console ) ; }
var rec = function ( node ) {
var e _8 , _a ;
var pids = getSubProcesses ( node . pid , "DIRECT SUB PROCESSES ONLY" ) ;
if ( pids . length === 0 ) {
return ;
}
node . sub = [ ] ;
try {
for ( var pids _2 = _ _values ( pids ) , pids _2 _1 = pids _2 . next ( ) ; ! pids _2 _1 . done ; pids _2 _1 = pids _2 . next ( ) ) {
var pid = pids _2 _1 . value ;
var sub _node = { pid : pid } ;
node . sub . push ( sub _node ) ;
rec ( sub _node ) ;
}
}
catch ( e _8 _1 ) { e _8 = { error : e _8 _1 } ; }
finally {
try {
if ( pids _2 _1 && ! pids _2 _1 . done && ( _a = pids _2 . return ) ) _a . call ( pids _2 ) ;
}
finally { if ( e _8 ) throw e _8 . error ; }
}
} ;
var tree = { "pid" : process . pid } ;
rec ( tree ) ;
log ( JSON . stringify ( tree , null , 3 ) ) ;
}
stopProcessSync . _printProcessTree = _printProcessTree ;
stopProcessSync . log = function ( ) { } ;
} ) ( stopProcessSync = exports . stopProcessSync || ( exports . stopProcessSync = { } ) ) ;
/ * *
*
* Function to create the entry point ( main . js ) of a node service that can :
* - Restart on crash ( without relying on systemd to do so ) .
* - Execute as specific unix user but can perform tasks as root before start .
* - Be stopped gracefully by sending USR2 signal on the root process ( identified by pidfile ) .
* - Be started via a shell and gracefully stopped with CTRL - C ( INT signal ) .
* - Ensure only one instance of the service run at the same time .
* ( if at the time the main is called there is an other instance of the service
* running it is gracefully terminated )
* - Ensure that the process will terminate in at most [ stop _timeout ] ms after
* receiving INT or USR2 signal . ( default 5 second )
* - Forward daemon processes stdout to root process stdout .
* - Can fork multiple daemon process .
*
* The root process forward command line arguments and environnement variable to
* the daemon processes .
*
* => rootProcess function should return ( when not default ) :
* - pidfile _path : where to store the pid of the root process .
* take to terminate after requested to exit gracefully .
* - srv _name : Name of the service to overwrite the process names . ( Default : not overwriting )
* - stop _timeout : The maximum amount of time ( in ms ) the
* that beforeExitTask can take to complete before being killed by force by root process .
* After receiving USR2 signal or CTRL , the root process will be closed within [ trop _timeout ] + 1000 ms
* - assert _unix _user : enforce that the main be called by a specific user .
* - isQuiet ? : set to true to disable process debug info logging on stdout . Prefixed by [ service ] . ( default false )
* - doForwardDaemonStdout ? : set to true to forward everything the daemon
* process write to stdout to the root process stdout . ( default true )
* - daemon _unix _user ? : User who should own the daemon process .
* - daemon _node _path ? : Node . js executable that should be used to by the daemon process .
* - daemon _cwd ? : working directory of the daemon process .
* - daemon _restart _after _crash _delay ? : ( Default to 500 ms . ) Delay in ms before restarting the daemon
* after it terminate without being requested to . If set to a negative number the daemons
* will not be restarted after it terminate for the first time and :
* If all daemons process exited with 0 and there is no other daemon process the root process
* will end with a clean exit code .
* If any of the daemon exit with an unclean code the root process will be terminated with an error code
* even if there is some other daemon running .
* - daemon _count : Number of instance of daemon process that should be forked , default 1.
* - max _consecutive _restart : Number of time a daemon should be restarted after crashing right after start .
* ( Default ~ Infinity ) .
* - preForkTask : Task to perform before forking a daemon process .
* It is called just before forking the daemon process . ( called again on every restart . )
* If the function is async the daemon will not be forked until the returned promise resolve .
* If the function throw exception root process will exit with code 1.
* ( pidfile will be deleted )
* If the function is async and if it need to spawn child processes then
* an implementation for terminateSubProcess ( passed as reference ) should be provided so that
* if when called it kill all the child processes then resolve once they are terminated .
* The to which the promise resolve will be used as exit code for the root process .
* Note that terminateSubProcess should never be called , it is a OUT parameter .
* However if the implementation provided is just to send a SIGKILL to the forked processes
* then there is no need to provide an implementation as all the root process ' s sub processes tree
* will be killed before exiting anyway .
*
* => daemonProcess
* It should return :
* - launch : the function that the daemon process need to call to start the actual job that the service is meant to perform .
* - beforeExitTask : function that should be called before the daemon process exit . ( e . g . creating crash report ) .
* If the daemon process is terminating due to an error the error will be passed as argument .
* There is two scenario that will led to this function NOT being called :
* 1 ) The daemon process receive KILL or other deadly signal that can ' t be overridden .
* 2 ) The root process terminate .
* daemon _number represent the instance index of the daemon among the total of [ damon _count ] process forked .
* It can be user to use a different logfile for each daemon process instance .
*
* NOTE : If the root process receive a deadly signal other than INT , USR2 or HUP
* ( e . g . KILL or STOP ) the root and daemon processes will immediately terminate without
* executing beforeExit tasks or removing pidfile .
*
* NOTE : because setting listener on "message" and "disconnect" process event prevent the
* thread from terminating naturally where is nothing more to do if you wish to manually
* terminate the daemon process without termination being requested from the parent you can :
* 1 ) emit "beforeExit" on process setting the desired exit code ( process . emit ( "beforeExit" , process . exitCode = X ) ;
* 2 ) throw an exception .
*
* /
function createService ( params ) {
var _this = this ;
var log = ( function ( ) { } ) ;
var getLog = function ( prefix ) {
return ( function ( ) {
var args = [ ] ;
for ( var _i = 0 ; _i < arguments . length ; _i ++ ) {
args [ _i ] = arguments [ _i ] ;
}
return process . stdout . write ( Buffer . from ( "[service] ( " + prefix + " ) " + util . format . apply ( util , args ) + "\n" , "utf8" ) ) ;
2022-10-11 16:10:23 +02:00
} ) ;
2022-10-12 17:48:05 +02:00
} ;
var rootProcess = params . rootProcess , daemonProcess = params . daemonProcess ;
var main _root = function ( main _js _path ) { return _ _awaiter ( _this , void 0 , void 0 , function ( ) {
var _a , pidfile _path , srv _name , _stop _timeout , assert _unix _user , isQuiet , _doForwardDaemonStdout , daemon _unix _user , daemon _node _path , daemon _cwd , _daemon _restart _after _crash _delay , max _consecutive _restart , preForkTask , _daemon _count , stop _timeout , doForwardDaemonStdout , daemon _restart _after _crash _delay , daemon _count , daemonContexts , isTerminating , args , _b , daemon _uid , daemon _gid , makeForkOptions , forkDaemon , daemon _number ;
var _this = this ;
return _ _generator ( this , function ( _c ) {
switch ( _c . label ) {
case 0 : return [ 4 /*yield*/ , rootProcess ( ) ] ;
case 1 :
_a = _c . sent ( ) , pidfile _path = _a . pidfile _path , srv _name = _a . srv _name , _stop _timeout = _a . stop _timeout , assert _unix _user = _a . assert _unix _user , isQuiet = _a . isQuiet , _doForwardDaemonStdout = _a . doForwardDaemonStdout , daemon _unix _user = _a . daemon _unix _user , daemon _node _path = _a . daemon _node _path , daemon _cwd = _a . daemon _cwd , _daemon _restart _after _crash _delay = _a . daemon _restart _after _crash _delay , max _consecutive _restart = _a . max _consecutive _restart , preForkTask = _a . preForkTask , _daemon _count = _a . daemon _count ;
if ( srv _name !== undefined ) {
process . title = srv _name + " root process" ;
}
stop _timeout = _stop _timeout !== undefined ?
_stop _timeout : 5000 ;
doForwardDaemonStdout = _doForwardDaemonStdout !== undefined ?
_doForwardDaemonStdout : true ;
daemon _restart _after _crash _delay = _daemon _restart _after _crash _delay !== undefined ?
_daemon _restart _after _crash _delay : 500 ;
daemon _count = _daemon _count !== undefined ?
_daemon _count : 1 ;
if ( assert _unix _user !== undefined && os . userInfo ( ) . username !== assert _unix _user ) {
console . log ( colorize ( "Must be run as " + assert _unix _user , "RED" ) ) ;
process . exit ( 1 ) ;
return [ 2 /*return*/ ] ;
}
if ( ! isQuiet ) {
log = getLog ( "root process" ) ;
}
stopProcessSync . log = log ;
try {
stopProcessSync ( pidfile _path ) ;
}
catch ( error ) {
if ( ! ( error instanceof stopProcessSync . PidMatchCurrentProcessError ) ) {
throw error ;
}
error . cleanupRunfiles ( ) ;
}
if ( fs . existsSync ( pidfile _path ) ) {
throw Error ( "Other instance launched simultaneously" ) ;
}
( function createPidfile ( ) {
var pidfile _dir _path = path . dirname ( pidfile _path ) ;
if ( ! fs . existsSync ( pidfile _dir _path ) ) {
execSyncNoCmdTrace ( "mkdir -p " + pidfile _dir _path ) ;
}
fs . writeFileSync ( pidfile _path , process . pid . toString ( ) ) ;
} ) ( ) ;
log ( "PID: " + process . pid ) ;
daemonContexts = new Map ( ( new Array ( daemon _count ) )
. fill ( null )
. map ( function ( _ , index ) {
var context = [
index + 1 ,
{
"daemonProcess" : undefined ,
"terminatePreForkChildProcesses" : { "impl" : function ( ) { return Promise . resolve ( ) ; } } ,
"restart_attempt_remaining" : max _consecutive _restart || NaN ,
"reset_restart_attempt_timer" : setTimeout ( function ( ) { } , 0 )
}
] ;
return context ;
} ) ) ;
isTerminating = false ;
setProcessExitHandler ( function ( exitCause ) { return _ _awaiter ( _this , void 0 , void 0 , function ( ) {
var childProcessExitCode ;
return _ _generator ( this , function ( _a ) {
switch ( _a . label ) {
case 0 :
isTerminating = true ;
return [ 4 /*yield*/ , ( function terminateAllChildProcesses ( ) {
return _ _awaiter ( this , void 0 , void 0 , function ( ) {
var terminateDaemonProcess , terminatePreForkChildProcessesSafeCall , tasks , _loop _3 , _a , _b , _c , daemonProcess _1 , terminatePreForkChildProcesses ;
var e _9 , _d ;
var _this = this ;
return _ _generator ( this , function ( _e ) {
switch ( _e . label ) {
case 0 :
terminateDaemonProcess = function ( daemonProcess ) { return _ _awaiter ( _this , void 0 , void 0 , function ( ) {
return _ _generator ( this , function ( _a ) {
return [ 2 /*return*/ , new Promise ( function ( resolve ) {
log ( "Attempt to gracefully terminate daemon process PID: " + daemonProcess . pid + "..." ) ;
daemonProcess . send ( null ) ;
var timer = setTimeout ( function ( ) { return doStopAsap ( ) ; } , stop _timeout + 500 ) ;
daemonProcess . once ( "error" , function ( ) { return doStopAsap ( ) ; } ) ;
daemonProcess . once ( "close" , function ( childProcessExitCode ) {
clearTimeout ( timer ) ;
log ( "Daemon process PID: " + daemonProcess . pid + " exited with code " + childProcessExitCode ) ;
if ( typeof childProcessExitCode !== "number" || isNaN ( childProcessExitCode ) ) {
childProcessExitCode = 1 ;
}
resolve ( childProcessExitCode ) ;
} ) ;
var doStopAsap = function ( ) {
log ( "Daemon process PID:" + daemonProcess . pid + " not responding, force kill..." ) ;
clearTimeout ( timer ) ;
daemonProcess . removeAllListeners ( "error" ) ;
daemonProcess . removeAllListeners ( "close" ) ;
stopProcessSync . stopProcessAsapSync ( daemonProcess . pid ) ;
resolve ( 1 ) ;
} ;
} ) ] ;
} ) ;
} ) ; } ;
terminatePreForkChildProcessesSafeCall = function ( impl ) {
var timer ;
return Promise . race ( [
new Promise ( function ( resolve ) { return timer = setTimeout ( function ( ) { return resolve ( "TIMEOUT" ) ; } , stop _timeout + 500 ) ; } ) ,
( function ( ) { return _ _awaiter ( _this , void 0 , void 0 , function ( ) {
var result , _a ;
return _ _generator ( this , function ( _b ) {
switch ( _b . label ) {
case 0 :
_b . trys . push ( [ 0 , 2 , , 3 ] ) ;
return [ 4 /*yield*/ , impl ( ) ] ;
case 1 :
_b . sent ( ) ;
result = "SUCCESS" ;
return [ 3 /*break*/ , 3 ] ;
case 2 :
_a = _b . sent ( ) ;
result = "ERROR" ;
return [ 3 /*break*/ , 3 ] ;
case 3 :
clearTimeout ( timer ) ;
return [ 2 /*return*/ , result ] ;
}
} ) ;
} ) ; } ) ( )
] ) ;
} ;
tasks = [ ] ;
_loop _3 = function ( daemonProcess _1 , terminatePreForkChildProcesses ) {
tasks [ tasks . length ] = ! daemonProcess _1 ? ( new Promise ( function ( resolve ) { return terminatePreForkChildProcessesSafeCall ( terminatePreForkChildProcesses . impl )
. then ( function ( result ) { return result === "SUCCESS" ? resolve ( 0 ) : resolve ( 1 ) ; } ) ; } ) ) : terminateDaemonProcess ( daemonProcess _1 ) ;
} ;
try {
for ( _a = _ _values ( daemonContexts . values ( ) ) , _b = _a . next ( ) ; ! _b . done ; _b = _a . next ( ) ) {
_c = _b . value , daemonProcess _1 = _c . daemonProcess , terminatePreForkChildProcesses = _c . terminatePreForkChildProcesses ;
_loop _3 ( daemonProcess _1 , terminatePreForkChildProcesses ) ;
}
}
catch ( e _9 _1 ) { e _9 = { error : e _9 _1 } ; }
finally {
try {
if ( _b && ! _b . done && ( _d = _a . return ) ) _d . call ( _a ) ;
}
finally { if ( e _9 ) throw e _9 . error ; }
}
return [ 4 /*yield*/ , Promise . all ( tasks ) ] ;
case 1 : return [ 2 /*return*/ , ( _e . sent ( ) ) . reduce ( function ( accumulator , currentValue ) { return accumulator === 0 ? currentValue : accumulator ; } , 0 ) ] ;
}
} ) ;
} ) ;
} ) ( ) ] ;
case 1 :
childProcessExitCode = _a . sent ( ) ;
if ( exitCause . type === "EXCEPTION" ) {
/ *
preForkTask throw or daemonProcess emit error or
one of the daemon exited with a non 0 code and
restart _delay was set < 0
* /
log ( "Root process exception message: " + exitCause . error . message ) ;
process . exitCode = 1 ;
}
else {
process . exitCode = childProcessExitCode ;
}
fs . unlinkSync ( pidfile _path ) ;
log ( "pidfile deleted" ) ;
return [ 2 /*return*/ ] ;
}
} ) ;
} ) ; } , stop _timeout + 1000 ) ;
setProcessExitHandler . log = log ;
args = ( function ( ) {
var out = _ _spread ( process . argv ) ;
out . shift ( ) ;
out . shift ( ) ;
return out ;
} ) ( ) ;
_b = _ _read ( ( function ( ) {
if ( ! ! daemon _unix _user ) {
return [ get _uid ( daemon _unix _user ) , get _gid ( daemon _unix _user ) ] ;
}
else {
return [ undefined , undefined ] ;
}
} ) ( ) , 2 ) , daemon _uid = _b [ 0 ] , daemon _gid = _b [ 1 ] ;
makeForkOptions = function ( daemon _number ) { return ( {
"uid" : daemon _uid ,
"gid" : daemon _gid ,
"silent" : true ,
"cwd" : daemon _cwd ,
"execPath" : daemon _node _path ,
"env" : _ _assign ( { } , process . env , { daemon _number : daemon _number ,
daemon _count : daemon _count ,
srv _name : srv _name ,
stop _timeout : stop _timeout , "isQuiet" : isQuiet ? "1" : "0" } )
} ) ; } ;
forkDaemon = function ( daemon _number ) { return _ _awaiter ( _this , void 0 , void 0 , function ( ) {
var context , error _5 , daemonProcess ;
return _ _generator ( this , function ( _a ) {
switch ( _a . label ) {
case 0 :
context = daemonContexts . get ( daemon _number ) ;
clearTimeout ( context . reset _restart _attempt _timer ) ;
if ( ! ! ! preForkTask ) return [ 3 /*break*/ , 5 ] ;
log ( "performing pre fork tasks for daemon number " + daemon _number + "..." ) ;
_a . label = 1 ;
case 1 :
_a . trys . push ( [ 1 , 3 , , 4 ] ) ;
return [ 4 /*yield*/ , preForkTask ( context . terminatePreForkChildProcesses , daemon _number ) ] ;
case 2 :
_a . sent ( ) ;
return [ 3 /*break*/ , 4 ] ;
case 3 :
error _5 = _a . sent ( ) ;
log ( "PreFork tasks for daemon number " + daemon _number + " raised an exception" ) ;
throw error _5 ;
case 4 :
context . terminatePreForkChildProcesses . impl = function ( ) { return Promise . resolve ( ) ; } ;
_a . label = 5 ;
case 5 :
if ( isTerminating ) {
log ( "Not forking daemon because root process is terminating" ) ;
return [ 2 /*return*/ ] ;
}
if ( max _consecutive _restart !== undefined ) {
context . reset _restart _attempt _timer = setTimeout ( function ( ) { return context . restart _attempt _remaining = max _consecutive _restart ; } , 10000 ) ;
}
log ( "Forking daemon process number " + daemon _number + " now." ) ;
daemonProcess = child _process . fork ( main _js _path , args , makeForkOptions ( daemon _number ) ) ;
context . daemonProcess = daemonProcess ;
if ( doForwardDaemonStdout ) {
daemonProcess . stdout . on ( "data" , function ( data ) {
return process . stdout . write ( data ) ;
} ) ;
}
daemonProcess . once ( "error" , function ( error ) {
if ( isTerminating ) {
return ;
}
context . daemonProcess = undefined ;
log ( [
"Error evt emitted by daemon process number " + daemon _number ,
"Meaning that: " ,
"The process could not be spawned, or" ,
"The process could not be killed, or" ,
"Sending a message to the child process failed."
] . join ( "\n" ) ) ;
throw error ;
} ) ;
daemonProcess . once ( "close" , function ( childProcessExitCode ) {
if ( isTerminating ) {
return ;
}
context . daemonProcess = undefined ;
log ( "Daemon process " + daemon _number + " exited without being requested to." ) ;
if ( daemon _restart _after _crash _delay < 0 ) {
if ( childProcessExitCode === null ) {
childProcessExitCode = 1 ;
}
log ( "Daemon number " + daemon _number + " will not be restarted." ) ;
clearTimeout ( context . reset _restart _attempt _timer ) ;
if ( childProcessExitCode !== 0 ) {
throw new Error ( "Daemon number " + daemon _number + ", crashed" ) ;
}
else if ( ! Array . from ( daemonContexts . values ( ) ) . find ( function ( _a ) {
var daemonProcess = _a . daemonProcess ;
return ! ! daemonProcess ;
} ) ) {
log ( "As last remaining daemon process terminated cleanly we stop end root process" ) ;
process . emit ( "beforeExit" , NaN ) ;
}
return ;
}
if ( max _consecutive _restart !== undefined ) {
if ( context . restart _attempt _remaining -- === 0 ) {
throw new Error ( "Daemon process " + daemon _number + " is crashing over and over" ) ;
}
else {
log ( "Restart remaining: " + context . restart _attempt _remaining ) ;
}
}
log ( "Daemon process " + daemon _number + " will be restarted" ) ;
setTimeout ( function ( ) { return forkDaemon ( daemon _number ) ; } , daemon _restart _after _crash _delay ) ;
} ) ;
return [ 2 /*return*/ ] ;
}
} ) ;
} ) ; } ;
for ( daemon _number = 1 ; daemon _number <= daemon _count ; daemon _number ++ ) {
forkDaemon ( daemon _number ) ;
}
return [ 2 /*return*/ ] ;
}
2022-10-11 16:10:23 +02:00
} ) ;
2022-10-12 17:48:05 +02:00
} ) ; } ;
var main _daemon = function ( ) { return _ _awaiter ( _this , void 0 , void 0 , function ( ) {
var _a , daemon _number , daemon _count , stop _timeout , isQuiet , srv _name , _b , launch , beforeExitTask ;
var _this = this ;
return _ _generator ( this , function ( _c ) {
switch ( _c . label ) {
case 0 :
_a = _ _read ( [ "daemon_number" , "daemon_count" , "stop_timeout" , "isQuiet" ] . map ( function ( key ) {
var value = parseInt ( process . env [ key ] ) ;
delete process . env [ key ] ;
return value ;
} ) , 4 ) , daemon _number = _a [ 0 ] , daemon _count = _a [ 1 ] , stop _timeout = _a [ 2 ] , isQuiet = _a [ 3 ] ;
srv _name = ( function ( ) {
var key = "srv_name" ;
var value = process . env [ key ] ;
delete process . env [ key ] ;
if ( value === "" + undefined ) {
return undefined ;
}
else {
return value ;
}
} ) ( ) ;
if ( ! isQuiet ) {
log = getLog ( "daemon process " + daemon _number + "/" + daemon _count + ", PID: " + process . pid ) ;
}
if ( srv _name !== undefined ) {
process . title = srv _name + " daemon " + ( daemon _count === 1 ? "" : daemon _number ) ;
}
return [ 4 /*yield*/ , daemonProcess ( daemon _number , daemon _count ) ] ;
case 1 :
_b = _c . sent ( ) , launch = _b . launch , beforeExitTask = _b . beforeExitTask ;
process . once ( "message" , function ( ) { return process . emit ( "beforeExit" , process . exitCode = 0 ) ; } ) ;
process . once ( "disconnect" , function ( ) { return process . exit ( 1 ) ; } ) ;
setProcessExitHandler ( function ( exitCause ) { return _ _awaiter ( _this , void 0 , void 0 , function ( ) {
var error , prBeforeExitTask ;
return _ _generator ( this , function ( _a ) {
switch ( _a . label ) {
case 0 :
error = exitCause . type === "EXCEPTION" ? exitCause . error : undefined ;
if ( ! ! ! beforeExitTask ) return [ 3 /*break*/ , 2 ] ;
prBeforeExitTask = beforeExitTask ( error ) ;
if ( ! ( prBeforeExitTask instanceof Promise ) ) return [ 3 /*break*/ , 2 ] ;
return [ 4 /*yield*/ , safePr ( prBeforeExitTask , stop _timeout + 2000 ) . then ( function ( error ) {
if ( error instanceof Error ) {
//NOTE: Throwing does not overwrite the exit code.
if ( error . message === safePr . timeoutErrorMessage ) {
//NOTE: Throwing string to not have the log of setProcessExitHandler
//display the stack trace.
throw "beforeExitTask took too much time to complete." ;
}
else {
throw error ;
}
}
} ) ] ;
case 1 :
_a . sent ( ) ;
_a . label = 2 ;
case 2 : return [ 2 /*return*/ ] ;
}
} ) ;
} ) ; } , - 1 , function ( exitCause ) { return exitCause . type !== "SIGNAL" ; } ) ;
setProcessExitHandler . log = log ;
launch ( ) ;
return [ 2 /*return*/ ] ;
2022-10-11 16:10:23 +02:00
}
} ) ;
2022-10-12 17:48:05 +02:00
} ) ; } ;
if ( ! process . send ) {
main _root ( get _caller _file _path _2 . get _caller _file _path ( ) ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
else {
main _daemon ( ) ;
2022-10-11 16:10:23 +02:00
}
}
2022-10-12 17:48:05 +02:00
exports . createService = createService ;
var systemd ;
( function ( systemd ) {
var mkPath = function ( srv _name ) { return "/etc/systemd/system/" + srv _name + ".service" ; } ;
/ * *
* Generate a systemd config file for a service created via "createService" function
* enable by default , start by default .
* /
function createConfigFile ( srv _name , main _js _path , node _path , enable , start ) {
if ( node _path === void 0 ) { node _path = process . argv [ 0 ] ; }
if ( enable === void 0 ) { enable = "ENABLE" ; }
if ( start === void 0 ) { start = "START" ; }
fs . writeFileSync ( mkPath ( srv _name ) , Buffer . from ( [
"[Unit]" ,
"After=network.target" ,
"" ,
"[Service]" ,
"ExecStart=" + node _path + " " + main _js _path ,
"StandardOutput=inherit" ,
"KillMode=process" ,
"KillSignal=SIGUSR2" ,
"SendSIGKILL=no" ,
"Environment=NODE_ENV=production" ,
"" ,
"[Install]" ,
"WantedBy=multi-user.target" ,
""
] . join ( "\n" ) , "utf8" ) ) ;
execSyncNoCmdTrace ( "systemctl daemon-reload" ) ;
if ( ! ! enable ) {
execSyncNoCmdTrace ( "systemctl enable " + srv _name , { "stdio" : "pipe" } ) ;
}
if ( ! ! start ) {
execSyncNoCmdTrace ( "systemctl start " + srv _name ) ;
}
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
systemd . createConfigFile = createConfigFile ;
/** Remove config file disable and reload daemon, never throw, stop is false by default */
function deleteConfigFile ( srv _name , stop ) {
if ( stop === void 0 ) { stop = false ; }
if ( ! ! stop ) {
execSyncNoCmdTrace ( "systemctl stop " + srv _name + " || true" , { "stdio" : "pipe" } ) ;
}
execSyncNoCmdTrace ( "systemctl disable " + srv _name + " || true" , { "stdio" : "pipe" } ) ;
try {
fs . unlinkSync ( mkPath ( srv _name ) ) ;
}
catch ( _a ) { }
execSyncNoCmdTrace ( "systemctl daemon-reload || true" , { "stdio" : "pipe" } ) ;
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
systemd . deleteConfigFile = deleteConfigFile ;
} ) ( systemd = exports . systemd || ( exports . systemd = { } ) ) ;
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 5911 :
/***/ ( ( module , exports ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports = module . exports = SemVer
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var debug
/* istanbul ignore next */
if ( typeof process === 'object' &&
process . env &&
process . env . NODE _DEBUG &&
/\bsemver\b/i . test ( process . env . NODE _DEBUG ) ) {
debug = function ( ) {
var args = Array . prototype . slice . call ( arguments , 0 )
args . unshift ( 'SEMVER' )
console . log . apply ( console , args )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
} else {
debug = function ( ) { }
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
// Note: this is the semver.org version of the spec that it implements
// Not necessarily the package version of this code.
exports . SEMVER _SPEC _VERSION = '2.0.0'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var MAX _LENGTH = 256
var MAX _SAFE _INTEGER = Number . MAX _SAFE _INTEGER ||
/* istanbul ignore next */ 9007199254740991
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Max safe segment length for coercion.
var MAX _SAFE _COMPONENT _LENGTH = 16
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// The actual regexps go on exports.re
var re = exports . re = [ ]
var src = exports . src = [ ]
var R = 0
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// The following Regular Expressions can be used for tokenizing,
// validating, and parsing SemVer version strings.
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// ## Numeric Identifier
// A single `0`, or a non-zero digit followed by zero or more digits.
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var NUMERICIDENTIFIER = R ++
src [ NUMERICIDENTIFIER ] = '0|[1-9]\\d*'
var NUMERICIDENTIFIERLOOSE = R ++
src [ NUMERICIDENTIFIERLOOSE ] = '[0-9]+'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// ## Non-numeric Identifier
// Zero or more digits, followed by a letter or hyphen, and then zero or
// more letters, digits, or hyphens.
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var NONNUMERICIDENTIFIER = R ++
src [ NONNUMERICIDENTIFIER ] = '\\d*[a-zA-Z-][a-zA-Z0-9-]*'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// ## Main Version
// Three dot-separated numeric identifiers.
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var MAINVERSION = R ++
src [ MAINVERSION ] = '(' + src [ NUMERICIDENTIFIER ] + ')\\.' +
'(' + src [ NUMERICIDENTIFIER ] + ')\\.' +
'(' + src [ NUMERICIDENTIFIER ] + ')'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var MAINVERSIONLOOSE = R ++
src [ MAINVERSIONLOOSE ] = '(' + src [ NUMERICIDENTIFIERLOOSE ] + ')\\.' +
'(' + src [ NUMERICIDENTIFIERLOOSE ] + ')\\.' +
'(' + src [ NUMERICIDENTIFIERLOOSE ] + ')'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// ## Pre-release Version Identifier
// A numeric identifier, or a non-numeric identifier.
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var PRERELEASEIDENTIFIER = R ++
src [ PRERELEASEIDENTIFIER ] = '(?:' + src [ NUMERICIDENTIFIER ] +
'|' + src [ NONNUMERICIDENTIFIER ] + ')'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var PRERELEASEIDENTIFIERLOOSE = R ++
src [ PRERELEASEIDENTIFIERLOOSE ] = '(?:' + src [ NUMERICIDENTIFIERLOOSE ] +
'|' + src [ NONNUMERICIDENTIFIER ] + ')'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// ## Pre-release Version
// Hyphen, followed by one or more dot-separated pre-release version
// identifiers.
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var PRERELEASE = R ++
src [ PRERELEASE ] = '(?:-(' + src [ PRERELEASEIDENTIFIER ] +
'(?:\\.' + src [ PRERELEASEIDENTIFIER ] + ')*))'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var PRERELEASELOOSE = R ++
src [ PRERELEASELOOSE ] = '(?:-?(' + src [ PRERELEASEIDENTIFIERLOOSE ] +
'(?:\\.' + src [ PRERELEASEIDENTIFIERLOOSE ] + ')*))'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// ## Build Metadata Identifier
// Any combination of digits, letters, or hyphens.
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var BUILDIDENTIFIER = R ++
src [ BUILDIDENTIFIER ] = '[0-9A-Za-z-]+'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// ## Build Metadata
// Plus sign, followed by one or more period-separated build metadata
// identifiers.
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var BUILD = R ++
src [ BUILD ] = '(?:\\+(' + src [ BUILDIDENTIFIER ] +
'(?:\\.' + src [ BUILDIDENTIFIER ] + ')*))'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// ## Full Version String
// A main version, followed optionally by a pre-release version and
// build metadata.
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Note that the only major, minor, patch, and pre-release sections of
// the version string are capturing groups. The build metadata is not a
// capturing group, because it should not ever be used in version
// comparison.
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var FULL = R ++
var FULLPLAIN = 'v?' + src [ MAINVERSION ] +
src [ PRERELEASE ] + '?' +
src [ BUILD ] + '?'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
src [ FULL ] = '^' + FULLPLAIN + '$'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// like full, but allows v1.2.3 and =1.2.3, which people do sometimes.
// also, 1.0.0alpha1 (prerelease without the hyphen) which is pretty
// common in the npm registry.
var LOOSEPLAIN = '[v=\\s]*' + src [ MAINVERSIONLOOSE ] +
src [ PRERELEASELOOSE ] + '?' +
src [ BUILD ] + '?'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var LOOSE = R ++
src [ LOOSE ] = '^' + LOOSEPLAIN + '$'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var GTLT = R ++
src [ GTLT ] = '((?:<|>)?=?)'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Something like "2.*" or "1.2.x".
// Note that "x.x" is a valid xRange identifer, meaning "any version"
// Only the first item is strictly required.
var XRANGEIDENTIFIERLOOSE = R ++
src [ XRANGEIDENTIFIERLOOSE ] = src [ NUMERICIDENTIFIERLOOSE ] + '|x|X|\\*'
var XRANGEIDENTIFIER = R ++
src [ XRANGEIDENTIFIER ] = src [ NUMERICIDENTIFIER ] + '|x|X|\\*'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var XRANGEPLAIN = R ++
src [ XRANGEPLAIN ] = '[v=\\s]*(' + src [ XRANGEIDENTIFIER ] + ')' +
'(?:\\.(' + src [ XRANGEIDENTIFIER ] + ')' +
'(?:\\.(' + src [ XRANGEIDENTIFIER ] + ')' +
'(?:' + src [ PRERELEASE ] + ')?' +
src [ BUILD ] + '?' +
')?)?'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var XRANGEPLAINLOOSE = R ++
src [ XRANGEPLAINLOOSE ] = '[v=\\s]*(' + src [ XRANGEIDENTIFIERLOOSE ] + ')' +
'(?:\\.(' + src [ XRANGEIDENTIFIERLOOSE ] + ')' +
'(?:\\.(' + src [ XRANGEIDENTIFIERLOOSE ] + ')' +
'(?:' + src [ PRERELEASELOOSE ] + ')?' +
src [ BUILD ] + '?' +
')?)?'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var XRANGE = R ++
src [ XRANGE ] = '^' + src [ GTLT ] + '\\s*' + src [ XRANGEPLAIN ] + '$'
var XRANGELOOSE = R ++
src [ XRANGELOOSE ] = '^' + src [ GTLT ] + '\\s*' + src [ XRANGEPLAINLOOSE ] + '$'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Coercion.
// Extract anything that could conceivably be a part of a valid semver
var COERCE = R ++
src [ COERCE ] = '(?:^|[^\\d])' +
'(\\d{1,' + MAX _SAFE _COMPONENT _LENGTH + '})' +
'(?:\\.(\\d{1,' + MAX _SAFE _COMPONENT _LENGTH + '}))?' +
'(?:\\.(\\d{1,' + MAX _SAFE _COMPONENT _LENGTH + '}))?' +
'(?:$|[^\\d])'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Tilde ranges.
// Meaning is "reasonably at or greater than"
var LONETILDE = R ++
src [ LONETILDE ] = '(?:~>?)'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var TILDETRIM = R ++
src [ TILDETRIM ] = '(\\s*)' + src [ LONETILDE ] + '\\s+'
re [ TILDETRIM ] = new RegExp ( src [ TILDETRIM ] , 'g' )
var tildeTrimReplace = '$1~'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var TILDE = R ++
src [ TILDE ] = '^' + src [ LONETILDE ] + src [ XRANGEPLAIN ] + '$'
var TILDELOOSE = R ++
src [ TILDELOOSE ] = '^' + src [ LONETILDE ] + src [ XRANGEPLAINLOOSE ] + '$'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Caret ranges.
// Meaning is "at least and backwards compatible with"
var LONECARET = R ++
src [ LONECARET ] = '(?:\\^)'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var CARETTRIM = R ++
src [ CARETTRIM ] = '(\\s*)' + src [ LONECARET ] + '\\s+'
re [ CARETTRIM ] = new RegExp ( src [ CARETTRIM ] , 'g' )
var caretTrimReplace = '$1^'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var CARET = R ++
src [ CARET ] = '^' + src [ LONECARET ] + src [ XRANGEPLAIN ] + '$'
var CARETLOOSE = R ++
src [ CARETLOOSE ] = '^' + src [ LONECARET ] + src [ XRANGEPLAINLOOSE ] + '$'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// A simple gt/lt/eq thing, or just "" to indicate "any version"
var COMPARATORLOOSE = R ++
src [ COMPARATORLOOSE ] = '^' + src [ GTLT ] + '\\s*(' + LOOSEPLAIN + ')$|^$'
var COMPARATOR = R ++
src [ COMPARATOR ] = '^' + src [ GTLT ] + '\\s*(' + FULLPLAIN + ')$|^$'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// An expression to strip any whitespace between the gtlt and the thing
// it modifies, so that `> 1.2.3` ==> `>1.2.3`
var COMPARATORTRIM = R ++
src [ COMPARATORTRIM ] = '(\\s*)' + src [ GTLT ] +
'\\s*(' + LOOSEPLAIN + '|' + src [ XRANGEPLAIN ] + ')'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// this one has to use the /g flag
re [ COMPARATORTRIM ] = new RegExp ( src [ COMPARATORTRIM ] , 'g' )
var comparatorTrimReplace = '$1$2$3'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Something like `1.2.3 - 1.2.4`
// Note that these all use the loose form, because they'll be
// checked against either the strict or loose comparator form
// later.
var HYPHENRANGE = R ++
src [ HYPHENRANGE ] = '^\\s*(' + src [ XRANGEPLAIN ] + ')' +
'\\s+-\\s+' +
'(' + src [ XRANGEPLAIN ] + ')' +
'\\s*$'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var HYPHENRANGELOOSE = R ++
src [ HYPHENRANGELOOSE ] = '^\\s*(' + src [ XRANGEPLAINLOOSE ] + ')' +
'\\s+-\\s+' +
'(' + src [ XRANGEPLAINLOOSE ] + ')' +
'\\s*$'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Star ranges basically just allow anything at all.
var STAR = R ++
src [ STAR ] = '(<|>)?=?\\s*\\*'
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Compile to actual regexp objects.
// All are flag-free, unless they were created above with a flag.
for ( var i = 0 ; i < R ; i ++ ) {
debug ( i , src [ i ] )
if ( ! re [ i ] ) {
re [ i ] = new RegExp ( src [ i ] )
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . parse = parse
function parse ( version , options ) {
if ( ! options || typeof options !== 'object' ) {
options = {
loose : ! ! options ,
includePrerelease : false
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( version instanceof SemVer ) {
return version
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( typeof version !== 'string' ) {
return null
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( version . length > MAX _LENGTH ) {
return null
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var r = options . loose ? re [ LOOSE ] : re [ FULL ]
if ( ! r . test ( version ) ) {
return null
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
try {
return new SemVer ( version , options )
} catch ( er ) {
return null
}
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
exports . valid = valid
function valid ( version , options ) {
var v = parse ( version , options )
return v ? v . version : null
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
exports . clean = clean
function clean ( version , options ) {
var s = parse ( version . trim ( ) . replace ( /^[=v]+/ , '' ) , options )
return s ? s . version : null
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
exports . SemVer = SemVer
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
function SemVer ( version , options ) {
if ( ! options || typeof options !== 'object' ) {
options = {
loose : ! ! options ,
includePrerelease : false
}
}
if ( version instanceof SemVer ) {
if ( version . loose === options . loose ) {
return version
} else {
version = version . version
}
} else if ( typeof version !== 'string' ) {
throw new TypeError ( 'Invalid Version: ' + version )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( version . length > MAX _LENGTH ) {
throw new TypeError ( 'version is longer than ' + MAX _LENGTH + ' characters' )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( ! ( this instanceof SemVer ) ) {
return new SemVer ( version , options )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
debug ( 'SemVer' , version , options )
this . options = options
this . loose = ! ! options . loose
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var m = version . trim ( ) . match ( options . loose ? re [ LOOSE ] : re [ FULL ] )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! m ) {
throw new TypeError ( 'Invalid Version: ' + version )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
this . raw = version
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// these are actually numbers
this . major = + m [ 1 ]
this . minor = + m [ 2 ]
this . patch = + m [ 3 ]
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( this . major > MAX _SAFE _INTEGER || this . major < 0 ) {
throw new TypeError ( 'Invalid major version' )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( this . minor > MAX _SAFE _INTEGER || this . minor < 0 ) {
throw new TypeError ( 'Invalid minor version' )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( this . patch > MAX _SAFE _INTEGER || this . patch < 0 ) {
throw new TypeError ( 'Invalid patch version' )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// numberify any prerelease numeric ids
if ( ! m [ 4 ] ) {
this . prerelease = [ ]
} else {
this . prerelease = m [ 4 ] . split ( '.' ) . map ( function ( id ) {
if ( /^[0-9]+$/ . test ( id ) ) {
var num = + id
if ( num >= 0 && num < MAX _SAFE _INTEGER ) {
return num
}
}
return id
} )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
this . build = m [ 5 ] ? m [ 5 ] . split ( '.' ) : [ ]
this . format ( )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
SemVer . prototype . format = function ( ) {
this . version = this . major + '.' + this . minor + '.' + this . patch
if ( this . prerelease . length ) {
this . version += '-' + this . prerelease . join ( '.' )
}
return this . version
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
SemVer . prototype . toString = function ( ) {
return this . version
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
SemVer . prototype . compare = function ( other ) {
debug ( 'SemVer.compare' , this . version , this . options , other )
if ( ! ( other instanceof SemVer ) ) {
other = new SemVer ( other , this . options )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return this . compareMain ( other ) || this . comparePre ( other )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
SemVer . prototype . compareMain = function ( other ) {
if ( ! ( other instanceof SemVer ) ) {
other = new SemVer ( other , this . options )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return compareIdentifiers ( this . major , other . major ) ||
compareIdentifiers ( this . minor , other . minor ) ||
compareIdentifiers ( this . patch , other . patch )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
SemVer . prototype . comparePre = function ( other ) {
if ( ! ( other instanceof SemVer ) ) {
other = new SemVer ( other , this . options )
2022-10-11 16:10:23 +02:00
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// NOT having a prerelease is > having one
if ( this . prerelease . length && ! other . prerelease . length ) {
return - 1
} else if ( ! this . prerelease . length && other . prerelease . length ) {
return 1
} else if ( ! this . prerelease . length && ! other . prerelease . length ) {
return 0
}
var i = 0
do {
var a = this . prerelease [ i ]
var b = other . prerelease [ i ]
debug ( 'prerelease compare' , i , a , b )
if ( a === undefined && b === undefined ) {
return 0
} else if ( b === undefined ) {
return 1
} else if ( a === undefined ) {
return - 1
} else if ( a === b ) {
continue
} else {
return compareIdentifiers ( a , b )
}
} while ( ++ i )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
// preminor will bump the version up to the next minor release, and immediately
// down to pre-release. premajor and prepatch work the same way.
SemVer . prototype . inc = function ( release , identifier ) {
switch ( release ) {
case 'premajor' :
this . prerelease . length = 0
this . patch = 0
this . minor = 0
this . major ++
this . inc ( 'pre' , identifier )
break
case 'preminor' :
this . prerelease . length = 0
this . patch = 0
this . minor ++
this . inc ( 'pre' , identifier )
break
case 'prepatch' :
// If this is already a prerelease, it will bump to the next version
// drop any prereleases that might already exist, since they are not
// relevant at this point.
this . prerelease . length = 0
this . inc ( 'patch' , identifier )
this . inc ( 'pre' , identifier )
break
// If the input is a non-prerelease version, this acts the same as
// prepatch.
case 'prerelease' :
if ( this . prerelease . length === 0 ) {
this . inc ( 'patch' , identifier )
}
this . inc ( 'pre' , identifier )
break
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
case 'major' :
// If this is a pre-major version, bump up to the same major version.
// Otherwise increment major.
// 1.0.0-5 bumps to 1.0.0
// 1.1.0 bumps to 2.0.0
if ( this . minor !== 0 ||
this . patch !== 0 ||
this . prerelease . length === 0 ) {
this . major ++
}
this . minor = 0
this . patch = 0
this . prerelease = [ ]
break
case 'minor' :
// If this is a pre-minor version, bump up to the same minor version.
// Otherwise increment minor.
// 1.2.0-5 bumps to 1.2.0
// 1.2.1 bumps to 1.3.0
if ( this . patch !== 0 || this . prerelease . length === 0 ) {
this . minor ++
}
this . patch = 0
this . prerelease = [ ]
break
case 'patch' :
// If this is not a pre-release version, it will increment the patch.
// If it is a pre-release it will bump up to the same patch version.
// 1.2.0-5 patches to 1.2.0
// 1.2.0 patches to 1.2.1
if ( this . prerelease . length === 0 ) {
this . patch ++
}
this . prerelease = [ ]
break
// This probably shouldn't be used publicly.
// 1.0.0 "pre" would become 1.0.0-0 which is the wrong direction.
case 'pre' :
if ( this . prerelease . length === 0 ) {
this . prerelease = [ 0 ]
} else {
var i = this . prerelease . length
while ( -- i >= 0 ) {
if ( typeof this . prerelease [ i ] === 'number' ) {
this . prerelease [ i ] ++
i = - 2
}
}
if ( i === - 1 ) {
// didn't increment anything
this . prerelease . push ( 0 )
}
}
if ( identifier ) {
// 1.2.0-beta.1 bumps to 1.2.0-beta.2,
// 1.2.0-beta.fooblz or 1.2.0-beta bumps to 1.2.0-beta.0
if ( this . prerelease [ 0 ] === identifier ) {
if ( isNaN ( this . prerelease [ 1 ] ) ) {
this . prerelease = [ identifier , 0 ]
}
} else {
this . prerelease = [ identifier , 0 ]
}
}
break
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
default :
throw new Error ( 'invalid increment argument: ' + release )
}
this . format ( )
this . raw = this . version
return this
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
exports . inc = inc
function inc ( version , release , loose , identifier ) {
if ( typeof ( loose ) === 'string' ) {
identifier = loose
loose = undefined
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
try {
return new SemVer ( version , loose ) . inc ( release , identifier ) . version
} catch ( er ) {
return null
}
}
exports . diff = diff
function diff ( version1 , version2 ) {
if ( eq ( version1 , version2 ) ) {
return null
} else {
var v1 = parse ( version1 )
var v2 = parse ( version2 )
var prefix = ''
if ( v1 . prerelease . length || v2 . prerelease . length ) {
prefix = 'pre'
var defaultResult = 'prerelease'
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
for ( var key in v1 ) {
if ( key === 'major' || key === 'minor' || key === 'patch' ) {
if ( v1 [ key ] !== v2 [ key ] ) {
return prefix + key
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
}
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
return defaultResult // may be undefined
}
2022-10-12 17:48:05 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . compareIdentifiers = compareIdentifiers
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var numeric = /^[0-9]+$/
function compareIdentifiers ( a , b ) {
var anum = numeric . test ( a )
var bnum = numeric . test ( b )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( anum && bnum ) {
a = + a
b = + b
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return a === b ? 0
: ( anum && ! bnum ) ? - 1
: ( bnum && ! anum ) ? 1
: a < b ? - 1
: 1
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . rcompareIdentifiers = rcompareIdentifiers
function rcompareIdentifiers ( a , b ) {
return compareIdentifiers ( b , a )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . major = major
function major ( a , loose ) {
return new SemVer ( a , loose ) . major
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . minor = minor
function minor ( a , loose ) {
return new SemVer ( a , loose ) . minor
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . patch = patch
function patch ( a , loose ) {
return new SemVer ( a , loose ) . patch
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . compare = compare
function compare ( a , b , loose ) {
return new SemVer ( a , loose ) . compare ( new SemVer ( b , loose ) )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . compareLoose = compareLoose
function compareLoose ( a , b ) {
return compare ( a , b , true )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . rcompare = rcompare
function rcompare ( a , b , loose ) {
return compare ( b , a , loose )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . sort = sort
function sort ( list , loose ) {
return list . sort ( function ( a , b ) {
return exports . compare ( a , b , loose )
} )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
exports . rsort = rsort
function rsort ( list , loose ) {
return list . sort ( function ( a , b ) {
return exports . rcompare ( a , b , loose )
} )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
exports . gt = gt
function gt ( a , b , loose ) {
return compare ( a , b , loose ) > 0
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . lt = lt
function lt ( a , b , loose ) {
return compare ( a , b , loose ) < 0
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . eq = eq
function eq ( a , b , loose ) {
return compare ( a , b , loose ) === 0
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . neq = neq
function neq ( a , b , loose ) {
return compare ( a , b , loose ) !== 0
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . gte = gte
function gte ( a , b , loose ) {
return compare ( a , b , loose ) >= 0
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . lte = lte
function lte ( a , b , loose ) {
return compare ( a , b , loose ) <= 0
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . cmp = cmp
function cmp ( a , op , b , loose ) {
switch ( op ) {
case '===' :
if ( typeof a === 'object' )
a = a . version
if ( typeof b === 'object' )
b = b . version
return a === b
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
case '!==' :
if ( typeof a === 'object' )
a = a . version
if ( typeof b === 'object' )
b = b . version
return a !== b
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
case '' :
case '=' :
case '==' :
return eq ( a , b , loose )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
case '!=' :
return neq ( a , b , loose )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
case '>' :
return gt ( a , b , loose )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
case '>=' :
return gte ( a , b , loose )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
case '<' :
return lt ( a , b , loose )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
case '<=' :
return lte ( a , b , loose )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
default :
throw new TypeError ( 'Invalid operator: ' + op )
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . Comparator = Comparator
function Comparator ( comp , options ) {
if ( ! options || typeof options !== 'object' ) {
options = {
loose : ! ! options ,
includePrerelease : false
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( comp instanceof Comparator ) {
if ( comp . loose === ! ! options . loose ) {
return comp
} else {
comp = comp . value
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! ( this instanceof Comparator ) ) {
return new Comparator ( comp , options )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
debug ( 'comparator' , comp , options )
this . options = options
this . loose = ! ! options . loose
this . parse ( comp )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( this . semver === ANY ) {
this . value = ''
} else {
this . value = this . operator + this . semver . version
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
debug ( 'comp' , this )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var ANY = { }
Comparator . prototype . parse = function ( comp ) {
var r = this . options . loose ? re [ COMPARATORLOOSE ] : re [ COMPARATOR ]
var m = comp . match ( r )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! m ) {
throw new TypeError ( 'Invalid comparator: ' + comp )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
this . operator = m [ 1 ]
if ( this . operator === '=' ) {
this . operator = ''
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// if it literally is just '>' or '' then allow anything.
if ( ! m [ 2 ] ) {
this . semver = ANY
} else {
this . semver = new SemVer ( m [ 2 ] , this . options . loose )
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Comparator . prototype . toString = function ( ) {
return this . value
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Comparator . prototype . test = function ( version ) {
debug ( 'Comparator.test' , version , this . options . loose )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( this . semver === ANY ) {
return true
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( typeof version === 'string' ) {
version = new SemVer ( version , this . options )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return cmp ( version , this . operator , this . semver , this . options )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Comparator . prototype . intersects = function ( comp , options ) {
if ( ! ( comp instanceof Comparator ) ) {
throw new TypeError ( 'a Comparator is required' )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! options || typeof options !== 'object' ) {
options = {
loose : ! ! options ,
includePrerelease : false
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var rangeTmp
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( this . operator === '' ) {
rangeTmp = new Range ( comp . value , options )
return satisfies ( this . value , rangeTmp , options )
} else if ( comp . operator === '' ) {
rangeTmp = new Range ( this . value , options )
return satisfies ( comp . semver , rangeTmp , options )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var sameDirectionIncreasing =
( this . operator === '>=' || this . operator === '>' ) &&
( comp . operator === '>=' || comp . operator === '>' )
var sameDirectionDecreasing =
( this . operator === '<=' || this . operator === '<' ) &&
( comp . operator === '<=' || comp . operator === '<' )
var sameSemVer = this . semver . version === comp . semver . version
var differentDirectionsInclusive =
( this . operator === '>=' || this . operator === '<=' ) &&
( comp . operator === '>=' || comp . operator === '<=' )
var oppositeDirectionsLessThan =
cmp ( this . semver , '<' , comp . semver , options ) &&
( ( this . operator === '>=' || this . operator === '>' ) &&
( comp . operator === '<=' || comp . operator === '<' ) )
var oppositeDirectionsGreaterThan =
cmp ( this . semver , '>' , comp . semver , options ) &&
( ( this . operator === '<=' || this . operator === '<' ) &&
( comp . operator === '>=' || comp . operator === '>' ) )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return sameDirectionIncreasing || sameDirectionDecreasing ||
( sameSemVer && differentDirectionsInclusive ) ||
oppositeDirectionsLessThan || oppositeDirectionsGreaterThan
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . Range = Range
function Range ( range , options ) {
if ( ! options || typeof options !== 'object' ) {
options = {
loose : ! ! options ,
includePrerelease : false
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( range instanceof Range ) {
if ( range . loose === ! ! options . loose &&
range . includePrerelease === ! ! options . includePrerelease ) {
return range
} else {
return new Range ( range . raw , options )
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( range instanceof Comparator ) {
return new Range ( range . value , options )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! ( this instanceof Range ) ) {
return new Range ( range , options )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
this . options = options
this . loose = ! ! options . loose
this . includePrerelease = ! ! options . includePrerelease
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// First, split based on boolean or ||
this . raw = range
this . set = range . split ( /\s*\|\|\s*/ ) . map ( function ( range ) {
return this . parseRange ( range . trim ( ) )
} , this ) . filter ( function ( c ) {
// throw out any that are not relevant for whatever reason
return c . length
} )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! this . set . length ) {
throw new TypeError ( 'Invalid SemVer Range: ' + range )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
this . format ( )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
Range . prototype . format = function ( ) {
this . range = this . set . map ( function ( comps ) {
return comps . join ( ' ' ) . trim ( )
} ) . join ( '||' ) . trim ( )
return this . range
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
Range . prototype . toString = function ( ) {
return this . range
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
Range . prototype . parseRange = function ( range ) {
var loose = this . options . loose
range = range . trim ( )
// `1.2.3 - 1.2.4` => `>=1.2.3 <=1.2.4`
var hr = loose ? re [ HYPHENRANGELOOSE ] : re [ HYPHENRANGE ]
range = range . replace ( hr , hyphenReplace )
debug ( 'hyphen replace' , range )
// `> 1.2.3 < 1.2.5` => `>1.2.3 <1.2.5`
range = range . replace ( re [ COMPARATORTRIM ] , comparatorTrimReplace )
debug ( 'comparator trim' , range , re [ COMPARATORTRIM ] )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// `~ 1.2.3` => `~1.2.3`
range = range . replace ( re [ TILDETRIM ] , tildeTrimReplace )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// `^ 1.2.3` => `^1.2.3`
range = range . replace ( re [ CARETTRIM ] , caretTrimReplace )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// normalize spaces
range = range . split ( /\s+/ ) . join ( ' ' )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// At this point, the range is completely trimmed and
// ready to be split into comparators.
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var compRe = loose ? re [ COMPARATORLOOSE ] : re [ COMPARATOR ]
var set = range . split ( ' ' ) . map ( function ( comp ) {
return parseComparator ( comp , this . options )
} , this ) . join ( ' ' ) . split ( /\s+/ )
if ( this . options . loose ) {
// in loose mode, throw out any that are not valid comparators
set = set . filter ( function ( comp ) {
return ! ! comp . match ( compRe )
2022-10-11 16:10:23 +02:00
} )
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
set = set . map ( function ( comp ) {
return new Comparator ( comp , this . options )
} , this )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return set
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
Range . prototype . intersects = function ( range , options ) {
if ( ! ( range instanceof Range ) ) {
throw new TypeError ( 'a Range is required' )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
return this . set . some ( function ( thisComparators ) {
return thisComparators . every ( function ( thisComparator ) {
return range . set . some ( function ( rangeComparators ) {
return rangeComparators . every ( function ( rangeComparator ) {
return thisComparator . intersects ( rangeComparator , options )
} )
} )
} )
} )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
// Mostly just for testing and legacy API reasons
exports . toComparators = toComparators
function toComparators ( range , options ) {
return new Range ( range , options ) . set . map ( function ( comp ) {
return comp . map ( function ( c ) {
return c . value
} ) . join ( ' ' ) . trim ( ) . split ( ' ' )
} )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// comprised of xranges, tildes, stars, and gtlt's at this point.
// already replaced the hyphen ranges
// turn into a set of JUST comparators.
function parseComparator ( comp , options ) {
debug ( 'comp' , comp , options )
comp = replaceCarets ( comp , options )
debug ( 'caret' , comp )
comp = replaceTildes ( comp , options )
debug ( 'tildes' , comp )
comp = replaceXRanges ( comp , options )
debug ( 'xrange' , comp )
comp = replaceStars ( comp , options )
debug ( 'stars' , comp )
return comp
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function isX ( id ) {
return ! id || id . toLowerCase ( ) === 'x' || id === '*'
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
// ~, ~> --> * (any, kinda silly)
// ~2, ~2.x, ~2.x.x, ~>2, ~>2.x ~>2.x.x --> >=2.0.0 <3.0.0
// ~2.0, ~2.0.x, ~>2.0, ~>2.0.x --> >=2.0.0 <2.1.0
// ~1.2, ~1.2.x, ~>1.2, ~>1.2.x --> >=1.2.0 <1.3.0
// ~1.2.3, ~>1.2.3 --> >=1.2.3 <1.3.0
// ~1.2.0, ~>1.2.0 --> >=1.2.0 <1.3.0
function replaceTildes ( comp , options ) {
return comp . trim ( ) . split ( /\s+/ ) . map ( function ( comp ) {
return replaceTilde ( comp , options )
} ) . join ( ' ' )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function replaceTilde ( comp , options ) {
var r = options . loose ? re [ TILDELOOSE ] : re [ TILDE ]
return comp . replace ( r , function ( _ , M , m , p , pr ) {
debug ( 'tilde' , comp , _ , M , m , p , pr )
var ret
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( isX ( M ) ) {
ret = ''
} else if ( isX ( m ) ) {
ret = '>=' + M + '.0.0 <' + ( + M + 1 ) + '.0.0'
} else if ( isX ( p ) ) {
// ~1.2 == >=1.2.0 <1.3.0
ret = '>=' + M + '.' + m + '.0 <' + M + '.' + ( + m + 1 ) + '.0'
} else if ( pr ) {
debug ( 'replaceTilde pr' , pr )
ret = '>=' + M + '.' + m + '.' + p + '-' + pr +
' <' + M + '.' + ( + m + 1 ) + '.0'
} else {
// ~1.2.3 == >=1.2.3 <1.3.0
ret = '>=' + M + '.' + m + '.' + p +
' <' + M + '.' + ( + m + 1 ) + '.0'
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
debug ( 'tilde return' , ret )
return ret
} )
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
// ^ --> * (any, kinda silly)
// ^2, ^2.x, ^2.x.x --> >=2.0.0 <3.0.0
// ^2.0, ^2.0.x --> >=2.0.0 <3.0.0
// ^1.2, ^1.2.x --> >=1.2.0 <2.0.0
// ^1.2.3 --> >=1.2.3 <2.0.0
// ^1.2.0 --> >=1.2.0 <2.0.0
function replaceCarets ( comp , options ) {
return comp . trim ( ) . split ( /\s+/ ) . map ( function ( comp ) {
return replaceCaret ( comp , options )
} ) . join ( ' ' )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
function replaceCaret ( comp , options ) {
debug ( 'caret' , comp , options )
var r = options . loose ? re [ CARETLOOSE ] : re [ CARET ]
return comp . replace ( r , function ( _ , M , m , p , pr ) {
debug ( 'caret' , comp , _ , M , m , p , pr )
var ret
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( isX ( M ) ) {
ret = ''
} else if ( isX ( m ) ) {
ret = '>=' + M + '.0.0 <' + ( + M + 1 ) + '.0.0'
} else if ( isX ( p ) ) {
if ( M === '0' ) {
ret = '>=' + M + '.' + m + '.0 <' + M + '.' + ( + m + 1 ) + '.0'
} else {
ret = '>=' + M + '.' + m + '.0 <' + ( + M + 1 ) + '.0.0'
}
} else if ( pr ) {
debug ( 'replaceCaret pr' , pr )
if ( M === '0' ) {
if ( m === '0' ) {
ret = '>=' + M + '.' + m + '.' + p + '-' + pr +
' <' + M + '.' + m + '.' + ( + p + 1 )
2022-10-12 17:48:05 +02:00
} else {
2024-05-19 08:24:38 +02:00
ret = '>=' + M + '.' + m + '.' + p + '-' + pr +
' <' + M + '.' + ( + m + 1 ) + '.0'
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
} else {
ret = '>=' + M + '.' + m + '.' + p + '-' + pr +
' <' + ( + M + 1 ) + '.0.0'
}
} else {
debug ( 'no pr' )
if ( M === '0' ) {
if ( m === '0' ) {
ret = '>=' + M + '.' + m + '.' + p +
' <' + M + '.' + m + '.' + ( + p + 1 )
} else {
ret = '>=' + M + '.' + m + '.' + p +
' <' + M + '.' + ( + m + 1 ) + '.0'
}
} else {
ret = '>=' + M + '.' + m + '.' + p +
' <' + ( + M + 1 ) + '.0.0'
2022-10-12 17:48:05 +02:00
}
}
2024-05-19 08:24:38 +02:00
debug ( 'caret return' , ret )
return ret
2022-10-12 17:48:05 +02:00
} )
}
2024-05-19 08:24:38 +02:00
function replaceXRanges ( comp , options ) {
debug ( 'replaceXRanges' , comp , options )
return comp . split ( /\s+/ ) . map ( function ( comp ) {
return replaceXRange ( comp , options )
} ) . join ( ' ' )
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
function replaceXRange ( comp , options ) {
comp = comp . trim ( )
var r = options . loose ? re [ XRANGELOOSE ] : re [ XRANGE ]
return comp . replace ( r , function ( ret , gtlt , M , m , p , pr ) {
debug ( 'xRange' , comp , ret , gtlt , M , m , p , pr )
var xM = isX ( M )
var xm = xM || isX ( m )
var xp = xm || isX ( p )
var anyX = xp
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( gtlt === '=' && anyX ) {
gtlt = ''
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( xM ) {
if ( gtlt === '>' || gtlt === '<' ) {
// nothing is allowed
ret = '<0.0.0'
} else {
// nothing is forbidden
ret = '*'
}
} else if ( gtlt && anyX ) {
// we know patch is an x, because we have any x at all.
// replace X with 0
if ( xm ) {
m = 0
}
p = 0
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( gtlt === '>' ) {
// >1 => >=2.0.0
// >1.2 => >=1.3.0
// >1.2.3 => >= 1.2.4
gtlt = '>='
if ( xm ) {
M = + M + 1
m = 0
p = 0
} else {
m = + m + 1
p = 0
}
} else if ( gtlt === '<=' ) {
// <=0.7.x is actually <0.8.0, since any 0.7.x should
// pass. Similarly, <=7.x is actually <8.0.0, etc.
gtlt = '<'
if ( xm ) {
M = + M + 1
} else {
m = + m + 1
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
ret = gtlt + M + '.' + m + '.' + p
} else if ( xm ) {
ret = '>=' + M + '.0.0 <' + ( + M + 1 ) + '.0.0'
} else if ( xp ) {
ret = '>=' + M + '.' + m + '.0 <' + M + '.' + ( + m + 1 ) + '.0'
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
debug ( 'xRange return' , ret )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return ret
} )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Because * is AND-ed with everything else in the comparator,
// and '' means "any version", just remove the *s entirely.
function replaceStars ( comp , options ) {
debug ( 'replaceStars' , comp , options )
// Looseness is ignored here. star is always as loose as it gets!
return comp . trim ( ) . replace ( re [ STAR ] , '' )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// This function is passed to string.replace(re[HYPHENRANGE])
// M, m, patch, prerelease, build
// 1.2 - 3.4.5 => >=1.2.0 <=3.4.5
// 1.2.3 - 3.4 => >=1.2.0 <3.5.0 Any 3.4.x will do
// 1.2 - 3.4 => >=1.2.0 <3.5.0
function hyphenReplace ( $0 ,
from , fM , fm , fp , fpr , fb ,
to , tM , tm , tp , tpr , tb ) {
if ( isX ( fM ) ) {
from = ''
} else if ( isX ( fm ) ) {
from = '>=' + fM + '.0.0'
} else if ( isX ( fp ) ) {
from = '>=' + fM + '.' + fm + '.0'
} else {
from = '>=' + from
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( isX ( tM ) ) {
to = ''
} else if ( isX ( tm ) ) {
to = '<' + ( + tM + 1 ) + '.0.0'
} else if ( isX ( tp ) ) {
to = '<' + tM + '.' + ( + tm + 1 ) + '.0'
} else if ( tpr ) {
to = '<=' + tM + '.' + tm + '.' + tp + '-' + tpr
} else {
to = '<=' + to
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
return ( from + ' ' + to ) . trim ( )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
// if ANY of the sets match ALL of its comparators, then pass
Range . prototype . test = function ( version ) {
if ( ! version ) {
return false
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( typeof version === 'string' ) {
version = new SemVer ( version , this . options )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
for ( var i = 0 ; i < this . set . length ; i ++ ) {
if ( testSet ( this . set [ i ] , version , this . options ) ) {
return true
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
}
return false
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
function testSet ( set , version , options ) {
for ( var i = 0 ; i < set . length ; i ++ ) {
if ( ! set [ i ] . test ( version ) ) {
return false
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( version . prerelease . length && ! options . includePrerelease ) {
// Find the set of versions that are allowed to have prereleases
// For example, ^1.2.3-pr.1 desugars to >=1.2.3-pr.1 <2.0.0
// That should allow `1.2.3-pr.2` to pass.
// However, `1.2.4-alpha.notready` should NOT be allowed,
// even though it's within the range set by the comparators.
for ( i = 0 ; i < set . length ; i ++ ) {
debug ( set [ i ] . semver )
if ( set [ i ] . semver === ANY ) {
continue
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( set [ i ] . semver . prerelease . length > 0 ) {
var allowed = set [ i ] . semver
if ( allowed . major === version . major &&
allowed . minor === version . minor &&
allowed . patch === version . patch ) {
return true
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
}
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
// Version has a -pre, but it's not one of the ones we like.
return false
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return true
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
exports . satisfies = satisfies
function satisfies ( version , range , options ) {
try {
range = new Range ( range , options )
} catch ( er ) {
return false
}
return range . test ( version )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
exports . maxSatisfying = maxSatisfying
function maxSatisfying ( versions , range , options ) {
var max = null
var maxSV = null
try {
var rangeObj = new Range ( range , options )
} catch ( er ) {
return null
}
versions . forEach ( function ( v ) {
if ( rangeObj . test ( v ) ) {
// satisfies(v, range, options)
if ( ! max || maxSV . compare ( v ) === - 1 ) {
// compare(max, v, true)
max = v
maxSV = new SemVer ( max , options )
}
}
} )
return max
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
exports . minSatisfying = minSatisfying
function minSatisfying ( versions , range , options ) {
var min = null
var minSV = null
try {
var rangeObj = new Range ( range , options )
} catch ( er ) {
return null
}
versions . forEach ( function ( v ) {
if ( rangeObj . test ( v ) ) {
// satisfies(v, range, options)
if ( ! min || minSV . compare ( v ) === 1 ) {
// compare(min, v, true)
min = v
minSV = new SemVer ( min , options )
}
}
} )
return min
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
exports . minVersion = minVersion
function minVersion ( range , loose ) {
range = new Range ( range , loose )
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var minver = new SemVer ( '0.0.0' )
if ( range . test ( minver ) ) {
return minver
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
minver = new SemVer ( '0.0.0-0' )
if ( range . test ( minver ) ) {
return minver
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
minver = null
for ( var i = 0 ; i < range . set . length ; ++ i ) {
var comparators = range . set [ i ]
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
comparators . forEach ( function ( comparator ) {
// Clone to avoid manipulating the comparator's semver object.
var compver = new SemVer ( comparator . semver . version )
switch ( comparator . operator ) {
case '>' :
if ( compver . prerelease . length === 0 ) {
compver . patch ++
} else {
compver . prerelease . push ( 0 )
}
compver . raw = compver . format ( )
/* fallthrough */
case '' :
case '>=' :
if ( ! minver || gt ( minver , compver ) ) {
minver = compver
}
break
case '<' :
case '<=' :
/* Ignore maximum versions */
break
/* istanbul ignore next */
default :
throw new Error ( 'Unexpected operation: ' + comparator . operator )
}
} )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( minver && range . test ( minver ) ) {
return minver
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
return null
}
exports . validRange = validRange
function validRange ( range , options ) {
try {
// Return '*' instead of '' so that truthiness works.
// This will throw if it's invalid anyway
return new Range ( range , options ) . range || '*'
} catch ( er ) {
return null
2021-12-01 13:39:57 +01:00
}
2022-10-11 16:10:23 +02:00
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
// Determine if version is less than all the versions possible in the range
exports . ltr = ltr
function ltr ( version , range , options ) {
return outside ( version , range , '<' , options )
}
// Determine if version is greater than all the versions possible in the range.
exports . gtr = gtr
function gtr ( version , range , options ) {
return outside ( version , range , '>' , options )
}
exports . outside = outside
function outside ( version , range , hilo , options ) {
version = new SemVer ( version , options )
range = new Range ( range , options )
var gtfn , ltefn , ltfn , comp , ecomp
switch ( hilo ) {
case '>' :
gtfn = gt
ltefn = lte
ltfn = lt
comp = '>'
ecomp = '>='
break
case '<' :
gtfn = lt
ltefn = gte
ltfn = gt
comp = '<'
ecomp = '<='
break
default :
throw new TypeError ( 'Must provide a hilo val of "<" or ">"' )
}
// If it satisifes the range it is not outside
if ( satisfies ( version , range , options ) ) {
2022-10-11 16:10:23 +02:00
return false
}
2024-05-19 08:24:38 +02:00
// From now on, variable terms are as if we're in "gtr" mode.
// but note that everything is flipped for the "ltr" function.
for ( var i = 0 ; i < range . set . length ; ++ i ) {
var comparators = range . set [ i ]
var high = null
var low = null
comparators . forEach ( function ( comparator ) {
if ( comparator . semver === ANY ) {
comparator = new Comparator ( '>=0.0.0' )
}
high = high || comparator
low = low || comparator
if ( gtfn ( comparator . semver , high . semver , options ) ) {
high = comparator
} else if ( ltfn ( comparator . semver , low . semver , options ) ) {
low = comparator
}
} )
// If the edge version comparator has a operator then our version
// isn't outside it
if ( high . operator === comp || high . operator === ecomp ) {
return false
}
// If the lowest version comparator has an operator and our version
// is less than it then it isn't higher than the range
if ( ( ! low . operator || low . operator === comp ) &&
ltefn ( version , low . semver ) ) {
return false
} else if ( low . operator === ecomp && ltfn ( version , low . semver ) ) {
return false
}
}
return true
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
exports . prerelease = prerelease
function prerelease ( version , options ) {
var parsed = parse ( version , options )
return ( parsed && parsed . prerelease . length ) ? parsed . prerelease : null
2022-10-11 16:10:23 +02:00
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
exports . intersects = intersects
function intersects ( r1 , r2 , options ) {
r1 = new Range ( r1 , options )
r2 = new Range ( r2 , options )
return r1 . intersects ( r2 )
}
exports . coerce = coerce
function coerce ( version ) {
if ( version instanceof SemVer ) {
return version
}
if ( typeof version !== 'string' ) {
return null
}
var match = version . match ( re [ COERCE ] )
if ( match == null ) {
return null
}
return parse ( match [ 1 ] +
'.' + ( match [ 2 ] || '0' ) +
'.' + ( match [ 3 ] || '0' ) )
2022-10-11 16:10:23 +02:00
}
2021-12-01 13:39:57 +01:00
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 7032 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2021-12-01 13:39:57 +01:00
2022-10-11 16:10:23 +02:00
"use strict" ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var shebangRegex = _ _nccwpck _require _ _ ( 2638 ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
module . exports = function ( str ) {
var match = str . match ( shebangRegex ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
if ( ! match ) {
return null ;
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var arr = match [ 0 ] . replace ( /#! ?/ , '' ) . split ( ' ' ) ;
var bin = arr [ 0 ] . split ( '/' ) . pop ( ) ;
var arg = arr [ 1 ] ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
return ( bin === 'env' ?
arg :
bin + ( arg ? ' ' + arg : '' )
) ;
} ;
2022-10-11 16:10:23 +02:00
2021-12-01 13:39:57 +01:00
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 2638 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
module . exports = /^#!.*/ ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 4931 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
// Note: since nyc uses this module to output coverage, any lines
// that are in the direct sync flow of nyc's outputCoverage are
// ignored, since we can never get coverage for them.
// grab a reference to node's real process object right away
var process = global . process
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
const processOk = function ( process ) {
return process &&
typeof process === 'object' &&
typeof process . removeListener === 'function' &&
typeof process . emit === 'function' &&
typeof process . reallyExit === 'function' &&
typeof process . listeners === 'function' &&
typeof process . kill === 'function' &&
typeof process . pid === 'number' &&
typeof process . on === 'function'
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
// some kind of non-node environment, just no-op
/* istanbul ignore if */
if ( ! processOk ( process ) ) {
module . exports = function ( ) {
return function ( ) { }
}
} else {
var assert = _ _nccwpck _require _ _ ( 9491 )
var signals = _ _nccwpck _require _ _ ( 3710 )
var isWin = /^win/i . test ( process . platform )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var EE = _ _nccwpck _require _ _ ( 2361 )
/* istanbul ignore if */
if ( typeof EE !== 'function' ) {
EE = EE . EventEmitter
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var emitter
if ( process . _ _signal _exit _emitter _ _ ) {
emitter = process . _ _signal _exit _emitter _ _
} else {
emitter = process . _ _signal _exit _emitter _ _ = new EE ( )
emitter . count = 0
emitter . emitted = { }
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
// Because this emitter is a global, we have to check to see if a
// previous version of this library failed to enable infinite listeners.
// I know what you're about to say. But literally everything about
// signal-exit is a compromise with evil. Get used to it.
if ( ! emitter . infinite ) {
emitter . setMaxListeners ( Infinity )
emitter . infinite = true
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
module . exports = function ( cb , opts ) {
/* istanbul ignore if */
if ( ! processOk ( global . process ) ) {
return function ( ) { }
}
assert . equal ( typeof cb , 'function' , 'a callback must be provided for exit handler' )
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( loaded === false ) {
load ( )
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var ev = 'exit'
if ( opts && opts . alwaysLast ) {
ev = 'afterexit'
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var remove = function ( ) {
emitter . removeListener ( ev , cb )
if ( emitter . listeners ( 'exit' ) . length === 0 &&
emitter . listeners ( 'afterexit' ) . length === 0 ) {
unload ( )
}
}
emitter . on ( ev , cb )
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return remove
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var unload = function unload ( ) {
if ( ! loaded || ! processOk ( global . process ) ) {
return
}
loaded = false
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
signals . forEach ( function ( sig ) {
try {
process . removeListener ( sig , sigListeners [ sig ] )
} catch ( er ) { }
} )
process . emit = originalProcessEmit
process . reallyExit = originalProcessReallyExit
emitter . count -= 1
}
module . exports . unload = unload
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var emit = function emit ( event , code , signal ) {
/* istanbul ignore if */
if ( emitter . emitted [ event ] ) {
return
}
emitter . emitted [ event ] = true
emitter . emit ( event , code , signal )
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// { <signal>: <listener fn>, ... }
var sigListeners = { }
signals . forEach ( function ( sig ) {
sigListeners [ sig ] = function listener ( ) {
/* istanbul ignore if */
if ( ! processOk ( global . process ) ) {
return
}
// If there are no other listeners, an exit is coming!
// Simplest way: remove us and then re-send the signal.
// We know that this will kill the process, so we can
// safely emit now.
var listeners = process . listeners ( sig )
if ( listeners . length === emitter . count ) {
unload ( )
emit ( 'exit' , null , sig )
/* istanbul ignore next */
emit ( 'afterexit' , null , sig )
/* istanbul ignore next */
if ( isWin && sig === 'SIGHUP' ) {
// "SIGHUP" throws an `ENOSYS` error on Windows,
// so use a supported signal instead
sig = 'SIGINT'
}
/* istanbul ignore next */
process . kill ( process . pid , sig )
}
}
} )
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
module . exports . signals = function ( ) {
return signals
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var loaded = false
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var load = function load ( ) {
if ( loaded || ! processOk ( global . process ) ) {
return
}
loaded = true
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
// This is the number of onSignalExit's that are in play.
// It's important so that we can count the correct number of
// listeners on signals, and don't wait for the other one to
// handle it instead of us.
emitter . count += 1
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
signals = signals . filter ( function ( sig ) {
try {
process . on ( sig , sigListeners [ sig ] )
return true
} catch ( er ) {
return false
}
} )
process . emit = processEmit
process . reallyExit = processReallyExit
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
module . exports . load = load
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
var originalProcessReallyExit = process . reallyExit
var processReallyExit = function processReallyExit ( code ) {
/* istanbul ignore if */
if ( ! processOk ( global . process ) ) {
return
}
process . exitCode = code || /* istanbul ignore next */ 0
emit ( 'exit' , process . exitCode , null )
/* istanbul ignore next */
emit ( 'afterexit' , process . exitCode , null )
/* istanbul ignore next */
originalProcessReallyExit . call ( process , process . exitCode )
}
var originalProcessEmit = process . emit
var processEmit = function processEmit ( ev , arg ) {
if ( ev === 'exit' && processOk ( global . process ) ) {
/* istanbul ignore else */
if ( arg !== undefined ) {
process . exitCode = arg
}
var ret = originalProcessEmit . apply ( this , arguments )
/* istanbul ignore next */
emit ( 'exit' , process . exitCode , null )
/* istanbul ignore next */
emit ( 'afterexit' , process . exitCode , null )
/* istanbul ignore next */
return ret
} else {
return originalProcessEmit . apply ( this , arguments )
}
}
}
/***/ } ) ,
/***/ 3710 :
/***/ ( ( module ) => {
// This is not the set of all possible signals.
//
// It IS, however, the set of all signals that trigger
// an exit on either Linux or BSD systems. Linux is a
// superset of the signal names supported on BSD, and
// the unknown signals just fail to register, so we can
// catch that easily enough.
//
// Don't bother with SIGKILL. It's uncatchable, which
// means that we can't fire any callbacks anyway.
//
// If a user does happen to register a handler on a non-
// fatal signal like SIGWINCH or something, and then
// exit, it'll end up firing `process.emit('exit')`, so
// the handler will be fired anyway.
//
// SIGBUS, SIGFPE, SIGSEGV and SIGILL, when not raised
// artificially, inherently leave the process in a
// state from which it is not safe to try and enter JS
// listeners.
module . exports = [
'SIGABRT' ,
'SIGALRM' ,
'SIGHUP' ,
'SIGINT' ,
'SIGTERM'
]
if ( process . platform !== 'win32' ) {
module . exports . push (
'SIGVTALRM' ,
'SIGXCPU' ,
'SIGXFSZ' ,
'SIGUSR2' ,
'SIGTRAP' ,
'SIGSYS' ,
'SIGQUIT' ,
'SIGIOT'
// should detect profiler and enable/disable accordingly.
// see #21
// 'SIGPROF'
)
}
if ( process . platform === 'linux' ) {
module . exports . push (
'SIGIO' ,
'SIGPOLL' ,
'SIGPWR' ,
'SIGSTKFLT' ,
'SIGUNUSED'
)
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 5515 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
module . exports = function ( x ) {
var lf = typeof x === 'string' ? '\n' : '\n' . charCodeAt ( ) ;
var cr = typeof x === 'string' ? '\r' : '\r' . charCodeAt ( ) ;
if ( x [ x . length - 1 ] === lf ) {
x = x . slice ( 0 , x . length - 1 ) ;
}
if ( x [ x . length - 1 ] === cr ) {
x = x . slice ( 0 , x . length - 1 ) ;
}
return x ;
2021-12-01 13:39:57 +01:00
} ;
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 4256 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
var punycode = _ _nccwpck _require _ _ ( 5477 ) ;
var mappingTable = _ _nccwpck _require _ _ ( 2020 ) ;
var PROCESSING _OPTIONS = {
TRANSITIONAL : 0 ,
NONTRANSITIONAL : 1
} ;
function normalize ( str ) { // fix bug in v8
return str . split ( '\u0000' ) . map ( function ( s ) { return s . normalize ( 'NFC' ) ; } ) . join ( '\u0000' ) ;
}
function findStatus ( val ) {
var start = 0 ;
var end = mappingTable . length - 1 ;
while ( start <= end ) {
var mid = Math . floor ( ( start + end ) / 2 ) ;
var target = mappingTable [ mid ] ;
if ( target [ 0 ] [ 0 ] <= val && target [ 0 ] [ 1 ] >= val ) {
return target ;
} else if ( target [ 0 ] [ 0 ] > val ) {
end = mid - 1 ;
} else {
start = mid + 1 ;
}
}
return null ;
}
var regexAstralSymbols = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g ;
function countSymbols ( string ) {
return string
// replace every surrogate pair with a BMP symbol
. replace ( regexAstralSymbols , '_' )
// then get the length
. length ;
}
function mapChars ( domain _name , useSTD3 , processing _option ) {
var hasError = false ;
var processed = "" ;
var len = countSymbols ( domain _name ) ;
for ( var i = 0 ; i < len ; ++ i ) {
var codePoint = domain _name . codePointAt ( i ) ;
var status = findStatus ( codePoint ) ;
switch ( status [ 1 ] ) {
case "disallowed" :
hasError = true ;
processed += String . fromCodePoint ( codePoint ) ;
break ;
case "ignored" :
break ;
case "mapped" :
processed += String . fromCodePoint . apply ( String , status [ 2 ] ) ;
break ;
case "deviation" :
if ( processing _option === PROCESSING _OPTIONS . TRANSITIONAL ) {
processed += String . fromCodePoint . apply ( String , status [ 2 ] ) ;
} else {
processed += String . fromCodePoint ( codePoint ) ;
}
break ;
case "valid" :
processed += String . fromCodePoint ( codePoint ) ;
break ;
case "disallowed_STD3_mapped" :
if ( useSTD3 ) {
hasError = true ;
processed += String . fromCodePoint ( codePoint ) ;
} else {
processed += String . fromCodePoint . apply ( String , status [ 2 ] ) ;
}
break ;
case "disallowed_STD3_valid" :
if ( useSTD3 ) {
hasError = true ;
}
processed += String . fromCodePoint ( codePoint ) ;
break ;
}
}
return {
string : processed ,
error : hasError
} ;
}
var combiningMarksRegex = /[\u0300-\u036F\u0483-\u0489\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u0610-\u061A\u064B-\u065F\u0670\u06D6-\u06DC\u06DF-\u06E4\u06E7\u06E8\u06EA-\u06ED\u0711\u0730-\u074A\u07A6-\u07B0\u07EB-\u07F3\u0816-\u0819\u081B-\u0823\u0825-\u0827\u0829-\u082D\u0859-\u085B\u08E4-\u0903\u093A-\u093C\u093E-\u094F\u0951-\u0957\u0962\u0963\u0981-\u0983\u09BC\u09BE-\u09C4\u09C7\u09C8\u09CB-\u09CD\u09D7\u09E2\u09E3\u0A01-\u0A03\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A70\u0A71\u0A75\u0A81-\u0A83\u0ABC\u0ABE-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AE2\u0AE3\u0B01-\u0B03\u0B3C\u0B3E-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B62\u0B63\u0B82\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD7\u0C00-\u0C03\u0C3E-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C62\u0C63\u0C81-\u0C83\u0CBC\u0CBE-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CE2\u0CE3\u0D01-\u0D03\u0D3E-\u0D44\u0D46-\u0D48\u0D4A-\u0D4D\u0D57\u0D62\u0D63\u0D82\u0D83\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DF2\u0DF3\u0E31\u0E34-\u0E3A\u0E47-\u0E4E\u0EB1\u0EB4-\u0EB9\u0EBB\u0EBC\u0EC8-\u0ECD\u0F18\u0F19\u0F35\u0F37\u0F39\u0F3E\u0F3F\u0F71-\u0F84\u0F86\u0F87\u0F8D-\u0F97\u0F99-\u0FBC\u0FC6\u102B-\u103E\u1056-\u1059\u105E-\u1060\u1062-\u1064\u1067-\u106D\u1071-\u1074\u1082-\u108D\u108F\u109A-\u109D\u135D-\u135F\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17B4-\u17D3\u17DD\u180B-\u180D\u18A9\u1920-\u192B\u1930-\u193B\u19B0-\u19C0\u19C8\u19C9\u1A17-\u1A1B\u1A55-\u1A5E\u1A60-\u1A7C\u1A7F\u1AB0-\u1ABE\u1B00-\u1B04\u1B34-\u1B44\u1B6B-\u1B73\u1B80-\u1B82\u1BA1-\u1BAD\u1BE6-\u1BF3\u1C24-\u1C37\u1CD0-\u1CD2\u1CD4-\u1CE8\u1CED\u1CF2-\u1CF4\u1CF8\u1CF9\u1DC0-\u1DF5\u1DFC-\u1DFF\u20D0-\u20F0\u2CEF-\u2CF1\u2D7F\u2DE0-\u2DFF\u302A-\u302F\u3099\u309A\uA66F-\uA672\uA674-\uA67D\uA69F\uA6F0\uA6F1\uA802\uA806\uA80B\uA823-\uA827\uA880\uA881\uA8B4-\uA8C4\uA8E0-\uA8F1\uA926-\uA92D\uA947-\uA953\uA980-\uA983\uA9B3-\uA9C0\uA9E5\uAA29-\uAA36\uAA43\uAA4C\uAA4D\uAA7B-\uAA7D\uAAB0\uAAB2-\uAAB4\uAAB7\uAAB8\uAABE\uAABF\uAAC1\uAAEB-\uAAEF\uAAF5\uAAF6\uABE3-\uABEA\uABEC\uABED\uFB1E\uFE00-\uFE0F\uFE20-\uFE2D]|\uD800[\uDDFD\uDEE0\uDF76-\uDF7A]|\uD802[\uDE01-\uDE03\uDE05\uDE06\uDE0C-\uDE0F\uDE38-\uDE3A\uDE3F\uDEE5\uDEE6]|\uD804[\uDC00-\uDC02\uDC38-\uDC46\uDC7F-\uDC82\uDCB0-\uDCBA\uDD00-\uDD02\uDD27-\uDD34\uDD73\uDD80-\uDD82\uDDB3-\uDDC0\uDE2C-\uDE37\uDEDF-\uDEEA\uDF01-\uDF03\uDF3C\uDF3E-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF57\uDF62\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDCB0-\uDCC3\uDDAF-\uDDB5\uDDB8-\uDDC0\uDE30-\uDE40\uDEAB-\uDEB7]|\uD81A[\uDEF0-\uDEF4\uDF30-\uDF36]|\uD81B[\uDF51-\uDF7E\uDF8F-\uDF92]|\uD82F[\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD83A[\uDCD0-\uDCD6]|\uDB40[\uDD00-\uDDEF]/ ;
function validateLabel ( label , processing _option ) {
if ( label . substr ( 0 , 4 ) === "xn--" ) {
label = punycode . toUnicode ( label ) ;
processing _option = PROCESSING _OPTIONS . NONTRANSITIONAL ;
}
var error = false ;
if ( normalize ( label ) !== label ||
( label [ 3 ] === "-" && label [ 4 ] === "-" ) ||
label [ 0 ] === "-" || label [ label . length - 1 ] === "-" ||
label . indexOf ( "." ) !== - 1 ||
label . search ( combiningMarksRegex ) === 0 ) {
error = true ;
}
var len = countSymbols ( label ) ;
for ( var i = 0 ; i < len ; ++ i ) {
var status = findStatus ( label . codePointAt ( i ) ) ;
if ( ( processing === PROCESSING _OPTIONS . TRANSITIONAL && status [ 1 ] !== "valid" ) ||
( processing === PROCESSING _OPTIONS . NONTRANSITIONAL &&
status [ 1 ] !== "valid" && status [ 1 ] !== "deviation" ) ) {
error = true ;
break ;
}
}
return {
label : label ,
error : error
} ;
}
function processing ( domain _name , useSTD3 , processing _option ) {
var result = mapChars ( domain _name , useSTD3 , processing _option ) ;
result . string = normalize ( result . string ) ;
var labels = result . string . split ( "." ) ;
for ( var i = 0 ; i < labels . length ; ++ i ) {
try {
var validation = validateLabel ( labels [ i ] ) ;
labels [ i ] = validation . label ;
result . error = result . error || validation . error ;
} catch ( e ) {
result . error = true ;
}
}
return {
string : labels . join ( "." ) ,
error : result . error
} ;
}
module . exports . toASCII = function ( domain _name , useSTD3 , processing _option , verifyDnsLength ) {
var result = processing ( domain _name , useSTD3 , processing _option ) ;
var labels = result . string . split ( "." ) ;
labels = labels . map ( function ( l ) {
try {
return punycode . toASCII ( l ) ;
} catch ( e ) {
result . error = true ;
return l ;
}
} ) ;
if ( verifyDnsLength ) {
var total = labels . slice ( 0 , labels . length - 1 ) . join ( "." ) . length ;
if ( total . length > 253 || total . length === 0 ) {
result . error = true ;
}
for ( var i = 0 ; i < labels . length ; ++ i ) {
if ( labels . length > 63 || labels . length === 0 ) {
result . error = true ;
break ;
}
}
}
if ( result . error ) return null ;
return labels . join ( "." ) ;
} ;
module . exports . toUnicode = function ( domain _name , useSTD3 ) {
var result = processing ( domain _name , useSTD3 , PROCESSING _OPTIONS . NONTRANSITIONAL ) ;
return {
domain : result . string ,
error : result . error
} ;
} ;
module . exports . PROCESSING _OPTIONS = PROCESSING _OPTIONS ;
/***/ } ) ,
/***/ 8078 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _extends = ( this && this . _ _extends ) || ( function ( ) {
var extendStatics = function ( d , b ) {
extendStatics = Object . setPrototypeOf ||
( { _ _proto _ _ : [ ] } instanceof Array && function ( d , b ) { d . _ _proto _ _ = b ; } ) ||
function ( d , b ) { for ( var p in b ) if ( Object . prototype . hasOwnProperty . call ( b , p ) ) d [ p ] = b [ p ] ; } ;
return extendStatics ( d , b ) ;
} ;
return function ( d , b ) {
if ( typeof b !== "function" && b !== null )
throw new TypeError ( "Class extends value " + String ( b ) + " is not a constructor or null" ) ;
extendStatics ( d , b ) ;
function _ _ ( ) { this . constructor = d ; }
d . prototype = b === null ? Object . create ( b ) : ( _ _ . prototype = b . prototype , new _ _ ( ) ) ;
} ;
} ) ( ) ;
var _ _read = ( this && this . _ _read ) || function ( o , n ) {
var m = typeof Symbol === "function" && o [ Symbol . iterator ] ;
if ( ! m ) return o ;
var i = m . call ( o ) , r , ar = [ ] , e ;
try {
while ( ( n === void 0 || n -- > 0 ) && ! ( r = i . next ( ) ) . done ) ar . push ( r . value ) ;
}
catch ( error ) { e = { error : error } ; }
finally {
try {
if ( r && ! r . done && ( m = i [ "return" ] ) ) m . call ( i ) ;
}
finally { if ( e ) throw e . error ; }
}
return ar ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . assert = exports . AssertionError = void 0 ;
/* eslint-disable @typescript-eslint/no-unused-vars */
var overwriteReadonlyProp _1 = _ _nccwpck _require _ _ ( 747 ) ;
var assertIsRefWrapper _1 = _ _nccwpck _require _ _ ( 2562 ) ;
/** @see <https://docs.tsafe.dev/assert#error-thrown> */
var AssertionError = /** @class */ ( function ( _super ) {
_ _extends ( AssertionError , _super ) ;
function AssertionError ( msg ) {
var _newTarget = this . constructor ;
var _this = _super . call ( this , "Wrong assertion encountered" + ( ! msg ? "" : ": \"" + msg + "\"" ) ) || this ;
Object . setPrototypeOf ( _this , _newTarget . prototype ) ;
if ( ! _this . stack ) {
return _this ;
}
try {
( 0 , overwriteReadonlyProp _1 . overwriteReadonlyProp ) ( _this , "stack" , _this . stack
. split ( "\n" )
. filter ( function ( ) {
var _a = [ ] ;
for ( var _i = 0 ; _i < arguments . length ; _i ++ ) {
_a [ _i ] = arguments [ _i ] ;
}
var _b = _ _read ( _a , 2 ) , i = _b [ 1 ] ;
return i !== 1 && i !== 2 ;
} )
. join ( "\n" ) ) ;
// eslint-disable-next-line no-empty
}
catch ( _a ) { }
return _this ;
}
return AssertionError ;
} ( Error ) ) ;
exports . AssertionError = AssertionError ;
/** https://docs.tsafe.dev/assert */
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function assert ( condition , msg ) {
if ( condition === void 0 ) { condition = true ; }
if ( assertIsRefWrapper _1 . assertIsRefWrapper . ref !== undefined ) {
assertIsRefWrapper _1 . assertIsRefWrapper . ref = undefined ;
return ;
}
if ( ! condition ) {
throw new AssertionError ( msg ) ;
}
}
exports . assert = assert ;
//# sourceMappingURL=assert.js.map
/***/ } ) ,
/***/ 3047 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . id = void 0 ;
/** https://docs.tsafe.dev/id */
var id = function ( x ) { return x ; } ;
exports . id = id ;
//# sourceMappingURL=id.js.map
/***/ } ) ,
/***/ 4655 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
/* eslint-disable @typescript-eslint/no-namespace */
/* eslint-disable @typescript-eslint/no-explicit-any */
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . is = void 0 ;
var assertIsRefWrapper _1 = _ _nccwpck _require _ _ ( 2562 ) ;
var errorMessage = [
"Wrong usage of the " + is . name + " function refer to" ,
"https://docs.tsafe.dev/" + is . name . toLowerCase ( ) ,
] . join ( " " ) ;
function is ( _value ) {
var ref = { } ;
if ( assertIsRefWrapper _1 . assertIsRefWrapper . ref !== undefined ) {
assertIsRefWrapper _1 . assertIsRefWrapper . ref = undefined ;
throw new Error ( errorMessage ) ;
}
assertIsRefWrapper _1 . assertIsRefWrapper . ref = ref ;
Promise . resolve ( ) . then ( function ( ) {
if ( assertIsRefWrapper _1 . assertIsRefWrapper . ref === ref ) {
throw new Error ( errorMessage ) ;
}
} ) ;
return null ;
}
exports . is = is ;
//# sourceMappingURL=is.js.map
/***/ } ) ,
/***/ 747 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _assign = ( this && this . _ _assign ) || function ( ) {
_ _assign = Object . assign || function ( t ) {
for ( var s , i = 1 , n = arguments . length ; i < n ; i ++ ) {
s = arguments [ i ] ;
for ( var p in s ) if ( Object . prototype . hasOwnProperty . call ( s , p ) )
t [ p ] = s [ p ] ;
}
return t ;
} ;
return _ _assign . apply ( this , arguments ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . overwriteReadonlyProp = void 0 ;
/* eslint-disable no-empty */
/* eslint-disable @typescript-eslint/no-explicit-any */
var assert _1 = _ _nccwpck _require _ _ ( 8078 ) ;
var is _1 = _ _nccwpck _require _ _ ( 4655 ) ;
/ * *
* Assign a value to a property even if the object is freezed or if the property is not writable
* Throw if the assignation fail ( for example if the property is non configurable write : false )
* * /
var overwriteReadonlyProp = function ( obj , propertyName , value ) {
try {
obj [ propertyName ] = value ;
}
catch ( _a ) { }
if ( obj [ propertyName ] === value ) {
return value ;
}
var errorDefineProperty = undefined ;
var propertyDescriptor = Object . getOwnPropertyDescriptor ( obj , propertyName ) || {
"enumerable" : true ,
"configurable" : true ,
} ;
if ( ! ! propertyDescriptor . get ) {
throw new Error ( "Probably a wrong ides to overwrite " + propertyName + " getter" ) ;
}
try {
Object . defineProperty ( obj , propertyName , _ _assign ( _ _assign ( { } , propertyDescriptor ) , { value : value } ) ) ;
}
catch ( error ) {
( 0 , assert _1 . assert ) ( ( 0 , is _1 . is ) ( error ) ) ;
errorDefineProperty = error ;
}
if ( obj [ propertyName ] !== value ) {
throw errorDefineProperty || new Error ( "Can't assign" ) ;
}
return value ;
} ;
exports . overwriteReadonlyProp = overwriteReadonlyProp ;
//# sourceMappingURL=overwriteReadonlyProp.js.map
/***/ } ) ,
/***/ 2562 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . assertIsRefWrapper = void 0 ;
var id _1 = _ _nccwpck _require _ _ ( 3047 ) ;
exports . assertIsRefWrapper = {
"ref" : ( 0 , id _1 . id ) ( undefined ) ,
} ;
//# sourceMappingURL=assertIsRefWrapper.js.map
/***/ } ) ,
/***/ 4294 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
module . exports = _ _nccwpck _require _ _ ( 4219 ) ;
/***/ } ) ,
/***/ 4219 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
var net = _ _nccwpck _require _ _ ( 1808 ) ;
var tls = _ _nccwpck _require _ _ ( 4404 ) ;
var http = _ _nccwpck _require _ _ ( 3685 ) ;
var https = _ _nccwpck _require _ _ ( 5687 ) ;
var events = _ _nccwpck _require _ _ ( 2361 ) ;
var assert = _ _nccwpck _require _ _ ( 9491 ) ;
var util = _ _nccwpck _require _ _ ( 3837 ) ;
exports . httpOverHttp = httpOverHttp ;
exports . httpsOverHttp = httpsOverHttp ;
exports . httpOverHttps = httpOverHttps ;
exports . httpsOverHttps = httpsOverHttps ;
function httpOverHttp ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = http . request ;
return agent ;
}
function httpsOverHttp ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = http . request ;
agent . createSocket = createSecureSocket ;
agent . defaultPort = 443 ;
return agent ;
}
function httpOverHttps ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = https . request ;
return agent ;
}
function httpsOverHttps ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = https . request ;
agent . createSocket = createSecureSocket ;
agent . defaultPort = 443 ;
return agent ;
}
function TunnelingAgent ( options ) {
var self = this ;
self . options = options || { } ;
self . proxyOptions = self . options . proxy || { } ;
self . maxSockets = self . options . maxSockets || http . Agent . defaultMaxSockets ;
self . requests = [ ] ;
self . sockets = [ ] ;
self . on ( 'free' , function onFree ( socket , host , port , localAddress ) {
var options = toOptions ( host , port , localAddress ) ;
for ( var i = 0 , len = self . requests . length ; i < len ; ++ i ) {
var pending = self . requests [ i ] ;
if ( pending . host === options . host && pending . port === options . port ) {
// Detect the request to connect same origin server,
// reuse the connection.
self . requests . splice ( i , 1 ) ;
pending . request . onSocket ( socket ) ;
return ;
}
}
socket . destroy ( ) ;
self . removeSocket ( socket ) ;
} ) ;
}
util . inherits ( TunnelingAgent , events . EventEmitter ) ;
TunnelingAgent . prototype . addRequest = function addRequest ( req , host , port , localAddress ) {
var self = this ;
var options = mergeOptions ( { request : req } , self . options , toOptions ( host , port , localAddress ) ) ;
if ( self . sockets . length >= this . maxSockets ) {
// We are over limit so we'll add it to the queue.
self . requests . push ( options ) ;
return ;
}
// If we are under maxSockets create a new one.
self . createSocket ( options , function ( socket ) {
socket . on ( 'free' , onFree ) ;
socket . on ( 'close' , onCloseOrRemove ) ;
socket . on ( 'agentRemove' , onCloseOrRemove ) ;
req . onSocket ( socket ) ;
function onFree ( ) {
self . emit ( 'free' , socket , options ) ;
}
function onCloseOrRemove ( err ) {
self . removeSocket ( socket ) ;
socket . removeListener ( 'free' , onFree ) ;
socket . removeListener ( 'close' , onCloseOrRemove ) ;
socket . removeListener ( 'agentRemove' , onCloseOrRemove ) ;
}
} ) ;
} ;
TunnelingAgent . prototype . createSocket = function createSocket ( options , cb ) {
var self = this ;
var placeholder = { } ;
self . sockets . push ( placeholder ) ;
var connectOptions = mergeOptions ( { } , self . proxyOptions , {
method : 'CONNECT' ,
path : options . host + ':' + options . port ,
agent : false ,
headers : {
host : options . host + ':' + options . port
}
} ) ;
if ( options . localAddress ) {
connectOptions . localAddress = options . localAddress ;
}
if ( connectOptions . proxyAuth ) {
connectOptions . headers = connectOptions . headers || { } ;
connectOptions . headers [ 'Proxy-Authorization' ] = 'Basic ' +
new Buffer ( connectOptions . proxyAuth ) . toString ( 'base64' ) ;
}
debug ( 'making CONNECT request' ) ;
var connectReq = self . request ( connectOptions ) ;
connectReq . useChunkedEncodingByDefault = false ; // for v0.6
connectReq . once ( 'response' , onResponse ) ; // for v0.6
connectReq . once ( 'upgrade' , onUpgrade ) ; // for v0.6
connectReq . once ( 'connect' , onConnect ) ; // for v0.7 or later
connectReq . once ( 'error' , onError ) ;
connectReq . end ( ) ;
function onResponse ( res ) {
// Very hacky. This is necessary to avoid http-parser leaks.
res . upgrade = true ;
}
function onUpgrade ( res , socket , head ) {
// Hacky.
process . nextTick ( function ( ) {
onConnect ( res , socket , head ) ;
} ) ;
}
function onConnect ( res , socket , head ) {
connectReq . removeAllListeners ( ) ;
socket . removeAllListeners ( ) ;
if ( res . statusCode !== 200 ) {
debug ( 'tunneling socket could not be established, statusCode=%d' ,
res . statusCode ) ;
socket . destroy ( ) ;
var error = new Error ( 'tunneling socket could not be established, ' +
'statusCode=' + res . statusCode ) ;
error . code = 'ECONNRESET' ;
options . request . emit ( 'error' , error ) ;
self . removeSocket ( placeholder ) ;
return ;
}
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
/***/ } ) ,
/***/ 5030 :
/***/ ( ( _ _unused _webpack _module , exports ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
function getUserAgent ( ) {
if ( typeof navigator === "object" && "userAgent" in navigator ) {
return navigator . userAgent ;
}
if ( typeof process === "object" && "version" in process ) {
return ` Node.js/ ${ process . version . substr ( 1 ) } ( ${ process . platform } ; ${ process . arch } ) ` ;
}
return "<environment undetectable>" ;
}
exports . getUserAgent = getUserAgent ;
//# sourceMappingURL=index.js.map
/***/ } ) ,
/***/ 2821 :
/***/ ( function ( module ) {
( function ( name , context , definition ) {
if ( true && module . exports ) module . exports = definition ( ) ;
else if ( typeof define === 'function' && define . amd ) define ( definition ) ;
else context [ name ] = definition ( ) ;
} ) ( 'urljoin' , this , function ( ) {
function normalize ( strArray ) {
var resultArray = [ ] ;
if ( strArray . length === 0 ) { return '' ; }
if ( typeof strArray [ 0 ] !== 'string' ) {
throw new TypeError ( 'Url must be a string. Received ' + strArray [ 0 ] ) ;
}
// If the first part is a plain protocol, we combine it with the next part.
if ( strArray [ 0 ] . match ( /^[^/:]+:\/*$/ ) && strArray . length > 1 ) {
var first = strArray . shift ( ) ;
strArray [ 0 ] = first + strArray [ 0 ] ;
}
// There must be two or three slashes in the file protocol, two slashes in anything else.
if ( strArray [ 0 ] . match ( /^file:\/\/\// ) ) {
strArray [ 0 ] = strArray [ 0 ] . replace ( /^([^/:]+):\/*/ , '$1:///' ) ;
} else {
strArray [ 0 ] = strArray [ 0 ] . replace ( /^([^/:]+):\/*/ , '$1://' ) ;
}
for ( var i = 0 ; i < strArray . length ; i ++ ) {
var component = strArray [ i ] ;
if ( typeof component !== 'string' ) {
throw new TypeError ( 'Url must be a string. Received ' + component ) ;
}
if ( component === '' ) { continue ; }
if ( i > 0 ) {
// Removing the starting slashes for each component but the first.
component = component . replace ( /^[\/]+/ , '' ) ;
}
if ( i < strArray . length - 1 ) {
// Removing the ending slashes for each component but the last.
component = component . replace ( /[\/]+$/ , '' ) ;
} else {
// For the last component we will combine multiple slashes to a single one.
component = component . replace ( /[\/]+$/ , '/' ) ;
}
resultArray . push ( component ) ;
}
var str = resultArray . join ( '/' ) ;
// Each input component is now separated by a single slash except the possible first plain protocol part.
// remove trailing slash before parameters or hash
str = str . replace ( /\/(\?|&|#[^!])/g , '$1' ) ;
// replace ? in parameters with &
var parts = str . split ( '?' ) ;
str = parts . shift ( ) + ( parts . length > 0 ? '?' : '' ) + parts . join ( '&' ) ;
return str ;
}
return function ( ) {
var input ;
if ( typeof arguments [ 0 ] === 'object' ) {
input = arguments [ 0 ] ;
} else {
input = [ ] . slice . call ( arguments ) ;
}
return normalize ( input ) ;
} ;
} ) ;
/***/ } ) ,
/***/ 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 ;
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 9120 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
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 ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
var _default = validate ;
exports [ "default" ] = _default ;
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 1595 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
Object . defineProperty ( exports , "__esModule" , ( {
value : true
} ) ) ;
exports [ "default" ] = void 0 ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var _validate = _interopRequireDefault ( _ _nccwpck _require _ _ ( 6900 ) ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { default : obj } ; }
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
function version ( uuid ) {
if ( ! ( 0 , _validate . default ) ( uuid ) ) {
throw TypeError ( 'Invalid UUID' ) ;
}
return parseInt ( uuid . substr ( 14 , 1 ) , 16 ) ;
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var _default = version ;
exports [ "default" ] = _default ;
2021-12-01 13:39:57 +01:00
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 4150 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-10-11 16:10:23 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
var scopedPackagePattern = new RegExp ( '^(?:@([^/]+?)[/])?([^/]+?)$' )
var builtins = _ _nccwpck _require _ _ ( 2587 )
var blacklist = [
'node_modules' ,
'favicon.ico'
]
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
var validate = module . exports = function ( name ) {
var warnings = [ ]
var errors = [ ]
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( name === null ) {
errors . push ( 'name cannot be null' )
return done ( warnings , errors )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( name === undefined ) {
errors . push ( 'name cannot be undefined' )
return done ( warnings , errors )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( typeof name !== 'string' ) {
errors . push ( 'name must be a string' )
return done ( warnings , errors )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( ! name . length ) {
errors . push ( 'name length must be greater than zero' )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( name . match ( /^\./ ) ) {
errors . push ( 'name cannot start with a period' )
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( name . match ( /^_/ ) ) {
errors . push ( 'name cannot start with an underscore' )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
if ( name . trim ( ) !== name ) {
errors . push ( 'name cannot contain leading or trailing spaces' )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
// No funny business
blacklist . forEach ( function ( blacklistedName ) {
if ( name . toLowerCase ( ) === blacklistedName ) {
errors . push ( blacklistedName + ' is a blacklisted name' )
}
} )
// Generate warnings for stuff that used to be allowed
// core module names like http, events, util, etc
builtins . forEach ( function ( builtin ) {
if ( name . toLowerCase ( ) === builtin ) {
warnings . push ( builtin + ' is a core module name' )
}
} )
// really-long-package-names-------------------------------such--length-----many---wow
// the thisisareallyreallylongpackagenameitshouldpublishdowenowhavealimittothelengthofpackagenames-poch.
if ( name . length > 214 ) {
warnings . push ( 'name can no longer contain more than 214 characters' )
2022-10-11 16:10:23 +02:00
}
2024-05-19 08:24:38 +02:00
// mIxeD CaSe nAMEs
if ( name . toLowerCase ( ) !== name ) {
warnings . push ( 'name can no longer contain capital letters' )
}
if ( /[~'!()*]/ . test ( name . split ( '/' ) . slice ( - 1 ) [ 0 ] ) ) {
warnings . push ( 'name can no longer contain special characters ("~\'!()*")' )
}
if ( encodeURIComponent ( name ) !== name ) {
// Maybe it's a scoped package name, like @user/package
var nameMatch = name . match ( scopedPackagePattern )
if ( nameMatch ) {
var user = nameMatch [ 1 ]
var pkg = nameMatch [ 2 ]
if ( encodeURIComponent ( user ) === user && encodeURIComponent ( pkg ) === pkg ) {
return done ( warnings , errors )
}
}
errors . push ( 'name can only contain URL-friendly characters' )
}
return done ( warnings , errors )
}
validate . scopedPackagePattern = scopedPackagePattern
var done = function ( warnings , errors ) {
var result = {
validForNewPackages : errors . length === 0 && warnings . length === 0 ,
validForOldPackages : errors . length === 0 ,
warnings : warnings ,
errors : errors
}
if ( ! result . warnings . length ) delete result . warnings
if ( ! result . errors . length ) delete result . errors
return result
}
/***/ } ) ,
/***/ 4886 :
/***/ ( ( module ) => {
"use strict" ;
var conversions = { } ;
module . exports = conversions ;
function sign ( x ) {
return x < 0 ? - 1 : 1 ;
}
function evenRound ( x ) {
// Round x to the nearest integer, choosing the even integer if it lies halfway between two.
if ( ( x % 1 ) === 0.5 && ( x & 1 ) === 0 ) { // [even number].5; round down (i.e. floor)
return Math . floor ( x ) ;
} else {
return Math . round ( x ) ;
}
}
function createNumberConversion ( bitLength , typeOpts ) {
if ( ! typeOpts . unsigned ) {
-- bitLength ;
}
const lowerBound = typeOpts . unsigned ? 0 : - Math . pow ( 2 , bitLength ) ;
const upperBound = Math . pow ( 2 , bitLength ) - 1 ;
const moduloVal = typeOpts . moduloBitLength ? Math . pow ( 2 , typeOpts . moduloBitLength ) : Math . pow ( 2 , bitLength ) ;
const moduloBound = typeOpts . moduloBitLength ? Math . pow ( 2 , typeOpts . moduloBitLength - 1 ) : Math . pow ( 2 , bitLength - 1 ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return function ( V , opts ) {
if ( ! opts ) opts = { } ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
let x = + V ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( opts . enforceRange ) {
if ( ! Number . isFinite ( x ) ) {
throw new TypeError ( "Argument is not a finite number" ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
x = sign ( x ) * Math . floor ( Math . abs ( x ) ) ;
if ( x < lowerBound || x > upperBound ) {
throw new TypeError ( "Argument is not in byte range" ) ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return x ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! isNaN ( x ) && opts . clamp ) {
x = evenRound ( x ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( x < lowerBound ) x = lowerBound ;
if ( x > upperBound ) x = upperBound ;
return x ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! Number . isFinite ( x ) || x === 0 ) {
return 0 ;
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
x = sign ( x ) * Math . floor ( Math . abs ( x ) ) ;
x = x % moduloVal ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
if ( ! typeOpts . unsigned && x >= moduloBound ) {
return x - moduloVal ;
} else if ( typeOpts . unsigned ) {
if ( x < 0 ) {
x += moduloVal ;
} else if ( x === - 0 ) { // don't return negative zero
return 0 ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
return x ;
}
}
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
conversions [ "void" ] = function ( ) {
return undefined ;
2022-10-11 16:10:23 +02:00
} ;
2024-05-19 08:24:38 +02:00
conversions [ "boolean" ] = function ( val ) {
return ! ! val ;
} ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
conversions [ "byte" ] = createNumberConversion ( 8 , { unsigned : false } ) ;
conversions [ "octet" ] = createNumberConversion ( 8 , { unsigned : true } ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
conversions [ "short" ] = createNumberConversion ( 16 , { unsigned : false } ) ;
conversions [ "unsigned short" ] = createNumberConversion ( 16 , { unsigned : true } ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
conversions [ "long" ] = createNumberConversion ( 32 , { unsigned : false } ) ;
conversions [ "unsigned long" ] = createNumberConversion ( 32 , { unsigned : true } ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
conversions [ "long long" ] = createNumberConversion ( 32 , { unsigned : false , moduloBitLength : 64 } ) ;
conversions [ "unsigned long long" ] = createNumberConversion ( 32 , { unsigned : true , moduloBitLength : 64 } ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
conversions [ "double" ] = function ( V ) {
const x = + V ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
if ( ! Number . isFinite ( x ) ) {
throw new TypeError ( "Argument is not a finite floating-point value" ) ;
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
return x ;
} ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
conversions [ "unrestricted double" ] = function ( V ) {
const x = + V ;
if ( isNaN ( x ) ) {
throw new TypeError ( "Argument is NaN" ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
return x ;
} ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
// not quite valid, but good enough for JS
conversions [ "float" ] = conversions [ "double" ] ;
conversions [ "unrestricted float" ] = conversions [ "unrestricted double" ] ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
conversions [ "DOMString" ] = function ( V , opts ) {
if ( ! opts ) opts = { } ;
if ( opts . treatNullAsEmptyString && V === null ) {
return "" ;
}
return String ( V ) ;
} ;
conversions [ "ByteString" ] = function ( V , opts ) {
const x = String ( V ) ;
let c = undefined ;
for ( let i = 0 ; ( c = x . codePointAt ( i ) ) !== undefined ; ++ i ) {
if ( c > 255 ) {
throw new TypeError ( "Argument is not a valid bytestring" ) ;
}
}
return x ;
} ;
conversions [ "USVString" ] = function ( V ) {
const S = String ( V ) ;
const n = S . length ;
const U = [ ] ;
for ( let i = 0 ; i < n ; ++ i ) {
const c = S . charCodeAt ( i ) ;
if ( c < 0xD800 || c > 0xDFFF ) {
U . push ( String . fromCodePoint ( c ) ) ;
} else if ( 0xDC00 <= c && c <= 0xDFFF ) {
U . push ( String . fromCodePoint ( 0xFFFD ) ) ;
} else {
if ( i === n - 1 ) {
U . push ( String . fromCodePoint ( 0xFFFD ) ) ;
} else {
const d = S . charCodeAt ( i + 1 ) ;
if ( 0xDC00 <= d && d <= 0xDFFF ) {
const a = c & 0x3FF ;
const b = d & 0x3FF ;
U . push ( String . fromCodePoint ( ( 2 << 15 ) + ( 2 << 9 ) * a + b ) ) ;
++ i ;
} else {
U . push ( String . fromCodePoint ( 0xFFFD ) ) ;
}
2021-12-01 13:39:57 +01:00
}
}
2024-05-19 08:24:38 +02:00
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
return U . join ( '' ) ;
} ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
conversions [ "Date" ] = function ( V , opts ) {
if ( ! ( V instanceof Date ) ) {
throw new TypeError ( "Argument is not a Date object" ) ;
}
if ( isNaN ( V ) ) {
return undefined ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
return V ;
} ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
conversions [ "RegExp" ] = function ( V , opts ) {
if ( ! ( V instanceof RegExp ) ) {
V = new RegExp ( V ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
return V ;
2021-12-01 13:39:57 +01:00
} ;
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 7537 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
const usm = _ _nccwpck _require _ _ ( 2158 ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
exports . implementation = class URLImpl {
constructor ( constructorArgs ) {
const url = constructorArgs [ 0 ] ;
const base = constructorArgs [ 1 ] ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
let parsedBase = null ;
if ( base !== undefined ) {
parsedBase = usm . basicURLParse ( base ) ;
if ( parsedBase === "failure" ) {
throw new TypeError ( "Invalid base URL" ) ;
}
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
const parsedURL = usm . basicURLParse ( url , { baseURL : parsedBase } ) ;
if ( parsedURL === "failure" ) {
throw new TypeError ( "Invalid URL" ) ;
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
this . _url = parsedURL ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
// TODO: query stuff
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
get href ( ) {
return usm . serializeURL ( this . _url ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
set href ( v ) {
const parsedURL = usm . basicURLParse ( v ) ;
if ( parsedURL === "failure" ) {
throw new TypeError ( "Invalid URL" ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
this . _url = parsedURL ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
get origin ( ) {
return usm . serializeURLOrigin ( this . _url ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
get protocol ( ) {
return this . _url . scheme + ":" ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
set protocol ( v ) {
usm . basicURLParse ( v + ":" , { url : this . _url , stateOverride : "scheme start" } ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
get username ( ) {
return this . _url . username ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
set username ( v ) {
if ( usm . cannotHaveAUsernamePasswordPort ( this . _url ) ) {
return ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
usm . setTheUsername ( this . _url , v ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
get password ( ) {
return this . _url . password ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
set password ( v ) {
if ( usm . cannotHaveAUsernamePasswordPort ( this . _url ) ) {
return ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
usm . setThePassword ( this . _url , v ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
get host ( ) {
const url = this . _url ;
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( url . host === null ) {
return "" ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
if ( url . port === null ) {
return usm . serializeHost ( url . host ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
return usm . serializeHost ( url . host ) + ":" + usm . serializeInteger ( url . port ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
set host ( v ) {
if ( this . _url . cannotBeABaseURL ) {
return ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
usm . basicURLParse ( v , { url : this . _url , stateOverride : "host" } ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
get hostname ( ) {
if ( this . _url . host === null ) {
return "" ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return usm . serializeHost ( this . _url . host ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
set hostname ( v ) {
if ( this . _url . cannotBeABaseURL ) {
return ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
usm . basicURLParse ( v , { url : this . _url , stateOverride : "hostname" } ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
get port ( ) {
if ( this . _url . port === null ) {
return "" ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return usm . serializeInteger ( this . _url . port ) ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
set port ( v ) {
if ( usm . cannotHaveAUsernamePasswordPort ( this . _url ) ) {
return ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( v === "" ) {
this . _url . port = null ;
} else {
usm . basicURLParse ( v , { url : this . _url , stateOverride : "port" } ) ;
}
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
get pathname ( ) {
if ( this . _url . cannotBeABaseURL ) {
return this . _url . path [ 0 ] ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
if ( this . _url . path . length === 0 ) {
return "" ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return "/" + this . _url . path . join ( "/" ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
set pathname ( v ) {
if ( this . _url . cannotBeABaseURL ) {
return ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
this . _url . path = [ ] ;
usm . basicURLParse ( v , { url : this . _url , stateOverride : "path start" } ) ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
get search ( ) {
if ( this . _url . query === null || this . _url . query === "" ) {
return "" ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return "?" + this . _url . query ;
2022-10-12 17:48:05 +02:00
}
2024-05-19 08:24:38 +02:00
set search ( v ) {
// TODO: query stuff
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
const url = this . _url ;
if ( v === "" ) {
url . query = null ;
return ;
}
const input = v [ 0 ] === "?" ? v . substring ( 1 ) : v ;
url . query = "" ;
usm . basicURLParse ( input , { url , stateOverride : "query" } ) ;
}
get hash ( ) {
if ( this . _url . fragment === null || this . _url . fragment === "" ) {
return "" ;
}
2022-10-12 17:48:05 +02:00
2024-05-19 08:24:38 +02:00
return "#" + this . _url . fragment ;
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
set hash ( v ) {
if ( v === "" ) {
this . _url . fragment = null ;
return ;
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
const input = v [ 0 ] === "#" ? v . substring ( 1 ) : v ;
this . _url . fragment = "" ;
usm . basicURLParse ( input , { url : this . _url , stateOverride : "fragment" } ) ;
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
toJSON ( ) {
return this . href ;
}
} ;
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 3394 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
const conversions = _ _nccwpck _require _ _ ( 4886 ) ;
const utils = _ _nccwpck _require _ _ ( 3185 ) ;
const Impl = _ _nccwpck _require _ _ ( 7537 ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
const impl = utils . implSymbol ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
function URL ( url ) {
if ( ! this || this [ impl ] || ! ( this instanceof URL ) ) {
throw new TypeError ( "Failed to construct 'URL': Please use the 'new' operator, this DOM object constructor cannot be called as a function." ) ;
}
if ( arguments . length < 1 ) {
throw new TypeError ( "Failed to construct 'URL': 1 argument required, but only " + arguments . length + " present." ) ;
}
const args = [ ] ;
for ( let i = 0 ; i < arguments . length && i < 2 ; ++ i ) {
args [ i ] = arguments [ i ] ;
}
args [ 0 ] = conversions [ "USVString" ] ( args [ 0 ] ) ;
if ( args [ 1 ] !== undefined ) {
args [ 1 ] = conversions [ "USVString" ] ( args [ 1 ] ) ;
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
module . exports . setup ( this , args ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
URL . prototype . toJSON = function toJSON ( ) {
if ( ! this || ! module . exports . is ( this ) ) {
throw new TypeError ( "Illegal invocation" ) ;
}
const args = [ ] ;
for ( let i = 0 ; i < arguments . length && i < 0 ; ++ i ) {
args [ i ] = arguments [ i ] ;
}
return this [ impl ] . toJSON . apply ( this [ impl ] , args ) ;
} ;
Object . defineProperty ( URL . prototype , "href" , {
get ( ) {
return this [ impl ] . href ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . href = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
URL . prototype . toString = function ( ) {
if ( ! this || ! module . exports . is ( this ) ) {
throw new TypeError ( "Illegal invocation" ) ;
}
return this . href ;
} ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( URL . prototype , "origin" , {
get ( ) {
return this [ impl ] . origin ;
} ,
enumerable : true ,
configurable : true
} ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( URL . prototype , "protocol" , {
get ( ) {
return this [ impl ] . protocol ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . protocol = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( URL . prototype , "username" , {
get ( ) {
return this [ impl ] . username ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . username = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( URL . prototype , "password" , {
get ( ) {
return this [ impl ] . password ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . password = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( URL . prototype , "host" , {
get ( ) {
return this [ impl ] . host ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . host = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( URL . prototype , "hostname" , {
get ( ) {
return this [ impl ] . hostname ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . hostname = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
Object . defineProperty ( URL . prototype , "port" , {
get ( ) {
return this [ impl ] . port ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . port = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
Object . defineProperty ( URL . prototype , "pathname" , {
get ( ) {
return this [ impl ] . pathname ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . pathname = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
Object . defineProperty ( URL . prototype , "search" , {
get ( ) {
return this [ impl ] . search ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . search = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
Object . defineProperty ( URL . prototype , "hash" , {
get ( ) {
return this [ impl ] . hash ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . hash = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
module . exports = {
is ( obj ) {
return ! ! obj && obj [ impl ] instanceof Impl . implementation ;
} ,
create ( constructorArgs , privateData ) {
let obj = Object . create ( URL . prototype ) ;
this . setup ( obj , constructorArgs , privateData ) ;
return obj ;
} ,
setup ( obj , constructorArgs , privateData ) {
if ( ! privateData ) privateData = { } ;
privateData . wrapper = obj ;
obj [ impl ] = new Impl . implementation ( constructorArgs , privateData ) ;
obj [ impl ] [ utils . wrapperSymbol ] = obj ;
} ,
interface : URL ,
expose : {
Window : { URL : URL } ,
Worker : { URL : URL }
}
} ;
/***/ } ) ,
/***/ 8665 :
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
exports . URL = _ _nccwpck _require _ _ ( 3394 ) [ "interface" ] ;
exports . serializeURL = _ _nccwpck _require _ _ ( 2158 ) . serializeURL ;
exports . serializeURLOrigin = _ _nccwpck _require _ _ ( 2158 ) . serializeURLOrigin ;
exports . basicURLParse = _ _nccwpck _require _ _ ( 2158 ) . basicURLParse ;
exports . setTheUsername = _ _nccwpck _require _ _ ( 2158 ) . setTheUsername ;
exports . setThePassword = _ _nccwpck _require _ _ ( 2158 ) . setThePassword ;
exports . serializeHost = _ _nccwpck _require _ _ ( 2158 ) . serializeHost ;
exports . serializeInteger = _ _nccwpck _require _ _ ( 2158 ) . serializeInteger ;
exports . parseURL = _ _nccwpck _require _ _ ( 2158 ) . parseURL ;
/***/ } ) ,
/***/ 2158 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
const punycode = _ _nccwpck _require _ _ ( 5477 ) ;
const tr46 = _ _nccwpck _require _ _ ( 4256 ) ;
const specialSchemes = {
ftp : 21 ,
file : null ,
gopher : 70 ,
http : 80 ,
https : 443 ,
ws : 80 ,
wss : 443
} ;
const failure = Symbol ( "failure" ) ;
function countSymbols ( str ) {
return punycode . ucs2 . decode ( str ) . length ;
}
function at ( input , idx ) {
const c = input [ idx ] ;
return isNaN ( c ) ? undefined : String . fromCodePoint ( c ) ;
}
function isASCIIDigit ( c ) {
return c >= 0x30 && c <= 0x39 ;
}
function isASCIIAlpha ( c ) {
return ( c >= 0x41 && c <= 0x5A ) || ( c >= 0x61 && c <= 0x7A ) ;
}
function isASCIIAlphanumeric ( c ) {
return isASCIIAlpha ( c ) || isASCIIDigit ( c ) ;
}
function isASCIIHex ( c ) {
return isASCIIDigit ( c ) || ( c >= 0x41 && c <= 0x46 ) || ( c >= 0x61 && c <= 0x66 ) ;
}
function isSingleDot ( buffer ) {
return buffer === "." || buffer . toLowerCase ( ) === "%2e" ;
}
function isDoubleDot ( buffer ) {
buffer = buffer . toLowerCase ( ) ;
return buffer === ".." || buffer === "%2e." || buffer === ".%2e" || buffer === "%2e%2e" ;
}
function isWindowsDriveLetterCodePoints ( cp1 , cp2 ) {
return isASCIIAlpha ( cp1 ) && ( cp2 === 58 || cp2 === 124 ) ;
}
function isWindowsDriveLetterString ( string ) {
return string . length === 2 && isASCIIAlpha ( string . codePointAt ( 0 ) ) && ( string [ 1 ] === ":" || string [ 1 ] === "|" ) ;
}
function isNormalizedWindowsDriveLetterString ( string ) {
return string . length === 2 && isASCIIAlpha ( string . codePointAt ( 0 ) ) && string [ 1 ] === ":" ;
}
function containsForbiddenHostCodePoint ( string ) {
return string . search ( /\u0000|\u0009|\u000A|\u000D|\u0020|#|%|\/|:|\?|@|\[|\\|\]/ ) !== - 1 ;
}
function containsForbiddenHostCodePointExcludingPercent ( string ) {
return string . search ( /\u0000|\u0009|\u000A|\u000D|\u0020|#|\/|:|\?|@|\[|\\|\]/ ) !== - 1 ;
}
function isSpecialScheme ( scheme ) {
return specialSchemes [ scheme ] !== undefined ;
}
function isSpecial ( url ) {
return isSpecialScheme ( url . scheme ) ;
}
function defaultPort ( scheme ) {
return specialSchemes [ scheme ] ;
}
function percentEncode ( c ) {
let hex = c . toString ( 16 ) . toUpperCase ( ) ;
if ( hex . length === 1 ) {
hex = "0" + hex ;
}
return "%" + hex ;
}
function utf8PercentEncode ( c ) {
const buf = new Buffer ( c ) ;
let str = "" ;
for ( let i = 0 ; i < buf . length ; ++ i ) {
str += percentEncode ( buf [ i ] ) ;
}
return str ;
}
function utf8PercentDecode ( str ) {
const input = new Buffer ( str ) ;
const output = [ ] ;
for ( let i = 0 ; i < input . length ; ++ i ) {
if ( input [ i ] !== 37 ) {
output . push ( input [ i ] ) ;
} else if ( input [ i ] === 37 && isASCIIHex ( input [ i + 1 ] ) && isASCIIHex ( input [ i + 2 ] ) ) {
output . push ( parseInt ( input . slice ( i + 1 , i + 3 ) . toString ( ) , 16 ) ) ;
i += 2 ;
} else {
output . push ( input [ i ] ) ;
}
}
return new Buffer ( output ) . toString ( ) ;
}
function isC0ControlPercentEncode ( c ) {
return c <= 0x1F || c > 0x7E ;
}
const extraPathPercentEncodeSet = new Set ( [ 32 , 34 , 35 , 60 , 62 , 63 , 96 , 123 , 125 ] ) ;
function isPathPercentEncode ( c ) {
return isC0ControlPercentEncode ( c ) || extraPathPercentEncodeSet . has ( c ) ;
}
const extraUserinfoPercentEncodeSet =
new Set ( [ 47 , 58 , 59 , 61 , 64 , 91 , 92 , 93 , 94 , 124 ] ) ;
function isUserinfoPercentEncode ( c ) {
return isPathPercentEncode ( c ) || extraUserinfoPercentEncodeSet . has ( c ) ;
}
function percentEncodeChar ( c , encodeSetPredicate ) {
const cStr = String . fromCodePoint ( c ) ;
if ( encodeSetPredicate ( c ) ) {
return utf8PercentEncode ( cStr ) ;
}
return cStr ;
}
function parseIPv4Number ( input ) {
let R = 10 ;
if ( input . length >= 2 && input . charAt ( 0 ) === "0" && input . charAt ( 1 ) . toLowerCase ( ) === "x" ) {
input = input . substring ( 2 ) ;
R = 16 ;
} else if ( input . length >= 2 && input . charAt ( 0 ) === "0" ) {
input = input . substring ( 1 ) ;
R = 8 ;
}
if ( input === "" ) {
return 0 ;
}
const regex = R === 10 ? /[^0-9]/ : ( R === 16 ? /[^0-9A-Fa-f]/ : /[^0-7]/ ) ;
if ( regex . test ( input ) ) {
return failure ;
}
return parseInt ( input , R ) ;
}
function parseIPv4 ( input ) {
const parts = input . split ( "." ) ;
if ( parts [ parts . length - 1 ] === "" ) {
if ( parts . length > 1 ) {
parts . pop ( ) ;
}
}
if ( parts . length > 4 ) {
return input ;
}
const numbers = [ ] ;
for ( const part of parts ) {
if ( part === "" ) {
return input ;
}
const n = parseIPv4Number ( part ) ;
if ( n === failure ) {
return input ;
}
numbers . push ( n ) ;
}
for ( let i = 0 ; i < numbers . length - 1 ; ++ i ) {
if ( numbers [ i ] > 255 ) {
return failure ;
}
}
if ( numbers [ numbers . length - 1 ] >= Math . pow ( 256 , 5 - numbers . length ) ) {
return failure ;
}
let ipv4 = numbers . pop ( ) ;
let counter = 0 ;
for ( const n of numbers ) {
ipv4 += n * Math . pow ( 256 , 3 - counter ) ;
++ counter ;
}
return ipv4 ;
}
function serializeIPv4 ( address ) {
let output = "" ;
let n = address ;
for ( let i = 1 ; i <= 4 ; ++ i ) {
output = String ( n % 256 ) + output ;
if ( i !== 4 ) {
output = "." + output ;
}
n = Math . floor ( n / 256 ) ;
}
return output ;
}
function parseIPv6 ( input ) {
const address = [ 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 ] ;
let pieceIndex = 0 ;
let compress = null ;
let pointer = 0 ;
input = punycode . ucs2 . decode ( input ) ;
if ( input [ pointer ] === 58 ) {
if ( input [ pointer + 1 ] !== 58 ) {
return failure ;
}
pointer += 2 ;
++ pieceIndex ;
compress = pieceIndex ;
}
while ( pointer < input . length ) {
if ( pieceIndex === 8 ) {
return failure ;
}
if ( input [ pointer ] === 58 ) {
if ( compress !== null ) {
return failure ;
}
++ pointer ;
++ pieceIndex ;
compress = pieceIndex ;
continue ;
}
let value = 0 ;
let length = 0 ;
while ( length < 4 && isASCIIHex ( input [ pointer ] ) ) {
value = value * 0x10 + parseInt ( at ( input , pointer ) , 16 ) ;
++ pointer ;
++ length ;
}
if ( input [ pointer ] === 46 ) {
if ( length === 0 ) {
return failure ;
}
pointer -= length ;
if ( pieceIndex > 6 ) {
return failure ;
}
let numbersSeen = 0 ;
while ( input [ pointer ] !== undefined ) {
let ipv4Piece = null ;
if ( numbersSeen > 0 ) {
if ( input [ pointer ] === 46 && numbersSeen < 4 ) {
++ pointer ;
} else {
return failure ;
}
}
if ( ! isASCIIDigit ( input [ pointer ] ) ) {
return failure ;
}
while ( isASCIIDigit ( input [ pointer ] ) ) {
const number = parseInt ( at ( input , pointer ) ) ;
if ( ipv4Piece === null ) {
ipv4Piece = number ;
} else if ( ipv4Piece === 0 ) {
return failure ;
} else {
ipv4Piece = ipv4Piece * 10 + number ;
}
if ( ipv4Piece > 255 ) {
return failure ;
}
++ pointer ;
}
address [ pieceIndex ] = address [ pieceIndex ] * 0x100 + ipv4Piece ;
++ numbersSeen ;
if ( numbersSeen === 2 || numbersSeen === 4 ) {
++ pieceIndex ;
}
}
if ( numbersSeen !== 4 ) {
return failure ;
}
break ;
} else if ( input [ pointer ] === 58 ) {
++ pointer ;
if ( input [ pointer ] === undefined ) {
return failure ;
}
} else if ( input [ pointer ] !== undefined ) {
return failure ;
}
address [ pieceIndex ] = value ;
++ pieceIndex ;
}
if ( compress !== null ) {
let swaps = pieceIndex - compress ;
pieceIndex = 7 ;
while ( pieceIndex !== 0 && swaps > 0 ) {
const temp = address [ compress + swaps - 1 ] ;
address [ compress + swaps - 1 ] = address [ pieceIndex ] ;
address [ pieceIndex ] = temp ;
-- pieceIndex ;
-- swaps ;
}
} else if ( compress === null && pieceIndex !== 8 ) {
return failure ;
}
return address ;
}
function serializeIPv6 ( address ) {
let output = "" ;
const seqResult = findLongestZeroSequence ( address ) ;
const compress = seqResult . idx ;
let ignore0 = false ;
for ( let pieceIndex = 0 ; pieceIndex <= 7 ; ++ pieceIndex ) {
if ( ignore0 && address [ pieceIndex ] === 0 ) {
continue ;
} else if ( ignore0 ) {
ignore0 = false ;
}
if ( compress === pieceIndex ) {
const separator = pieceIndex === 0 ? "::" : ":" ;
output += separator ;
ignore0 = true ;
continue ;
}
output += address [ pieceIndex ] . toString ( 16 ) ;
if ( pieceIndex !== 7 ) {
output += ":" ;
}
}
return output ;
}
function parseHost ( input , isSpecialArg ) {
if ( input [ 0 ] === "[" ) {
if ( input [ input . length - 1 ] !== "]" ) {
return failure ;
}
return parseIPv6 ( input . substring ( 1 , input . length - 1 ) ) ;
}
if ( ! isSpecialArg ) {
return parseOpaqueHost ( input ) ;
}
const domain = utf8PercentDecode ( input ) ;
const asciiDomain = tr46 . toASCII ( domain , false , tr46 . PROCESSING _OPTIONS . NONTRANSITIONAL , false ) ;
if ( asciiDomain === null ) {
return failure ;
}
if ( containsForbiddenHostCodePoint ( asciiDomain ) ) {
return failure ;
}
const ipv4Host = parseIPv4 ( asciiDomain ) ;
if ( typeof ipv4Host === "number" || ipv4Host === failure ) {
return ipv4Host ;
}
return asciiDomain ;
}
function parseOpaqueHost ( input ) {
if ( containsForbiddenHostCodePointExcludingPercent ( input ) ) {
return failure ;
}
let output = "" ;
const decoded = punycode . ucs2 . decode ( input ) ;
for ( let i = 0 ; i < decoded . length ; ++ i ) {
output += percentEncodeChar ( decoded [ i ] , isC0ControlPercentEncode ) ;
}
return output ;
}
function findLongestZeroSequence ( arr ) {
let maxIdx = null ;
let maxLen = 1 ; // only find elements > 1
let currStart = null ;
let currLen = 0 ;
for ( let i = 0 ; i < arr . length ; ++ i ) {
if ( arr [ i ] !== 0 ) {
if ( currLen > maxLen ) {
maxIdx = currStart ;
maxLen = currLen ;
}
currStart = null ;
currLen = 0 ;
} else {
if ( currStart === null ) {
currStart = i ;
}
++ currLen ;
}
}
// if trailing zeros
if ( currLen > maxLen ) {
maxIdx = currStart ;
maxLen = currLen ;
}
return {
idx : maxIdx ,
len : maxLen
} ;
}
function serializeHost ( host ) {
if ( typeof host === "number" ) {
return serializeIPv4 ( host ) ;
}
// IPv6 serializer
if ( host instanceof Array ) {
return "[" + serializeIPv6 ( host ) + "]" ;
}
return host ;
}
function trimControlChars ( url ) {
return url . replace ( /^[\u0000-\u001F\u0020]+|[\u0000-\u001F\u0020]+$/g , "" ) ;
}
function trimTabAndNewline ( url ) {
return url . replace ( /\u0009|\u000A|\u000D/g , "" ) ;
}
function shortenPath ( url ) {
const path = url . path ;
if ( path . length === 0 ) {
return ;
}
if ( url . scheme === "file" && path . length === 1 && isNormalizedWindowsDriveLetter ( path [ 0 ] ) ) {
return ;
}
path . pop ( ) ;
}
function includesCredentials ( url ) {
return url . username !== "" || url . password !== "" ;
}
function cannotHaveAUsernamePasswordPort ( url ) {
return url . host === null || url . host === "" || url . cannotBeABaseURL || url . scheme === "file" ;
}
function isNormalizedWindowsDriveLetter ( string ) {
return /^[A-Za-z]:$/ . test ( string ) ;
}
function URLStateMachine ( input , base , encodingOverride , url , stateOverride ) {
this . pointer = 0 ;
this . input = input ;
this . base = base || null ;
this . encodingOverride = encodingOverride || "utf-8" ;
this . stateOverride = stateOverride ;
this . url = url ;
this . failure = false ;
this . parseError = false ;
if ( ! this . url ) {
this . url = {
scheme : "" ,
username : "" ,
password : "" ,
host : null ,
port : null ,
path : [ ] ,
query : null ,
fragment : null ,
cannotBeABaseURL : false
} ;
const res = trimControlChars ( this . input ) ;
if ( res !== this . input ) {
this . parseError = true ;
}
this . input = res ;
}
const res = trimTabAndNewline ( this . input ) ;
if ( res !== this . input ) {
this . parseError = true ;
}
this . input = res ;
this . state = stateOverride || "scheme start" ;
this . buffer = "" ;
this . atFlag = false ;
this . arrFlag = false ;
this . passwordTokenSeenFlag = false ;
this . input = punycode . ucs2 . decode ( this . input ) ;
for ( ; this . pointer <= this . input . length ; ++ this . pointer ) {
const c = this . input [ this . pointer ] ;
const cStr = isNaN ( c ) ? undefined : String . fromCodePoint ( c ) ;
// exec state machine
const ret = this [ "parse " + this . state ] ( c , cStr ) ;
if ( ! ret ) {
break ; // terminate algorithm
} else if ( ret === failure ) {
this . failure = true ;
break ;
}
}
}
URLStateMachine . prototype [ "parse scheme start" ] = function parseSchemeStart ( c , cStr ) {
if ( isASCIIAlpha ( c ) ) {
this . buffer += cStr . toLowerCase ( ) ;
this . state = "scheme" ;
} else if ( ! this . stateOverride ) {
this . state = "no scheme" ;
-- this . pointer ;
} else {
this . parseError = true ;
return failure ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse scheme" ] = function parseScheme ( c , cStr ) {
if ( isASCIIAlphanumeric ( c ) || c === 43 || c === 45 || c === 46 ) {
this . buffer += cStr . toLowerCase ( ) ;
} else if ( c === 58 ) {
if ( this . stateOverride ) {
if ( isSpecial ( this . url ) && ! isSpecialScheme ( this . buffer ) ) {
return false ;
}
if ( ! isSpecial ( this . url ) && isSpecialScheme ( this . buffer ) ) {
return false ;
}
if ( ( includesCredentials ( this . url ) || this . url . port !== null ) && this . buffer === "file" ) {
return false ;
}
if ( this . url . scheme === "file" && ( this . url . host === "" || this . url . host === null ) ) {
return false ;
}
}
this . url . scheme = this . buffer ;
this . buffer = "" ;
if ( this . stateOverride ) {
return false ;
}
if ( this . url . scheme === "file" ) {
if ( this . input [ this . pointer + 1 ] !== 47 || this . input [ this . pointer + 2 ] !== 47 ) {
this . parseError = true ;
}
this . state = "file" ;
} else if ( isSpecial ( this . url ) && this . base !== null && this . base . scheme === this . url . scheme ) {
this . state = "special relative or authority" ;
} else if ( isSpecial ( this . url ) ) {
this . state = "special authority slashes" ;
} else if ( this . input [ this . pointer + 1 ] === 47 ) {
this . state = "path or authority" ;
++ this . pointer ;
} else {
this . url . cannotBeABaseURL = true ;
this . url . path . push ( "" ) ;
this . state = "cannot-be-a-base-URL path" ;
}
} else if ( ! this . stateOverride ) {
this . buffer = "" ;
this . state = "no scheme" ;
this . pointer = - 1 ;
} else {
this . parseError = true ;
return failure ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse no scheme" ] = function parseNoScheme ( c ) {
if ( this . base === null || ( this . base . cannotBeABaseURL && c !== 35 ) ) {
return failure ;
} else if ( this . base . cannotBeABaseURL && c === 35 ) {
this . url . scheme = this . base . scheme ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = this . base . query ;
this . url . fragment = "" ;
this . url . cannotBeABaseURL = true ;
this . state = "fragment" ;
} else if ( this . base . scheme === "file" ) {
this . state = "file" ;
-- this . pointer ;
} else {
this . state = "relative" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse special relative or authority" ] = function parseSpecialRelativeOrAuthority ( c ) {
if ( c === 47 && this . input [ this . pointer + 1 ] === 47 ) {
this . state = "special authority ignore slashes" ;
++ this . pointer ;
} else {
this . parseError = true ;
this . state = "relative" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse path or authority" ] = function parsePathOrAuthority ( c ) {
if ( c === 47 ) {
this . state = "authority" ;
} else {
this . state = "path" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse relative" ] = function parseRelative ( c ) {
this . url . scheme = this . base . scheme ;
if ( isNaN ( c ) ) {
this . url . username = this . base . username ;
this . url . password = this . base . password ;
this . url . host = this . base . host ;
this . url . port = this . base . port ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = this . base . query ;
} else if ( c === 47 ) {
this . state = "relative slash" ;
} else if ( c === 63 ) {
this . url . username = this . base . username ;
this . url . password = this . base . password ;
this . url . host = this . base . host ;
this . url . port = this . base . port ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = "" ;
this . state = "query" ;
} else if ( c === 35 ) {
this . url . username = this . base . username ;
this . url . password = this . base . password ;
this . url . host = this . base . host ;
this . url . port = this . base . port ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = this . base . query ;
this . url . fragment = "" ;
this . state = "fragment" ;
} else if ( isSpecial ( this . url ) && c === 92 ) {
this . parseError = true ;
this . state = "relative slash" ;
} else {
this . url . username = this . base . username ;
this . url . password = this . base . password ;
this . url . host = this . base . host ;
this . url . port = this . base . port ;
this . url . path = this . base . path . slice ( 0 , this . base . path . length - 1 ) ;
this . state = "path" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse relative slash" ] = function parseRelativeSlash ( c ) {
if ( isSpecial ( this . url ) && ( c === 47 || c === 92 ) ) {
if ( c === 92 ) {
this . parseError = true ;
}
this . state = "special authority ignore slashes" ;
} else if ( c === 47 ) {
this . state = "authority" ;
} else {
this . url . username = this . base . username ;
this . url . password = this . base . password ;
this . url . host = this . base . host ;
this . url . port = this . base . port ;
this . state = "path" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse special authority slashes" ] = function parseSpecialAuthoritySlashes ( c ) {
if ( c === 47 && this . input [ this . pointer + 1 ] === 47 ) {
this . state = "special authority ignore slashes" ;
++ this . pointer ;
} else {
this . parseError = true ;
this . state = "special authority ignore slashes" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse special authority ignore slashes" ] = function parseSpecialAuthorityIgnoreSlashes ( c ) {
if ( c !== 47 && c !== 92 ) {
this . state = "authority" ;
-- this . pointer ;
} else {
this . parseError = true ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse authority" ] = function parseAuthority ( c , cStr ) {
if ( c === 64 ) {
this . parseError = true ;
if ( this . atFlag ) {
this . buffer = "%40" + this . buffer ;
}
this . atFlag = true ;
// careful, this is based on buffer and has its own pointer (this.pointer != pointer) and inner chars
const len = countSymbols ( this . buffer ) ;
for ( let pointer = 0 ; pointer < len ; ++ pointer ) {
const codePoint = this . buffer . codePointAt ( pointer ) ;
if ( codePoint === 58 && ! this . passwordTokenSeenFlag ) {
this . passwordTokenSeenFlag = true ;
continue ;
}
const encodedCodePoints = percentEncodeChar ( codePoint , isUserinfoPercentEncode ) ;
if ( this . passwordTokenSeenFlag ) {
this . url . password += encodedCodePoints ;
} else {
this . url . username += encodedCodePoints ;
}
}
this . buffer = "" ;
} else if ( isNaN ( c ) || c === 47 || c === 63 || c === 35 ||
( isSpecial ( this . url ) && c === 92 ) ) {
if ( this . atFlag && this . buffer === "" ) {
this . parseError = true ;
return failure ;
}
this . pointer -= countSymbols ( this . buffer ) + 1 ;
this . buffer = "" ;
this . state = "host" ;
} else {
this . buffer += cStr ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse hostname" ] =
URLStateMachine . prototype [ "parse host" ] = function parseHostName ( c , cStr ) {
if ( this . stateOverride && this . url . scheme === "file" ) {
-- this . pointer ;
this . state = "file host" ;
} else if ( c === 58 && ! this . arrFlag ) {
if ( this . buffer === "" ) {
this . parseError = true ;
return failure ;
}
const host = parseHost ( this . buffer , isSpecial ( this . url ) ) ;
if ( host === failure ) {
return failure ;
}
this . url . host = host ;
this . buffer = "" ;
this . state = "port" ;
if ( this . stateOverride === "hostname" ) {
return false ;
}
} else if ( isNaN ( c ) || c === 47 || c === 63 || c === 35 ||
( isSpecial ( this . url ) && c === 92 ) ) {
-- this . pointer ;
if ( isSpecial ( this . url ) && this . buffer === "" ) {
this . parseError = true ;
return failure ;
} else if ( this . stateOverride && this . buffer === "" &&
( includesCredentials ( this . url ) || this . url . port !== null ) ) {
this . parseError = true ;
return false ;
}
const host = parseHost ( this . buffer , isSpecial ( this . url ) ) ;
if ( host === failure ) {
return failure ;
}
this . url . host = host ;
this . buffer = "" ;
this . state = "path start" ;
if ( this . stateOverride ) {
return false ;
}
} else {
if ( c === 91 ) {
this . arrFlag = true ;
} else if ( c === 93 ) {
this . arrFlag = false ;
}
this . buffer += cStr ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse port" ] = function parsePort ( c , cStr ) {
if ( isASCIIDigit ( c ) ) {
this . buffer += cStr ;
} else if ( isNaN ( c ) || c === 47 || c === 63 || c === 35 ||
( isSpecial ( this . url ) && c === 92 ) ||
this . stateOverride ) {
if ( this . buffer !== "" ) {
const port = parseInt ( this . buffer ) ;
if ( port > Math . pow ( 2 , 16 ) - 1 ) {
this . parseError = true ;
return failure ;
}
this . url . port = port === defaultPort ( this . url . scheme ) ? null : port ;
this . buffer = "" ;
}
if ( this . stateOverride ) {
return false ;
}
this . state = "path start" ;
-- this . pointer ;
} else {
this . parseError = true ;
return failure ;
}
return true ;
} ;
const fileOtherwiseCodePoints = new Set ( [ 47 , 92 , 63 , 35 ] ) ;
URLStateMachine . prototype [ "parse file" ] = function parseFile ( c ) {
this . url . scheme = "file" ;
if ( c === 47 || c === 92 ) {
if ( c === 92 ) {
this . parseError = true ;
}
this . state = "file slash" ;
} else if ( this . base !== null && this . base . scheme === "file" ) {
if ( isNaN ( c ) ) {
this . url . host = this . base . host ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = this . base . query ;
} else if ( c === 63 ) {
this . url . host = this . base . host ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = "" ;
this . state = "query" ;
} else if ( c === 35 ) {
this . url . host = this . base . host ;
this . url . path = this . base . path . slice ( ) ;
this . url . query = this . base . query ;
this . url . fragment = "" ;
this . state = "fragment" ;
} else {
if ( this . input . length - this . pointer - 1 === 0 || // remaining consists of 0 code points
! isWindowsDriveLetterCodePoints ( c , this . input [ this . pointer + 1 ] ) ||
( this . input . length - this . pointer - 1 >= 2 && // remaining has at least 2 code points
! fileOtherwiseCodePoints . has ( this . input [ this . pointer + 2 ] ) ) ) {
this . url . host = this . base . host ;
this . url . path = this . base . path . slice ( ) ;
shortenPath ( this . url ) ;
} else {
this . parseError = true ;
}
this . state = "path" ;
-- this . pointer ;
}
} else {
this . state = "path" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse file slash" ] = function parseFileSlash ( c ) {
if ( c === 47 || c === 92 ) {
if ( c === 92 ) {
this . parseError = true ;
}
this . state = "file host" ;
} else {
if ( this . base !== null && this . base . scheme === "file" ) {
if ( isNormalizedWindowsDriveLetterString ( this . base . path [ 0 ] ) ) {
this . url . path . push ( this . base . path [ 0 ] ) ;
} else {
this . url . host = this . base . host ;
}
}
this . state = "path" ;
-- this . pointer ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse file host" ] = function parseFileHost ( c , cStr ) {
if ( isNaN ( c ) || c === 47 || c === 92 || c === 63 || c === 35 ) {
-- this . pointer ;
if ( ! this . stateOverride && isWindowsDriveLetterString ( this . buffer ) ) {
this . parseError = true ;
this . state = "path" ;
} else if ( this . buffer === "" ) {
this . url . host = "" ;
if ( this . stateOverride ) {
return false ;
}
this . state = "path start" ;
} else {
let host = parseHost ( this . buffer , isSpecial ( this . url ) ) ;
if ( host === failure ) {
return failure ;
}
if ( host === "localhost" ) {
host = "" ;
}
this . url . host = host ;
if ( this . stateOverride ) {
return false ;
}
this . buffer = "" ;
this . state = "path start" ;
}
} else {
this . buffer += cStr ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse path start" ] = function parsePathStart ( c ) {
if ( isSpecial ( this . url ) ) {
if ( c === 92 ) {
this . parseError = true ;
}
this . state = "path" ;
if ( c !== 47 && c !== 92 ) {
-- this . pointer ;
}
} else if ( ! this . stateOverride && c === 63 ) {
this . url . query = "" ;
this . state = "query" ;
} else if ( ! this . stateOverride && c === 35 ) {
this . url . fragment = "" ;
this . state = "fragment" ;
} else if ( c !== undefined ) {
this . state = "path" ;
if ( c !== 47 ) {
-- this . pointer ;
}
}
return true ;
} ;
URLStateMachine . prototype [ "parse path" ] = function parsePath ( c ) {
if ( isNaN ( c ) || c === 47 || ( isSpecial ( this . url ) && c === 92 ) ||
( ! this . stateOverride && ( c === 63 || c === 35 ) ) ) {
if ( isSpecial ( this . url ) && c === 92 ) {
this . parseError = true ;
}
if ( isDoubleDot ( this . buffer ) ) {
shortenPath ( this . url ) ;
if ( c !== 47 && ! ( isSpecial ( this . url ) && c === 92 ) ) {
this . url . path . push ( "" ) ;
}
} else if ( isSingleDot ( this . buffer ) && c !== 47 &&
! ( isSpecial ( this . url ) && c === 92 ) ) {
this . url . path . push ( "" ) ;
} else if ( ! isSingleDot ( this . buffer ) ) {
if ( this . url . scheme === "file" && this . url . path . length === 0 && isWindowsDriveLetterString ( this . buffer ) ) {
if ( this . url . host !== "" && this . url . host !== null ) {
this . parseError = true ;
this . url . host = "" ;
}
this . buffer = this . buffer [ 0 ] + ":" ;
}
this . url . path . push ( this . buffer ) ;
}
this . buffer = "" ;
if ( this . url . scheme === "file" && ( c === undefined || c === 63 || c === 35 ) ) {
while ( this . url . path . length > 1 && this . url . path [ 0 ] === "" ) {
this . parseError = true ;
this . url . path . shift ( ) ;
}
}
if ( c === 63 ) {
this . url . query = "" ;
this . state = "query" ;
}
if ( c === 35 ) {
this . url . fragment = "" ;
this . state = "fragment" ;
}
} else {
// TODO: If c is not a URL code point and not "%", parse error.
if ( c === 37 &&
( ! isASCIIHex ( this . input [ this . pointer + 1 ] ) ||
! isASCIIHex ( this . input [ this . pointer + 2 ] ) ) ) {
this . parseError = true ;
}
this . buffer += percentEncodeChar ( c , isPathPercentEncode ) ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse cannot-be-a-base-URL path" ] = function parseCannotBeABaseURLPath ( c ) {
if ( c === 63 ) {
this . url . query = "" ;
this . state = "query" ;
} else if ( c === 35 ) {
this . url . fragment = "" ;
this . state = "fragment" ;
} else {
// TODO: Add: not a URL code point
if ( ! isNaN ( c ) && c !== 37 ) {
this . parseError = true ;
}
if ( c === 37 &&
( ! isASCIIHex ( this . input [ this . pointer + 1 ] ) ||
! isASCIIHex ( this . input [ this . pointer + 2 ] ) ) ) {
this . parseError = true ;
}
if ( ! isNaN ( c ) ) {
this . url . path [ 0 ] = this . url . path [ 0 ] + percentEncodeChar ( c , isC0ControlPercentEncode ) ;
}
}
return true ;
} ;
URLStateMachine . prototype [ "parse query" ] = function parseQuery ( c , cStr ) {
if ( isNaN ( c ) || ( ! this . stateOverride && c === 35 ) ) {
if ( ! isSpecial ( this . url ) || this . url . scheme === "ws" || this . url . scheme === "wss" ) {
this . encodingOverride = "utf-8" ;
}
const buffer = new Buffer ( this . buffer ) ; // TODO: Use encoding override instead
for ( let i = 0 ; i < buffer . length ; ++ i ) {
if ( buffer [ i ] < 0x21 || buffer [ i ] > 0x7E || buffer [ i ] === 0x22 || buffer [ i ] === 0x23 ||
buffer [ i ] === 0x3C || buffer [ i ] === 0x3E ) {
this . url . query += percentEncode ( buffer [ i ] ) ;
} else {
this . url . query += String . fromCodePoint ( buffer [ i ] ) ;
}
}
this . buffer = "" ;
if ( c === 35 ) {
this . url . fragment = "" ;
this . state = "fragment" ;
}
} else {
// TODO: If c is not a URL code point and not "%", parse error.
if ( c === 37 &&
( ! isASCIIHex ( this . input [ this . pointer + 1 ] ) ||
! isASCIIHex ( this . input [ this . pointer + 2 ] ) ) ) {
this . parseError = true ;
}
this . buffer += cStr ;
}
return true ;
} ;
URLStateMachine . prototype [ "parse fragment" ] = function parseFragment ( c ) {
if ( isNaN ( c ) ) { // do nothing
} else if ( c === 0x0 ) {
this . parseError = true ;
} else {
// TODO: If c is not a URL code point and not "%", parse error.
if ( c === 37 &&
( ! isASCIIHex ( this . input [ this . pointer + 1 ] ) ||
! isASCIIHex ( this . input [ this . pointer + 2 ] ) ) ) {
this . parseError = true ;
}
this . url . fragment += percentEncodeChar ( c , isC0ControlPercentEncode ) ;
}
return true ;
} ;
function serializeURL ( url , excludeFragment ) {
let output = url . scheme + ":" ;
if ( url . host !== null ) {
output += "//" ;
if ( url . username !== "" || url . password !== "" ) {
output += url . username ;
if ( url . password !== "" ) {
output += ":" + url . password ;
}
output += "@" ;
}
output += serializeHost ( url . host ) ;
if ( url . port !== null ) {
output += ":" + url . port ;
}
} else if ( url . host === null && url . scheme === "file" ) {
output += "//" ;
}
if ( url . cannotBeABaseURL ) {
output += url . path [ 0 ] ;
} else {
for ( const string of url . path ) {
output += "/" + string ;
}
}
if ( url . query !== null ) {
output += "?" + url . query ;
}
if ( ! excludeFragment && url . fragment !== null ) {
output += "#" + url . fragment ;
}
return output ;
}
function serializeOrigin ( tuple ) {
let result = tuple . scheme + "://" ;
result += serializeHost ( tuple . host ) ;
if ( tuple . port !== null ) {
result += ":" + tuple . port ;
}
return result ;
}
module . exports . serializeURL = serializeURL ;
module . exports . serializeURLOrigin = function ( url ) {
// https://url.spec.whatwg.org/#concept-url-origin
switch ( url . scheme ) {
case "blob" :
try {
return module . exports . serializeURLOrigin ( module . exports . parseURL ( url . path [ 0 ] ) ) ;
} catch ( e ) {
// serializing an opaque origin returns "null"
return "null" ;
}
case "ftp" :
case "gopher" :
case "http" :
case "https" :
case "ws" :
case "wss" :
return serializeOrigin ( {
scheme : url . scheme ,
host : url . host ,
port : url . port
} ) ;
case "file" :
// spec says "exercise to the reader", chrome says "file://"
return "file://" ;
default :
// serializing an opaque origin returns "null"
return "null" ;
}
} ;
module . exports . basicURLParse = function ( input , options ) {
if ( options === undefined ) {
options = { } ;
}
const usm = new URLStateMachine ( input , options . baseURL , options . encodingOverride , options . url , options . stateOverride ) ;
if ( usm . failure ) {
return "failure" ;
}
return usm . url ;
} ;
module . exports . setTheUsername = function ( url , username ) {
url . username = "" ;
const decoded = punycode . ucs2 . decode ( username ) ;
for ( let i = 0 ; i < decoded . length ; ++ i ) {
url . username += percentEncodeChar ( decoded [ i ] , isUserinfoPercentEncode ) ;
}
} ;
module . exports . setThePassword = function ( url , password ) {
url . password = "" ;
const decoded = punycode . ucs2 . decode ( password ) ;
for ( let i = 0 ; i < decoded . length ; ++ i ) {
url . password += percentEncodeChar ( decoded [ i ] , isUserinfoPercentEncode ) ;
}
} ;
module . exports . serializeHost = serializeHost ;
module . exports . cannotHaveAUsernamePasswordPort = cannotHaveAUsernamePasswordPort ;
module . exports . serializeInteger = function ( integer ) {
return String ( integer ) ;
} ;
module . exports . parseURL = function ( input , options ) {
if ( options === undefined ) {
options = { } ;
}
// We don't handle blobs, so this just delegates:
return module . exports . basicURLParse ( input , { baseURL : options . baseURL , encodingOverride : options . encodingOverride } ) ;
} ;
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 3185 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
module . exports . mixin = function mixin ( target , source ) {
const keys = Object . getOwnPropertyNames ( source ) ;
for ( let i = 0 ; i < keys . length ; ++ i ) {
Object . defineProperty ( target , keys [ i ] , Object . getOwnPropertyDescriptor ( source , keys [ i ] ) ) ;
}
} ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
module . exports . wrapperSymbol = Symbol ( "wrapper" ) ;
module . exports . implSymbol = Symbol ( "impl" ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
module . exports . wrapperForImpl = function ( impl ) {
return impl [ module . exports . wrapperSymbol ] ;
} ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
module . exports . implForWrapper = function ( wrapper ) {
return wrapper [ module . exports . implSymbol ] ;
} ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 4207 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
module . exports = which
which . sync = whichSync
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var isWindows = process . platform === 'win32' ||
process . env . OSTYPE === 'cygwin' ||
process . env . OSTYPE === 'msys'
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var path = _ _nccwpck _require _ _ ( 1017 )
var COLON = isWindows ? ';' : ':'
var isexe = _ _nccwpck _require _ _ ( 7126 )
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
function getNotFoundError ( cmd ) {
var er = new Error ( 'not found: ' + cmd )
er . code = 'ENOENT'
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
return er
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
function getPathInfo ( cmd , opt ) {
var colon = opt . colon || COLON
var pathEnv = opt . path || process . env . PATH || ''
var pathExt = [ '' ]
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
pathEnv = pathEnv . split ( colon )
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var pathExtExe = ''
if ( isWindows ) {
pathEnv . unshift ( process . cwd ( ) )
pathExtExe = ( opt . pathExt || process . env . PATHEXT || '.EXE;.CMD;.BAT;.COM' )
pathExt = pathExtExe . split ( colon )
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
// Always test the cmd itself first. isexe will check to make sure
// it's found in the pathExt set.
if ( cmd . indexOf ( '.' ) !== - 1 && pathExt [ 0 ] !== '' )
pathExt . unshift ( '' )
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
// If it has a slash, then we don't bother searching the pathenv.
// just check the file itself, and that's it.
if ( cmd . match ( /\// ) || isWindows && cmd . match ( /\\/ ) )
pathEnv = [ '' ]
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
return {
env : pathEnv ,
ext : pathExt ,
extExe : pathExtExe
}
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
function which ( cmd , opt , cb ) {
if ( typeof opt === 'function' ) {
cb = opt
opt = { }
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var info = getPathInfo ( cmd , opt )
var pathEnv = info . env
var pathExt = info . ext
var pathExtExe = info . extExe
var found = [ ]
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
; ( function F ( i , l ) {
if ( i === l ) {
if ( opt . all && found . length )
return cb ( null , found )
else
return cb ( getNotFoundError ( cmd ) )
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var pathPart = pathEnv [ i ]
if ( pathPart . charAt ( 0 ) === '"' && pathPart . slice ( - 1 ) === '"' )
pathPart = pathPart . slice ( 1 , - 1 )
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var p = path . join ( pathPart , cmd )
if ( ! pathPart && ( /^\.[\\\/]/ ) . test ( cmd ) ) {
p = cmd . slice ( 0 , 2 ) + p
}
; ( function E ( ii , ll ) {
if ( ii === ll ) return F ( i + 1 , l )
var ext = pathExt [ ii ]
isexe ( p + ext , { pathExt : pathExtExe } , function ( er , is ) {
if ( ! er && is ) {
if ( opt . all )
found . push ( p + ext )
else
return cb ( null , p + ext )
}
return E ( ii + 1 , ll )
} )
} ) ( 0 , pathExt . length )
} ) ( 0 , pathEnv . length )
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
function whichSync ( cmd , opt ) {
opt = opt || { }
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var info = getPathInfo ( cmd , opt )
var pathEnv = info . env
var pathExt = info . ext
var pathExtExe = info . extExe
var found = [ ]
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
for ( var i = 0 , l = pathEnv . length ; i < l ; i ++ ) {
var pathPart = pathEnv [ i ]
if ( pathPart . charAt ( 0 ) === '"' && pathPart . slice ( - 1 ) === '"' )
pathPart = pathPart . slice ( 1 , - 1 )
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
var p = path . join ( pathPart , cmd )
if ( ! pathPart && /^\.[\\\/]/ . test ( cmd ) ) {
p = cmd . slice ( 0 , 2 ) + p
}
for ( var j = 0 , ll = pathExt . length ; j < ll ; j ++ ) {
var cur = p + pathExt [ j ]
var is
try {
is = isexe . sync ( cur , { pathExt : pathExtExe } )
if ( is ) {
if ( opt . all )
found . push ( cur )
else
return cur
}
} catch ( ex ) { }
}
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
if ( opt . all && found . length )
return found
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
if ( opt . nothrow )
return null
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
throw getNotFoundError ( cmd )
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 3515 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
const os = _ _nccwpck _require _ _ ( 2037 ) ;
const execa = _ _nccwpck _require _ _ ( 5447 ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
// Reference: https://www.gaijin.at/en/lstwinver.php
const names = new Map ( [
[ '10.0' , '10' ] ,
[ '6.3' , '8.1' ] ,
[ '6.2' , '8' ] ,
[ '6.1' , '7' ] ,
[ '6.0' , 'Vista' ] ,
[ '5.2' , 'Server 2003' ] ,
[ '5.1' , 'XP' ] ,
[ '5.0' , '2000' ] ,
[ '4.9' , 'ME' ] ,
[ '4.1' , '98' ] ,
[ '4.0' , '95' ]
] ) ;
const windowsRelease = release => {
const version = /\d+\.\d/ . exec ( release || os . release ( ) ) ;
if ( release && ! version ) {
throw new Error ( '`release` argument doesn\'t match `n.n`' ) ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
const ver = ( version || [ ] ) [ 0 ] ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
// Server 2008, 2012, 2016, and 2019 versions are ambiguous with desktop versions and must be detected at runtime.
// If `release` is omitted or we're on a Windows system, and the version number is an ambiguous version
// then use `wmic` to get the OS caption: https://msdn.microsoft.com/en-us/library/aa394531(v=vs.85).aspx
// If `wmic` is obsoloete (later versions of Windows 10), use PowerShell instead.
// If the resulting caption contains the year 2008, 2012, 2016 or 2019, it is a server version, so return a server OS name.
if ( ( ! release || release === os . release ( ) ) && [ '6.1' , '6.2' , '6.3' , '10.0' ] . includes ( ver ) ) {
let stdout ;
try {
stdout = execa . sync ( 'wmic' , [ 'os' , 'get' , 'Caption' ] ) . stdout || '' ;
} catch ( _ ) {
stdout = execa . sync ( 'powershell' , [ '(Get-CimInstance -ClassName Win32_OperatingSystem).caption' ] ) . stdout || '' ;
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
const year = ( stdout . match ( /2008|2012|2016|2019/ ) || [ ] ) [ 0 ] ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
if ( year ) {
return ` Server ${ year } ` ;
}
2021-12-01 13:39:57 +01:00
}
2024-05-19 08:24:38 +02:00
return names . get ( ver ) ;
} ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
module . exports = windowsRelease ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 2940 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
// Returns a wrapper function that returns a wrapped callback
// The wrapper function should do some stuff, and return a
// presumably different callback function.
// This makes sure that own properties are retained, so that
// decorations and such are not lost along the way.
module . exports = wrappy
function wrappy ( fn , cb ) {
if ( fn && cb ) return wrappy ( fn ) ( cb )
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
if ( typeof fn !== 'function' )
throw new TypeError ( 'need wrapper function' )
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
Object . keys ( fn ) . forEach ( function ( k ) {
wrapper [ k ] = fn [ k ]
} )
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
return wrapper
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
function wrapper ( ) {
var args = new Array ( arguments . length )
for ( var i = 0 ; i < args . length ; i ++ ) {
args [ i ] = arguments [ i ]
}
var ret = fn . apply ( this , args )
var cb = args [ args . length - 1 ]
if ( typeof ret === 'function' && ret !== cb ) {
Object . keys ( cb ) . forEach ( function ( k ) {
ret [ k ] = cb [ k ]
} )
}
return ret
}
}
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 2877 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
module . exports = eval ( "require" ) ( "encoding" ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 9491 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "assert" ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 2081 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "child_process" ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 6113 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "crypto" ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 2361 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "events" ) ;
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 7147 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
module . exports = require ( "fs" ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 3685 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "http" ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 5687 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "https" ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 1808 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "net" ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 2037 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "os" ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
/***/ 1017 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "path" ) ;
2021-12-01 13:39:57 +01:00
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 5477 :
/***/ ( ( module ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "punycode" ) ;
2022-10-11 16:10:23 +02:00
2021-12-01 13:39:57 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 4521 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "readline" ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 2781 :
/***/ ( ( module ) => {
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "stream" ) ;
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2021-12-01 13:39:57 +01:00
2024-05-19 08:24:38 +02:00
/***/ 4404 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "tls" ) ;
2021-12-01 13:39:57 +01:00
2022-10-11 16:10:23 +02:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 7310 :
/***/ ( ( module ) => {
2022-10-11 16:10:23 +02:00
"use strict" ;
2024-05-19 08:24:38 +02:00
module . exports = require ( "url" ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 3837 :
/***/ ( ( module ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "util" ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 9796 :
/***/ ( ( module ) => {
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
"use strict" ;
module . exports = require ( "zlib" ) ;
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ } ) ,
2022-10-11 16:10:23 +02:00
2024-05-19 08:24:38 +02:00
/***/ 2587 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = JSON . parse ( '["assert","buffer","child_process","cluster","console","constants","crypto","dgram","dns","domain","events","fs","http","https","module","net","os","path","process","punycode","querystring","readline","repl","stream","string_decoder","timers","tls","tty","url","util","v8","vm","zlib"]' ) ;
2022-10-11 16:10:23 +02:00
2021-12-01 14:40:14 +01:00
/***/ } ) ,
2024-05-19 08:24:38 +02:00
/***/ 2020 :
/***/ ( ( module ) => {
2021-12-01 14:40:14 +01:00
"use strict" ;
2024-05-19 08:24:38 +02:00
module . exports = JSON . parse ( ' [ [ [ 0 , 44 ] , "disallowed_STD3_valid" ] , [ [ 45 , 46 ] , "valid" ] , [ [ 47 , 47 ] , "disallowed_STD3_valid" ] , [ [ 48 , 57 ] , "valid" ] , [ [ 58 , 64 ] , "disallowed_STD3_valid" ] , [ [ 65 , 65 ] , "mapped" , [ 97 ] ] , [ [ 66 , 66 ] , "mapped" , [ 98 ] ] , [ [ 67 , 67 ] , "mapped" , [ 99 ] ] , [ [ 68 , 68 ] , "mapped" , [ 100 ] ] , [ [ 69 , 69 ] , "mapped" , [ 101 ] ] , [ [ 70 , 70 ] , "mapped" , [ 102 ] ] , [ [ 71 , 71 ] , "mapped" , [ 103 ] ] , [ [ 72 , 72 ] , "mapped" , [ 104 ] ] , [ [ 73 , 73 ] , "mapped" , [ 105 ] ] , [ [ 74 , 74 ] , "mapped" , [ 106 ] ] , [ [ 75 , 75 ] , "mapped" , [ 107 ] ] , [ [ 76 , 76 ] , "mapped" , [ 108 ] ] , [ [ 77 , 77 ] , "mapped" , [ 109 ] ] , [ [ 78 , 78 ] , "mapped" , [ 110 ] ] , [ [ 79 , 79 ] , "mapped" , [ 111 ] ] , [ [ 80 , 80 ] , "mapped" , [ 112 ] ] , [ [ 81 , 81 ] , "mapped" , [ 113 ] ] , [ [ 82 , 82 ] , "mapped" , [ 114 ] ] , [ [ 83 , 83 ] , "mapped" , [ 115 ] ] , [ [ 84 , 84 ] , "mapped" , [ 116 ] ] , [ [ 85 , 85 ] , "mapped" , [ 117 ] ] , [ [ 86 , 86 ] , "mapped" , [ 118 ] ] , [ [ 87 , 87 ] , "mapped" , [ 119 ] ] , [ [ 88 , 88 ] , "mapped" , [ 120 ] ] , [ [ 89 , 89 ] , "mapped" , [ 121 ] ] , [ [ 90 , 90 ] , "mapped" , [ 122 ] ] , [ [ 91 , 96 ] , "disallowed_STD3_valid" ] , [ [ 97 , 122 ] , "valid" ] , [ [ 123 , 127 ] , "disallowed_STD3_valid" ] , [ [ 128 , 159 ] , "disallowed" ] , [ [ 160 , 160 ] , "disallowed_STD3_mapped" , [ 32 ] ] , [ [ 161 , 167 ] , "valid" , [ ] , "NV8" ] , [ [ 168 , 168 ] , "disallowed_STD3_mapped" , [ 32 , 776 ] ] , [ [ 169 , 169 ] , "valid" , [ ] , "NV8" ] , [ [ 170 , 170 ] , "mapped" , [ 97 ] ] , [ [ 171 , 172 ] , "valid" , [ ] , "NV8" ] , [ [ 173 , 173 ] , "ignored" ] , [ [ 174 , 174 ] , "valid" , [ ] , "NV8" ] , [ [ 175 , 175 ] , "disallowed_STD3_mapped" , [ 32 , 772 ] ] , [ [ 176 , 177 ] , "valid" , [ ] , "NV8" ] , [ [ 178 , 178 ] , "mapped" , [ 50 ] ] , [ [ 179 , 179 ] , "mapped" , [ 51 ] ] , [ [ 180 , 180 ] , "disallowed_STD3_mapped" , [ 32 , 769 ] ] , [ [ 181 , 181 ] , "mapped" , [ 956 ] ] , [ [ 182 , 182 ] , "valid" , [ ] , "NV8" ] , [ [ 183 , 183 ] , "valid" ] , [ [ 184 , 184 ] , "disallowed_STD3_mapped" , [ 32 , 807 ] ] , [ [ 185 , 185 ] , "mapped" , [ 49 ] ] , [ [ 186 , 186 ] , "mapped" , [ 111 ] ] , [ [ 187 , 187 ] , "valid" , [ ] , "NV8" ] , [ [ 188 , 188 ] , "mapped" , [ 49 , 8260 , 52 ] ] , [ [ 189 , 189 ] , "mapped" , [ 49 , 8260 , 50 ] ] , [ [ 190 , 190 ] , "mapped" , [ 51 , 8260 , 52 ] ] , [ [ 191 , 191 ] , "valid" , [ ] , "NV8" ] , [ [ 192 , 192 ] , "mapped" , [ 224 ] ] , [ [ 193 , 193 ] , "mapped" , [ 225 ] ] , [ [ 194 , 194 ] , "mapped" , [ 226 ] ] , [ [ 195 , 195 ] , "mapped" , [ 227 ] ] , [ [ 196 , 196 ] , "mapped" , [ 228 ] ] , [ [ 197 , 197 ] , "mapped" , [ 229 ] ] , [ [ 198 , 198 ] , "mapped" , [ 230 ] ] , [ [ 199 , 199 ] , "mapped" , [ 231 ] ] , [ [ 200 , 200 ] , "mapped" , [ 232 ] ] , [ [ 201 , 201 ] , "mapped" , [ 233 ] ] , [ [ 202 , 202 ] , "mapped" , [ 234 ] ] , [ [ 203 , 203 ] , "mapped" , [ 235 ] ] , [ [ 204 , 204 ] , "mapped" , [ 236 ] ] , [ [ 205 , 205 ] , "mapped" , [ 237 ] ] , [ [ 206 , 206 ] , "mapped" , [ 238 ] ] , [ [ 207 , 207 ] , "mapped" , [ 239 ] ] , [ [ 208 , 208 ] , "mapped" , [ 240 ] ] , [ [ 209 , 209 ] , "mapped" , [ 241 ] ] , [ [ 210 , 210 ] , "mapped" , [ 242 ] ] , [ [ 211 , 211 ] , "mapped" , [ 243 ] ] , [ [ 212 , 212 ] , "mapped" , [ 244 ] ] , [ [ 213 , 213 ] , "mapped" , [ 245 ] ] , [ [ 214 , 214 ] , "mapped" , [ 246 ] ] , [ [ 215 , 215 ] , "valid" , [ ] , "NV8" ] , [ [ 216 , 216 ] , "mapped" , [ 248 ] ] , [ [ 217 , 217 ] , "mapped" , [ 249 ] ] , [ [ 218 , 218 ] , "mapped" , [ 250 ] ] , [ [ 219 , 219 ] , "mapped" , [ 251 ] ] , [ [ 220 , 220 ] , "mapped" , [ 252 ] ] , [ [ 221 , 221 ] , "mapped" , [ 253 ] ] , [ [ 222 , 222 ] , "mapped" , [ 254 ] ] , [ [ 223 , 223 ] , "deviation" , [ 115 , 115 ] ] , [ [ 224 , 246 ] , "valid" ] , [ [ 247 , 247 ] , "valid" , [ ] , "NV8" ] , [ [ 248 , 255 ] , "valid" ] , [ [ 256 , 256 ] , "mapped" , [ 257 ] ] , [ [ 257 , 257 ] , "valid" ] , [ [ 258 , 258 ] , "mapped" , [ 259 ] ] , [ [ 259 , 259 ] , "valid" ] , [ [ 260 , 260 ] , "mapped" , [ 261 ] ] , [ [ 261 , 261 ] , "valid" ] , [ [ 262 , 262 ] , "mapped" , [ 263 ] ] , [ [ 263 , 263 ] , "valid" ] , [ [ 264 , 264 ] , "mapped" , [ 265 ] ] , [ [ 265 , 265 ] , "valid" ] , [ [ 266 , 266 ] , "mapped" , [ 267 ] ] , [ [ 267 , 267 ] , "valid" ] , [ [ 268 , 268 ] , "mapped" , [ 269 ] ] , [ [ 269 , 269 ] , "valid" ] , [ [ 270 , 270 ] , "mapped" , [ 271 ] ] , [ [ 271 , 271 ] , "valid" ] , [ [ 272 , 272 ] , "mapped" , [ 273 ] ] , [ [ 273 , 273 ] , "valid" ] , [ [ 274 , 274 ] , "mapped" , [ 275 ] ] , [ [ 275 , 275 ] , "valid" ] , [ [ 276 , 276 ] , "mapped" , [ 277 ] ] , [ [ 277 , 277 ] , "valid" ] , [ [ 278 , 278 ] , "mapped" , [ 279 ] ] , [ [ 279 , 279 ] , "valid" ] , [ [ 280 , 280 ] , "mapped" , [ 281 ] ] , [ [ 281 , 281 ] , "valid" ] , [ [ 282 , 282 ] , "mapped" , [ 283 ] ] , [ [ 283 , 283 ] , "valid" ] , [ [ 284 , 284 ] , "mapped" , [ 285 ] ] , [ [ 285 , 285 ] , "valid" ] , [ [ 286 , 286 ] , "mapped" , [ 287 ] ] , [ [ 287 , 287 ] , "valid" ] , [ [ 288 , 288 ] , "mapped" , [ 289 ] ] , [ [ 289 , 289 ] , "valid" ] , [ [ 290 , 290 ] , "mapped" , [ 291 ] ] , [ [ 291 , 291 ] , "valid" ] , [ [ 292 , 292 ] , "mapped" , [ 293 ] ] , [ [ 293 , 293 ] , "valid" ] , [ [ 294 , 294 ] , "mapped" , [ 295 ] ] , [ [ 295 , 295 ] , "valid" ] , [ [ 296 , 296 ] , "mapped" , [ 297 ] ] , [ [ 297 , 297 ] , "valid" ] , [ [ 298 , 298 ] , "mapped" , [ 299 ] ] , [ [ 299 , 299 ] , "valid" ] , [ [ 300 , 300 ] , "mapped" , [ 301 ] ] , [ [ 301 , 301 ] , "valid" ] , [ [ 302 , 302 ] , "mapped" , [ 303 ] ] , [ [ 303 , 303 ] , "valid" ] , [ [ 304 , 304 ] , "mapped" , [ 105 , 775 ] ] , [ [ 305 , 305 ] , "valid" ] , [ [ 306 , 307 ] , "mapped" , [ 105 , 106 ] ] , [ [ 308 , 308 ] , "mapped" , [ 309 ] ] , [ [ 309 , 309 ] , "valid" ] , [ [ 310 , 310 ] , "mapped" , [ 311 ] ] , [ [ 311 , 312 ] , "valid" ] , [ [ 313 , 313 ] , "mapped" , [ 314 ] ] , [ [ 314 , 314 ] , "valid" ] , [ [ 315 , 315 ] , "mapped" , [ 316 ] ] , [ [ 316 , 316 ] , "valid" ] , [ [ 317 , 317 ] , "mapped" , [ 318 ] ] , [ [ 318 , 318 ] , "valid" ] , [ [ 319 , 320 ] , "mapped" ,
2021-12-01 14:40:14 +01:00
2021-12-01 13:39:57 +01:00
/***/ } )
2024-05-19 08:24:38 +02:00
/******/ } ) ;
/************************************************************************/
/******/ // The module cache
/******/ var _ _webpack _module _cache _ _ = { } ;
/******/
/******/ // The require function
/******/ function _ _nccwpck _require _ _ ( moduleId ) {
/******/ // Check if module is in cache
/******/ var cachedModule = _ _webpack _module _cache _ _ [ moduleId ] ;
/******/ if ( cachedModule !== undefined ) {
/******/ return cachedModule . exports ;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = _ _webpack _module _cache _ _ [ moduleId ] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports : { }
/******/ } ;
/******/
/******/ // Execute the module function
/******/ var threw = true ;
/******/ try {
/******/ _ _webpack _modules _ _ [ moduleId ] . call ( module . exports , module , module . exports , _ _nccwpck _require _ _ ) ;
/******/ threw = false ;
/******/ } finally {
/******/ if ( threw ) delete _ _webpack _module _cache _ _ [ moduleId ] ;
/******/ }
/******/
/******/ // Return the exports of the module
/******/ return module . exports ;
/******/ }
/******/
/************************************************************************/
/******/ /* webpack/runtime/compat */
/******/
/******/ if ( typeof _ _nccwpck _require _ _ !== 'undefined' ) _ _nccwpck _require _ _ . ab = _ _dirname + "/" ;
/******/
/************************************************************************/
/******/
/******/ // startup
/******/ // Load entry module and return exports
/******/ // This entry module is referenced by other modules so it can't be inlined
/******/ var _ _webpack _exports _ _ = _ _nccwpck _require _ _ ( 3109 ) ;
/******/ module . exports = _ _webpack _exports _ _ ;
/******/
/******/ } ) ( )
;