2020-09-23 15:58:52 +09:00
/******/ ( ( ) => { // webpackBootstrap
/******/ var _ _webpack _modules _ _ = ( {
2024-09-29 18:20:46 +01:00
/***/ 9200 :
2021-02-25 02:15:04 +00:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2020-09-23 15:58:52 +09:00
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2022-12-09 07:26:20 +00:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2020-09-23 15:58:52 +09:00
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
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 . updateRepositoryDescription = exports . getToken = void 0 ;
2024-09-29 18:20:46 +01:00
const core = _ _importStar ( _ _nccwpck _require _ _ ( 7484 ) ) ;
const fetch = _ _importStar ( _ _nccwpck _require _ _ ( 6705 ) ) ;
2020-09-23 15:58:52 +09:00
function getToken ( username , password ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const body = {
username : username ,
password : password
} ;
const response = yield fetch ( 'https://hub.docker.com/v2/users/login' , {
method : 'post' ,
body : JSON . stringify ( body ) ,
headers : { 'Content-Type' : 'application/json' }
} ) ;
2021-06-15 10:42:23 +09:00
if ( ! response . ok ) {
throw new Error ( ` Unexpected response: ${ response . status } ${ response . statusText } ` ) ;
}
2020-09-23 15:58:52 +09:00
const json = yield response . json ( ) ;
core . setSecret ( json [ 'token' ] ) ;
return json [ 'token' ] ;
} ) ;
}
exports . getToken = getToken ;
2020-09-25 15:22:36 +09:00
function updateRepositoryDescription ( token , repository , description , fullDescription ) {
2020-09-23 15:58:52 +09:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const body = {
full _description : fullDescription
} ;
2020-09-25 15:22:36 +09:00
if ( description ) {
2023-04-07 09:16:46 +09:00
body [ 'description' ] = description ;
2020-09-25 15:22:36 +09:00
}
2020-09-23 15:58:52 +09:00
yield fetch ( ` https://hub.docker.com/v2/repositories/ ${ repository } ` , {
method : 'patch' ,
body : JSON . stringify ( body ) ,
headers : {
'Content-Type' : 'application/json' ,
Authorization : ` JWT ${ token } `
}
2020-10-27 10:41:21 +09:00
} ) . then ( res => {
if ( ! res . ok ) {
throw new Error ( res . statusText ) ;
}
2020-09-23 15:58:52 +09:00
} ) ;
} ) ;
}
exports . updateRepositoryDescription = updateRepositoryDescription ;
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 5285 :
2021-02-25 02:15:04 +00:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2020-09-23 15:58:52 +09:00
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2022-12-09 07:26:20 +00:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2020-09-23 15:58:52 +09:00
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . validateInputs = exports . getInputs = void 0 ;
2024-09-29 18:20:46 +01:00
const core = _ _importStar ( _ _nccwpck _require _ _ ( 7484 ) ) ;
const readmeHelper = _ _importStar ( _ _nccwpck _require _ _ ( 4481 ) ) ;
2020-09-23 15:58:52 +09:00
function getInputs ( ) {
const inputs = {
2020-09-25 11:13:16 +09:00
username : core . getInput ( 'username' ) ,
password : core . getInput ( 'password' ) ,
repository : core . getInput ( 'repository' ) ,
2020-09-25 15:22:36 +09:00
shortDescription : core . getInput ( 'short-description' ) ,
2023-03-05 11:13:27 +09:00
readmeFilepath : core . getInput ( 'readme-filepath' ) ,
enableUrlCompletion : Boolean ( core . getInput ( 'enable-url-completion' ) ) ,
imageExtensions : core . getInput ( 'image-extensions' )
2020-09-23 15:58:52 +09:00
} ;
// Environment variable input alternatives and their aliases
2020-09-25 11:13:16 +09:00
if ( ! inputs . username && process . env [ 'DOCKERHUB_USERNAME' ] ) {
inputs . username = process . env [ 'DOCKERHUB_USERNAME' ] ;
2020-09-23 15:58:52 +09:00
}
2020-09-25 11:13:16 +09:00
if ( ! inputs . username && process . env [ 'DOCKER_USERNAME' ] ) {
inputs . username = process . env [ 'DOCKER_USERNAME' ] ;
2020-09-23 15:58:52 +09:00
}
2020-09-25 11:13:16 +09:00
if ( ! inputs . password && process . env [ 'DOCKERHUB_PASSWORD' ] ) {
inputs . password = process . env [ 'DOCKERHUB_PASSWORD' ] ;
2020-09-23 15:58:52 +09:00
}
2020-09-25 11:13:16 +09:00
if ( ! inputs . password && process . env [ 'DOCKER_PASSWORD' ] ) {
inputs . password = process . env [ 'DOCKER_PASSWORD' ] ;
2020-09-23 15:58:52 +09:00
}
2020-09-25 11:13:16 +09:00
if ( ! inputs . repository && process . env [ 'DOCKERHUB_REPOSITORY' ] ) {
inputs . repository = process . env [ 'DOCKERHUB_REPOSITORY' ] ;
2020-09-23 15:58:52 +09:00
}
2020-09-25 11:13:16 +09:00
if ( ! inputs . repository && process . env [ 'DOCKER_REPOSITORY' ] ) {
inputs . repository = process . env [ 'DOCKER_REPOSITORY' ] ;
2020-09-23 15:58:52 +09:00
}
2020-09-25 15:22:36 +09:00
if ( ! inputs . shortDescription && process . env [ 'SHORT_DESCRIPTION' ] ) {
inputs . shortDescription = process . env [ 'SHORT_DESCRIPTION' ] ;
}
2020-09-23 15:58:52 +09:00
if ( ! inputs . readmeFilepath && process . env [ 'README_FILEPATH' ] ) {
inputs . readmeFilepath = process . env [ 'README_FILEPATH' ] ;
}
2023-03-05 11:13:27 +09:00
if ( ! inputs . enableUrlCompletion && process . env [ 'ENABLE_URL_COMPLETION' ] ) {
inputs . enableUrlCompletion = Boolean ( process . env [ 'ENABLE_URL_COMPLETION' ] ) ;
}
if ( ! inputs . imageExtensions && process . env [ 'IMAGE_EXTENSIONS' ] ) {
inputs . imageExtensions = process . env [ 'IMAGE_EXTENSIONS' ] ;
}
2020-09-23 15:58:52 +09:00
// Set defaults
if ( ! inputs . readmeFilepath ) {
2023-03-05 11:13:27 +09:00
inputs . readmeFilepath = readmeHelper . README _FILEPATH _DEFAULT ;
}
if ( ! inputs . enableUrlCompletion ) {
inputs . enableUrlCompletion = readmeHelper . ENABLE _URL _COMPLETION _DEFAULT ;
}
if ( ! inputs . imageExtensions ) {
inputs . imageExtensions = readmeHelper . IMAGE _EXTENSIONS _DEFAULT ;
2020-09-23 15:58:52 +09:00
}
2020-09-25 14:41:18 +09:00
if ( ! inputs . repository && process . env [ 'GITHUB_REPOSITORY' ] ) {
inputs . repository = process . env [ 'GITHUB_REPOSITORY' ] ;
}
2023-03-05 11:13:27 +09:00
// Enforce lower case, where needed
2021-02-03 19:54:07 -05:00
inputs . repository = inputs . repository . toLowerCase ( ) ;
2023-03-05 11:13:27 +09:00
inputs . imageExtensions = inputs . imageExtensions . toLowerCase ( ) ;
2020-09-23 15:58:52 +09:00
return inputs ;
}
exports . getInputs = getInputs ;
function checkRequiredInput ( input , name ) {
if ( ! input ) {
throw new Error ( ` Required input ' ${ name } ' is missing. ` ) ;
}
}
function validateInputs ( inputs ) {
2020-09-25 11:13:16 +09:00
checkRequiredInput ( inputs . username , 'username' ) ;
checkRequiredInput ( inputs . password , 'password' ) ;
2020-09-23 15:58:52 +09:00
}
exports . validateInputs = validateInputs ;
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 5915 :
2021-02-25 02:15:04 +00:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2020-09-23 15:58:52 +09:00
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2022-12-09 07:26:20 +00:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2020-09-23 15:58:52 +09:00
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
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 } ) ) ;
2024-09-29 18:20:46 +01:00
const core = _ _importStar ( _ _nccwpck _require _ _ ( 7484 ) ) ;
const inputHelper = _ _importStar ( _ _nccwpck _require _ _ ( 5285 ) ) ;
const dockerhubHelper = _ _importStar ( _ _nccwpck _require _ _ ( 9200 ) ) ;
const readmeHelper = _ _importStar ( _ _nccwpck _require _ _ ( 4481 ) ) ;
const utils = _ _importStar ( _ _nccwpck _require _ _ ( 9277 ) ) ;
const util _1 = _ _nccwpck _require _ _ ( 9023 ) ;
2023-04-07 09:16:46 +09:00
const SHORT _DESCRIPTION _MAX _BYTES = 100 ;
2020-09-23 15:58:52 +09:00
function run ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
try {
const inputs = inputHelper . getInputs ( ) ;
2021-09-02 13:50:05 +09:00
core . debug ( ` Inputs: ${ ( 0 , util _1 . inspect ) ( inputs ) } ` ) ;
2020-09-23 15:58:52 +09:00
inputHelper . validateInputs ( inputs ) ;
// Fetch the readme content
2023-03-05 11:13:27 +09:00
core . info ( 'Reading description source file' ) ;
const readmeContent = yield readmeHelper . getReadmeContent ( inputs . readmeFilepath , inputs . enableUrlCompletion , inputs . imageExtensions ) ;
core . debug ( readmeContent ) ;
2023-04-07 09:16:46 +09:00
// Truncate the short description if it is too long
const truncatedShortDescription = utils . truncateToBytes ( inputs . shortDescription , SHORT _DESCRIPTION _MAX _BYTES ) ;
if ( truncatedShortDescription . length !== inputs . shortDescription . length ) {
core . warning ( ` The short description exceeds DockerHub's limit and has been truncated to ${ SHORT _DESCRIPTION _MAX _BYTES } bytes. ` ) ;
}
2023-04-10 08:18:10 +09:00
core . debug ( ` Truncated short description: ${ truncatedShortDescription } ` ) ;
2020-09-23 15:58:52 +09:00
// Acquire a token for the Docker Hub API
core . info ( 'Acquiring token' ) ;
2020-09-25 11:13:16 +09:00
const token = yield dockerhubHelper . getToken ( inputs . username , inputs . password ) ;
2020-09-23 15:58:52 +09:00
// Send a PATCH request to update the description of the repository
core . info ( 'Sending PATCH request' ) ;
2023-04-10 08:18:10 +09:00
yield dockerhubHelper . updateRepositoryDescription ( token , inputs . repository , truncatedShortDescription , readmeContent ) ;
2020-09-23 15:58:52 +09:00
core . info ( 'Request successful' ) ;
}
catch ( error ) {
2021-09-02 13:50:05 +09:00
core . debug ( ( 0 , util _1 . inspect ) ( error ) ) ;
2023-04-07 09:16:46 +09:00
core . setFailed ( utils . getErrorMessage ( error ) ) ;
2020-09-23 15:58:52 +09:00
}
} ) ;
}
run ( ) ;
2023-03-05 11:13:27 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 4481 :
2023-03-05 11:13:27 +09:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
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 } ) ) ;
2023-04-07 09:16:46 +09:00
exports . completeRelativeUrls = exports . getReadmeContent = exports . ENABLE _URL _COMPLETION _DEFAULT = exports . IMAGE _EXTENSIONS _DEFAULT = exports . README _FILEPATH _DEFAULT = void 0 ;
2024-09-29 18:20:46 +01:00
const core = _ _importStar ( _ _nccwpck _require _ _ ( 7484 ) ) ;
const fs = _ _importStar ( _ _nccwpck _require _ _ ( 9896 ) ) ;
const utils = _ _importStar ( _ _nccwpck _require _ _ ( 9277 ) ) ;
2023-03-05 11:13:27 +09:00
exports . README _FILEPATH _DEFAULT = './README.md' ;
exports . IMAGE _EXTENSIONS _DEFAULT = 'bmp,gif,jpg,jpeg,png,svg,webp' ;
exports . ENABLE _URL _COMPLETION _DEFAULT = false ;
const TITLE _REGEX = ` (?: +"[^"]+")? ` ;
const REPOSITORY _URL = ` ${ process . env [ 'GITHUB_SERVER_URL' ] } / ${ process . env [ 'GITHUB_REPOSITORY' ] } ` ;
const BLOB _PREFIX = ` ${ REPOSITORY _URL } /blob/ ${ process . env [ 'GITHUB_REF_NAME' ] } / ` ;
const RAW _PREFIX = ` ${ REPOSITORY _URL } /raw/ ${ process . env [ 'GITHUB_REF_NAME' ] } / ` ;
2023-03-06 12:50:56 +09:00
const MAX _BYTES = 25000 ;
2023-03-05 11:13:27 +09:00
function getReadmeContent ( readmeFilepath , enableUrlCompletion , imageExtensions ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
// Fetch the readme content
let readmeContent = yield fs . promises . readFile ( readmeFilepath , {
encoding : 'utf8'
} ) ;
readmeContent = completeRelativeUrls ( readmeContent , readmeFilepath , enableUrlCompletion , imageExtensions ) ;
2023-04-07 09:16:46 +09:00
const truncatedReadmeContent = utils . truncateToBytes ( readmeContent , MAX _BYTES ) ;
2023-03-06 12:50:56 +09:00
if ( truncatedReadmeContent . length !== readmeContent . length ) {
core . warning ( ` The README content exceeds DockerHub's limit and has been truncated to ${ MAX _BYTES } bytes. ` ) ;
}
return truncatedReadmeContent ;
2023-03-05 11:13:27 +09:00
} ) ;
}
exports . getReadmeContent = getReadmeContent ;
function completeRelativeUrls ( readmeContent , readmeFilepath , enableUrlCompletion , imageExtensions ) {
if ( enableUrlCompletion ) {
readmeFilepath = readmeFilepath . replace ( /^[.][/]/ , '' ) ;
// Make relative urls absolute
const rules = [
... getRelativeReadmeAnchorsRules ( readmeFilepath ) ,
... getRelativeImageUrlRules ( imageExtensions ) ,
... getRelativeUrlRules ( )
] ;
readmeContent = applyRules ( rules , readmeContent ) ;
}
return readmeContent ;
}
exports . completeRelativeUrls = completeRelativeUrls ;
function applyRules ( rules , readmeContent ) {
rules . forEach ( rule => {
const combinedRegex = ` ${ rule . left . source } [(] ${ rule . url . source } [)] ` ;
core . debug ( ` rule: ${ combinedRegex } ` ) ;
const replacement = ` $ <left>( ${ rule . absUrlPrefix } $ <url>) ` ;
core . debug ( ` replacement: ${ replacement } ` ) ;
readmeContent = readmeContent . replace ( new RegExp ( combinedRegex , 'giu' ) , replacement ) ;
} ) ;
return readmeContent ;
}
// has to be applied first to avoid wrong results
function getRelativeReadmeAnchorsRules ( readmeFilepath ) {
const prefix = ` ${ BLOB _PREFIX } ${ readmeFilepath } ` ;
// matches e.g.:
// #table-of-content
// #table-of-content "the anchor (a title)"
const url = new RegExp ( ` (?<url>#[^)]+ ${ TITLE _REGEX } ) ` ) ;
const rules = [
// matches e.g.:
// [#table-of-content](#table-of-content)
// [#table-of-content](#table-of-content "the anchor (a title)")
{
left : /(?<left>\[[^\]]+\])/ ,
url : url ,
absUrlPrefix : prefix
} ,
// matches e.g.:
// [![media/image.svg](media/image.svg)](#table-of-content)
// [![media/image.svg](media/image.svg "title a")](#table-of-content "title b")
{
left : /(?<left>\[!\[[^\]]*\]\([^)]+\)\])/ ,
url : url ,
absUrlPrefix : prefix
}
] ;
return rules ;
}
function getRelativeImageUrlRules ( imageExtensions ) {
const extensionsRegex = imageExtensions . replace ( /,/g , '|' ) ;
// matches e.g.:
// media/image.svg
// media/image.svg "with title"
const url = new RegExp ( ` (?<url>[^:)]+[.](?: ${ extensionsRegex } ) ${ TITLE _REGEX } ) ` ) ;
const rules = [
// matches e.g.:
// ![media/image.svg](media/image.svg)
// ![media/image.svg](media/image.svg "with title")
{
left : /(?<left>!\[[^\]]*\])/ ,
url : url ,
absUrlPrefix : RAW _PREFIX
}
] ;
return rules ;
}
function getRelativeUrlRules ( ) {
// matches e.g.:
// .releaserc.yaml
// README.md#table-of-content "title b"
// .releaserc.yaml "the .releaserc.yaml file (a title)"
const url = new RegExp ( ` (?<url>[^:)]+ ${ TITLE _REGEX } ) ` ) ;
const rules = [
// matches e.g.:
// [.releaserc.yaml](.releaserc.yaml)
// [.releaserc.yaml](.releaserc.yaml "the .releaserc.yaml file (a title)")
{
left : /(?<left>\[[^\]]+\])/ ,
url : url ,
absUrlPrefix : BLOB _PREFIX
} ,
// matches e.g.:
// [![media/image.svg](media/image.svg)](media/image.svg)
// [![media/image.svg](media/image.svg)](README.md#table-of-content "title b")
// [![media/image.svg](media/image.svg "title a")](media/image.svg)
// [![media/image.svg](media/image.svg "title a")](media/image.svg "title b")
// [![media/image.svg](media/image.svg "title a")](README.md#table-of-content "title b")
{
left : new RegExp ( ` (?<left> \\ [! \\ [[^ \\ ]]* \\ ] \\ ([^)]+ ${ TITLE _REGEX } \\ ) \\ ]) ` ) ,
url : url ,
absUrlPrefix : BLOB _PREFIX
}
] ;
return rules ;
}
2023-04-07 09:16:46 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 9277 :
2023-04-07 09:16:46 +09:00
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . truncateToBytes = exports . getErrorMessage = void 0 ;
2024-09-29 18:20:46 +01:00
const unicodeSubstring = _ _nccwpck _require _ _ ( 3534 ) ;
2023-04-07 09:16:46 +09:00
function getErrorMessage ( error ) {
if ( error instanceof Error )
return error . message ;
return String ( error ) ;
}
exports . getErrorMessage = getErrorMessage ;
function truncateToBytes ( s , n ) {
let len = n ;
while ( Buffer . byteLength ( s ) > n ) {
s = unicodeSubstring ( s , 0 , len -- ) ;
}
return s ;
}
exports . truncateToBytes = truncateToBytes ;
2020-09-23 15:58:52 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 4914 :
2021-02-25 02:15:04 +00:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2020-09-23 15:58:52 +09:00
"use strict" ;
2021-06-15 04:47:25 +00:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2024-10-08 20:21:42 +01:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2021-06-15 04:47:25 +00:00
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
2020-09-23 15:58:52 +09:00
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
2024-10-08 20:21:42 +01:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
2021-06-15 04:47:25 +00:00
_ _setModuleDefault ( result , mod ) ;
2020-09-23 15:58:52 +09:00
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-06-15 04:47:25 +00:00
exports . issue = exports . issueCommand = void 0 ;
2024-09-29 18:20:46 +01:00
const os = _ _importStar ( _ _nccwpck _require _ _ ( 857 ) ) ;
const utils _1 = _ _nccwpck _require _ _ ( 302 ) ;
2020-09-23 15:58:52 +09:00
/ * *
* Commands
*
* Command Format :
* : : name key = value , key = value : : message
*
* Examples :
* : : warning : : This is the message
* : : set - env name = MY _VAR : : some value
* /
function issueCommand ( command , properties , message ) {
const cmd = new Command ( command , properties , message ) ;
process . stdout . write ( cmd . toString ( ) + os . EOL ) ;
}
exports . issueCommand = issueCommand ;
function issue ( name , message = '' ) {
issueCommand ( name , { } , message ) ;
}
exports . issue = issue ;
const CMD _STRING = '::' ;
class Command {
constructor ( command , properties , message ) {
if ( ! command ) {
command = 'missing.command' ;
}
this . command = command ;
this . properties = properties ;
this . message = message ;
}
toString ( ) {
let cmdStr = CMD _STRING + this . command ;
if ( this . properties && Object . keys ( this . properties ) . length > 0 ) {
cmdStr += ' ' ;
let first = true ;
for ( const key in this . properties ) {
if ( this . properties . hasOwnProperty ( key ) ) {
const val = this . properties [ key ] ;
if ( val ) {
if ( first ) {
first = false ;
}
else {
cmdStr += ',' ;
}
cmdStr += ` ${ key } = ${ escapeProperty ( val ) } ` ;
}
}
}
}
cmdStr += ` ${ CMD _STRING } ${ escapeData ( this . message ) } ` ;
return cmdStr ;
}
}
function escapeData ( s ) {
2024-10-08 20:21:42 +01:00
return ( 0 , utils _1 . toCommandValue ) ( s )
2020-09-23 15:58:52 +09:00
. replace ( /%/g , '%25' )
. replace ( /\r/g , '%0D' )
. replace ( /\n/g , '%0A' ) ;
}
function escapeProperty ( s ) {
2024-10-08 20:21:42 +01:00
return ( 0 , utils _1 . toCommandValue ) ( s )
2020-09-23 15:58:52 +09:00
. replace ( /%/g , '%25' )
. replace ( /\r/g , '%0D' )
. replace ( /\n/g , '%0A' )
. replace ( /:/g , '%3A' )
. replace ( /,/g , '%2C' ) ;
}
//# sourceMappingURL=command.js.map
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 7484 :
2021-02-25 02:15:04 +00:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2020-09-23 15:58:52 +09:00
"use strict" ;
2021-06-15 04:47:25 +00:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2024-10-08 20:21:42 +01:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2021-06-15 04:47:25 +00:00
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
2024-10-08 20:21:42 +01:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
2021-06-15 04:47:25 +00:00
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
2020-09-23 15:58:52 +09: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 } ) ) ;
2024-10-08 20:21:42 +01:00
exports . platform = exports . toPlatformPath = exports . toWin32Path = exports . toPosixPath = exports . markdownSummary = exports . summary = 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 ;
2024-09-29 18:20:46 +01:00
const command _1 = _ _nccwpck _require _ _ ( 4914 ) ;
const file _command _1 = _ _nccwpck _require _ _ ( 4753 ) ;
const utils _1 = _ _nccwpck _require _ _ ( 302 ) ;
const os = _ _importStar ( _ _nccwpck _require _ _ ( 857 ) ) ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 6928 ) ) ;
const oidc _utils _1 = _ _nccwpck _require _ _ ( 5306 ) ;
2020-09-23 15:58:52 +09:00
/ * *
* 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" ;
2024-10-08 20:21:42 +01:00
} ) ( ExitCode || ( exports . ExitCode = ExitCode = { } ) ) ;
2020-09-23 15:58:52 +09:00
//-----------------------------------------------------------------------
// 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 ) {
2024-10-08 20:21:42 +01:00
const convertedVal = ( 0 , utils _1 . toCommandValue ) ( val ) ;
2020-09-23 15:58:52 +09:00
process . env [ name ] = convertedVal ;
2020-10-02 06:49:03 +00:00
const filePath = process . env [ 'GITHUB_ENV' ] || '' ;
if ( filePath ) {
2024-10-08 20:21:42 +01:00
return ( 0 , file _command _1 . issueFileCommand ) ( 'ENV' , ( 0 , file _command _1 . prepareKeyValueMessage ) ( name , val ) ) ;
2020-10-02 06:49:03 +00:00
}
2024-10-08 20:21:42 +01:00
( 0 , command _1 . issueCommand ) ( 'set-env' , { name } , convertedVal ) ;
2020-09-23 15:58:52 +09:00
}
exports . exportVariable = exportVariable ;
/ * *
* Registers a secret which will get masked from logs
* @ param secret value of the secret
* /
function setSecret ( secret ) {
2024-10-08 20:21:42 +01:00
( 0 , command _1 . issueCommand ) ( 'add-mask' , { } , secret ) ;
2020-09-23 15:58:52 +09:00
}
exports . setSecret = setSecret ;
/ * *
* Prepends inputPath to the PATH ( for this action and future actions )
* @ param inputPath
* /
function addPath ( inputPath ) {
2020-10-02 06:49:03 +00:00
const filePath = process . env [ 'GITHUB_PATH' ] || '' ;
if ( filePath ) {
2024-10-08 20:21:42 +01:00
( 0 , file _command _1 . issueFileCommand ) ( 'PATH' , inputPath ) ;
2020-10-02 06:49:03 +00:00
}
else {
2024-10-08 20:21:42 +01:00
( 0 , command _1 . issueCommand ) ( 'add-path' , { } , inputPath ) ;
2020-10-02 06:49:03 +00:00
}
2020-09-23 15:58:52 +09:00
process . env [ 'PATH' ] = ` ${ inputPath } ${ path . delimiter } ${ process . env [ 'PATH' ] } ` ;
}
exports . addPath = addPath ;
/ * *
2021-06-15 04:47:25 +00:00
* Gets the value of an input .
* Unless trimWhitespace is set to false in InputOptions , the value is also trimmed .
* Returns an empty string if the value is not defined .
2020-09-23 15:58:52 +09:00
*
* @ 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 } ` ) ;
}
2021-06-15 04:47:25 +00:00
if ( options && options . trimWhitespace === false ) {
return val ;
}
2020-09-23 15:58:52 +09:00
return val . trim ( ) ;
}
exports . getInput = getInput ;
2021-07-22 01:59:05 +00:00
/ * *
* Gets the values of an multiline input . Each value is also trimmed .
*
* @ param name name of the input to get
* @ param options optional . See InputOptions .
* @ returns string [ ]
*
* /
function getMultilineInput ( name , options ) {
const inputs = getInput ( name , options )
. split ( '\n' )
. filter ( x => x !== '' ) ;
2022-10-18 06:21:05 +00:00
if ( options && options . trimWhitespace === false ) {
return inputs ;
}
return inputs . map ( input => input . trim ( ) ) ;
2021-07-22 01:59:05 +00:00
}
exports . getMultilineInput = getMultilineInput ;
2021-06-15 04:47:25 +00:00
/ * *
* Gets the input value of the boolean type in the YAML 1.2 "core schema" specification .
* Support boolean input list : ` true | True | TRUE | false | False | FALSE ` .
* The return value is also in boolean type .
* ref : https : //yaml.org/spec/1.2/spec.html#id2804923
*
* @ param name name of the input to get
* @ param options optional . See InputOptions .
* @ returns boolean
* /
function getBooleanInput ( name , options ) {
const trueValue = [ 'true' , 'True' , 'TRUE' ] ;
const falseValue = [ 'false' , 'False' , 'FALSE' ] ;
const val = getInput ( name , options ) ;
if ( trueValue . includes ( val ) )
return true ;
if ( falseValue . includes ( val ) )
return false ;
throw new TypeError ( ` Input does not meet YAML 1.2 "Core Schema" specification: ${ name } \n ` +
` Support boolean input list: \` true | True | TRUE | false | False | FALSE \` ` ) ;
}
exports . getBooleanInput = getBooleanInput ;
2020-09-23 15:58:52 +09:00
/ * *
* Sets the value of an output .
*
* @ param name name of the output to set
* @ param value value to store . Non - string values will be converted to a string via JSON . stringify
* /
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function setOutput ( name , value ) {
2022-10-18 06:21:05 +00:00
const filePath = process . env [ 'GITHUB_OUTPUT' ] || '' ;
if ( filePath ) {
2024-10-08 20:21:42 +01:00
return ( 0 , file _command _1 . issueFileCommand ) ( 'OUTPUT' , ( 0 , file _command _1 . prepareKeyValueMessage ) ( name , value ) ) ;
2022-10-18 06:21:05 +00:00
}
2021-06-15 04:47:25 +00:00
process . stdout . write ( os . EOL ) ;
2024-10-08 20:21:42 +01:00
( 0 , command _1 . issueCommand ) ( 'set-output' , { name } , ( 0 , utils _1 . toCommandValue ) ( value ) ) ;
2020-09-23 15:58:52 +09:00
}
exports . setOutput = setOutput ;
/ * *
* Enables or disables the echoing of commands into stdout for the rest of the step .
* Echoing is disabled by default if ACTIONS _STEP _DEBUG is not set .
*
* /
function setCommandEcho ( enabled ) {
2024-10-08 20:21:42 +01:00
( 0 , command _1 . issue ) ( 'echo' , enabled ? 'on' : 'off' ) ;
2020-09-23 15:58:52 +09:00
}
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 ) {
2024-10-08 20:21:42 +01:00
( 0 , command _1 . issueCommand ) ( 'debug' , { } , message ) ;
2020-09-23 15:58:52 +09:00
}
exports . debug = debug ;
/ * *
* Adds an error issue
* @ param message error issue message . Errors will be converted to string via toString ( )
2021-09-02 13:50:05 +09:00
* @ param properties optional properties to add to the annotation .
2020-09-23 15:58:52 +09:00
* /
2021-09-02 13:50:05 +09:00
function error ( message , properties = { } ) {
2024-10-08 20:21:42 +01:00
( 0 , command _1 . issueCommand ) ( 'error' , ( 0 , utils _1 . toCommandProperties ) ( properties ) , message instanceof Error ? message . toString ( ) : message ) ;
2020-09-23 15:58:52 +09:00
}
exports . error = error ;
/ * *
2021-09-02 13:50:05 +09:00
* Adds a warning issue
2020-09-23 15:58:52 +09:00
* @ param message warning issue message . Errors will be converted to string via toString ( )
2021-09-02 13:50:05 +09:00
* @ param properties optional properties to add to the annotation .
2020-09-23 15:58:52 +09:00
* /
2021-09-02 13:50:05 +09:00
function warning ( message , properties = { } ) {
2024-10-08 20:21:42 +01:00
( 0 , command _1 . issueCommand ) ( 'warning' , ( 0 , utils _1 . toCommandProperties ) ( properties ) , message instanceof Error ? message . toString ( ) : message ) ;
2020-09-23 15:58:52 +09:00
}
exports . warning = warning ;
2021-09-02 13:50:05 +09:00
/ * *
* Adds a notice issue
* @ param message notice issue message . Errors will be converted to string via toString ( )
* @ param properties optional properties to add to the annotation .
* /
function notice ( message , properties = { } ) {
2024-10-08 20:21:42 +01:00
( 0 , command _1 . issueCommand ) ( 'notice' , ( 0 , utils _1 . toCommandProperties ) ( properties ) , message instanceof Error ? message . toString ( ) : message ) ;
2021-09-02 13:50:05 +09:00
}
exports . notice = notice ;
2020-09-23 15:58:52 +09:00
/ * *
* Writes info to log with console . log .
* @ param message info message
* /
function info ( message ) {
process . stdout . write ( message + os . EOL ) ;
}
exports . info = info ;
/ * *
* Begin an output group .
*
* Output until the next ` groupEnd ` will be foldable in this group
*
* @ param name The name of the output group
* /
function startGroup ( name ) {
2024-10-08 20:21:42 +01:00
( 0 , command _1 . issue ) ( 'group' , name ) ;
2020-09-23 15:58:52 +09:00
}
exports . startGroup = startGroup ;
/ * *
* End an output group .
* /
function endGroup ( ) {
2024-10-08 20:21:42 +01:00
( 0 , command _1 . issue ) ( 'endgroup' ) ;
2020-09-23 15:58:52 +09:00
}
exports . endGroup = endGroup ;
/ * *
* Wrap an asynchronous function call in a group .
*
* Returns the same type as the function itself .
*
* @ param name The name of the group
* @ param fn The function to wrap in the group
* /
function group ( name , fn ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
startGroup ( name ) ;
let result ;
try {
result = yield fn ( ) ;
}
finally {
endGroup ( ) ;
}
return result ;
} ) ;
}
exports . group = group ;
//-----------------------------------------------------------------------
// Wrapper action state
//-----------------------------------------------------------------------
/ * *
* Saves state for current action , the state can only be retrieved by this action ' s post job execution .
*
* @ param name name of the state to store
* @ param value value to store . Non - string values will be converted to a string via JSON . stringify
* /
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function saveState ( name , value ) {
2022-10-18 06:21:05 +00:00
const filePath = process . env [ 'GITHUB_STATE' ] || '' ;
if ( filePath ) {
2024-10-08 20:21:42 +01:00
return ( 0 , file _command _1 . issueFileCommand ) ( 'STATE' , ( 0 , file _command _1 . prepareKeyValueMessage ) ( name , value ) ) ;
2022-10-18 06:21:05 +00:00
}
2024-10-08 20:21:42 +01:00
( 0 , command _1 . issueCommand ) ( 'save-state' , { name } , ( 0 , utils _1 . toCommandValue ) ( value ) ) ;
2020-09-23 15:58:52 +09: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 ;
2021-10-07 01:39:26 +00:00
function getIDToken ( aud ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return yield oidc _utils _1 . OidcClient . getIDToken ( aud ) ;
} ) ;
}
exports . getIDToken = getIDToken ;
2022-08-19 02:59:02 +00:00
/ * *
* Summary exports
* /
2024-09-29 18:20:46 +01:00
var summary _1 = _ _nccwpck _require _ _ ( 1847 ) ;
2022-08-19 02:59:02 +00:00
Object . defineProperty ( exports , "summary" , ( { enumerable : true , get : function ( ) { return summary _1 . summary ; } } ) ) ;
/ * *
* @ deprecated use core . summary
* /
2024-09-29 18:20:46 +01:00
var summary _2 = _ _nccwpck _require _ _ ( 1847 ) ;
2022-08-19 02:59:02 +00:00
Object . defineProperty ( exports , "markdownSummary" , ( { enumerable : true , get : function ( ) { return summary _2 . markdownSummary ; } } ) ) ;
/ * *
* Path exports
* /
2024-09-29 18:20:46 +01:00
var path _utils _1 = _ _nccwpck _require _ _ ( 1976 ) ;
2022-08-19 02:59:02 +00:00
Object . defineProperty ( exports , "toPosixPath" , ( { enumerable : true , get : function ( ) { return path _utils _1 . toPosixPath ; } } ) ) ;
Object . defineProperty ( exports , "toWin32Path" , ( { enumerable : true , get : function ( ) { return path _utils _1 . toWin32Path ; } } ) ) ;
Object . defineProperty ( exports , "toPlatformPath" , ( { enumerable : true , get : function ( ) { return path _utils _1 . toPlatformPath ; } } ) ) ;
2024-10-08 20:21:42 +01:00
/ * *
* Platform utilities exports
* /
exports . platform = _ _importStar ( _ _nccwpck _require _ _ ( 8968 ) ) ;
2020-09-23 15:58:52 +09:00
//# sourceMappingURL=core.js.map
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 4753 :
2021-02-25 02:15:04 +00:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2020-10-02 06:49:03 +00:00
"use strict" ;
// For internal use, subject to change.
2021-06-15 04:47:25 +00:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2024-10-08 20:21:42 +01:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2021-06-15 04:47:25 +00:00
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
2020-10-02 06:49:03 +00:00
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
2024-10-08 20:21:42 +01:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
2021-06-15 04:47:25 +00:00
_ _setModuleDefault ( result , mod ) ;
2020-10-02 06:49:03 +00:00
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-10-18 06:21:05 +00:00
exports . prepareKeyValueMessage = exports . issueFileCommand = void 0 ;
2020-10-02 06:49:03 +00:00
// We use any as a valid input type
/* eslint-disable @typescript-eslint/no-explicit-any */
2024-10-08 20:21:42 +01:00
const crypto = _ _importStar ( _ _nccwpck _require _ _ ( 6982 ) ) ;
2024-09-29 18:20:46 +01:00
const fs = _ _importStar ( _ _nccwpck _require _ _ ( 9896 ) ) ;
const os = _ _importStar ( _ _nccwpck _require _ _ ( 857 ) ) ;
const utils _1 = _ _nccwpck _require _ _ ( 302 ) ;
2022-10-18 06:21:05 +00:00
function issueFileCommand ( command , message ) {
2020-10-02 06:49:03 +00:00
const filePath = process . env [ ` GITHUB_ ${ command } ` ] ;
if ( ! filePath ) {
throw new Error ( ` Unable to find environment variable for file command ${ command } ` ) ;
}
if ( ! fs . existsSync ( filePath ) ) {
throw new Error ( ` Missing file at path: ${ filePath } ` ) ;
}
2024-10-08 20:21:42 +01:00
fs . appendFileSync ( filePath , ` ${ ( 0 , utils _1 . toCommandValue ) ( message ) } ${ os . EOL } ` , {
2020-10-02 06:49:03 +00:00
encoding : 'utf8'
} ) ;
}
2022-10-18 06:21:05 +00:00
exports . issueFileCommand = issueFileCommand ;
function prepareKeyValueMessage ( key , value ) {
2024-10-08 20:21:42 +01:00
const delimiter = ` ghadelimiter_ ${ crypto . randomUUID ( ) } ` ;
const convertedValue = ( 0 , utils _1 . toCommandValue ) ( value ) ;
2022-10-18 06:21:05 +00:00
// These should realistically never happen, but just in case someone finds a
// way to exploit uuid generation let's not allow keys or values that contain
// the delimiter.
if ( key . includes ( delimiter ) ) {
throw new Error ( ` Unexpected input: name should not contain the delimiter " ${ delimiter } " ` ) ;
}
if ( convertedValue . includes ( delimiter ) ) {
throw new Error ( ` Unexpected input: value should not contain the delimiter " ${ delimiter } " ` ) ;
}
return ` ${ key } << ${ delimiter } ${ os . EOL } ${ convertedValue } ${ os . EOL } ${ delimiter } ` ;
}
exports . prepareKeyValueMessage = prepareKeyValueMessage ;
2020-10-02 06:49:03 +00:00
//# sourceMappingURL=file-command.js.map
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 5306 :
2021-10-07 01:39:26 +00:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . OidcClient = void 0 ;
2024-09-29 18:20:46 +01:00
const http _client _1 = _ _nccwpck _require _ _ ( 4844 ) ;
const auth _1 = _ _nccwpck _require _ _ ( 4552 ) ;
const core _1 = _ _nccwpck _require _ _ ( 7484 ) ;
2021-10-07 01:39:26 +00:00
class OidcClient {
static createHttpClient ( allowRetry = true , maxRetry = 10 ) {
const requestOptions = {
allowRetries : allowRetry ,
maxRetries : maxRetry
} ;
return new http _client _1 . HttpClient ( 'actions/oidc-client' , [ new auth _1 . BearerCredentialHandler ( OidcClient . getRequestToken ( ) ) ] , requestOptions ) ;
}
static getRequestToken ( ) {
const token = process . env [ 'ACTIONS_ID_TOKEN_REQUEST_TOKEN' ] ;
if ( ! token ) {
throw new Error ( 'Unable to get ACTIONS_ID_TOKEN_REQUEST_TOKEN env variable' ) ;
}
return token ;
}
static getIDTokenUrl ( ) {
const runtimeUrl = process . env [ 'ACTIONS_ID_TOKEN_REQUEST_URL' ] ;
if ( ! runtimeUrl ) {
throw new Error ( 'Unable to get ACTIONS_ID_TOKEN_REQUEST_URL env variable' ) ;
}
return runtimeUrl ;
}
static getCall ( id _token _url ) {
var _a ;
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const httpclient = OidcClient . createHttpClient ( ) ;
const res = yield httpclient
. getJson ( id _token _url )
. catch ( error => {
throw new Error ( ` Failed to get ID Token. \n
Error Code : $ { error . statusCode } \ n
2023-09-18 17:14:06 +09:00
Error Message : $ { error . message } ` );
2021-10-07 01:39:26 +00:00
} ) ;
const id _token = ( _a = res . result ) === null || _a === void 0 ? void 0 : _a . value ;
if ( ! id _token ) {
throw new Error ( 'Response json body do not have ID Token field' ) ;
}
return id _token ;
} ) ;
}
static getIDToken ( audience ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
try {
// New ID Token is requested from action service
let id _token _url = OidcClient . getIDTokenUrl ( ) ;
if ( audience ) {
const encodedAudience = encodeURIComponent ( audience ) ;
id _token _url = ` ${ id _token _url } &audience= ${ encodedAudience } ` ;
}
2024-10-08 20:21:42 +01:00
( 0 , core _1 . debug ) ( ` ID token url is ${ id _token _url } ` ) ;
2021-10-07 01:39:26 +00:00
const id _token = yield OidcClient . getCall ( id _token _url ) ;
2024-10-08 20:21:42 +01:00
( 0 , core _1 . setSecret ) ( id _token ) ;
2021-10-07 01:39:26 +00:00
return id _token ;
}
catch ( error ) {
throw new Error ( ` Error message: ${ error . message } ` ) ;
}
} ) ;
}
}
exports . OidcClient = OidcClient ;
//# sourceMappingURL=oidc-utils.js.map
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 1976 :
2022-08-19 02:59:02 +00:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
2024-10-08 20:21:42 +01:00
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
2022-08-19 02:59:02 +00:00
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
2024-10-08 20:21:42 +01:00
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
2022-08-19 02:59:02 +00:00
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . toPlatformPath = exports . toWin32Path = exports . toPosixPath = void 0 ;
2024-09-29 18:20:46 +01:00
const path = _ _importStar ( _ _nccwpck _require _ _ ( 6928 ) ) ;
2022-08-19 02:59:02 +00:00
/ * *
* toPosixPath converts the given path to the posix form . On Windows , \ \ will be
* replaced with / .
*
* @ param pth . Path to transform .
* @ return string Posix path .
* /
function toPosixPath ( pth ) {
return pth . replace ( /[\\]/g , '/' ) ;
}
exports . toPosixPath = toPosixPath ;
/ * *
* toWin32Path converts the given path to the win32 form . On Linux , / w i l l b e
* replaced with \ \ .
*
* @ param pth . Path to transform .
* @ return string Win32 path .
* /
function toWin32Path ( pth ) {
return pth . replace ( /[/]/g , '\\' ) ;
}
exports . toWin32Path = toWin32Path ;
/ * *
* toPlatformPath converts the given path to a platform - specific path . It does
* this by replacing instances of / a n d \ w i t h t h e p l a t f o r m - s p e c i f i c p a t h
* separator .
*
* @ param pth The path to platformize .
* @ return string The platform - specific path .
* /
function toPlatformPath ( pth ) {
return pth . replace ( /[/\\]/g , path . sep ) ;
}
exports . toPlatformPath = toPlatformPath ;
//# sourceMappingURL=path-utils.js.map
/***/ } ) ,
2024-10-08 20:21:42 +01:00
/***/ 8968 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
var desc = Object . getOwnPropertyDescriptor ( m , k ) ;
if ( ! desc || ( "get" in desc ? ! m . _ _esModule : desc . writable || desc . configurable ) ) {
desc = { enumerable : true , get : function ( ) { return m [ k ] ; } } ;
}
Object . defineProperty ( o , k2 , desc ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . prototype . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
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 . getDetails = exports . isLinux = exports . isMacOS = exports . isWindows = exports . arch = exports . platform = void 0 ;
const os _1 = _ _importDefault ( _ _nccwpck _require _ _ ( 857 ) ) ;
const exec = _ _importStar ( _ _nccwpck _require _ _ ( 5236 ) ) ;
const getWindowsInfo = ( ) => _ _awaiter ( void 0 , void 0 , void 0 , function * ( ) {
const { stdout : version } = yield exec . getExecOutput ( 'powershell -command "(Get-CimInstance -ClassName Win32_OperatingSystem).Version"' , undefined , {
silent : true
} ) ;
const { stdout : name } = yield exec . getExecOutput ( 'powershell -command "(Get-CimInstance -ClassName Win32_OperatingSystem).Caption"' , undefined , {
silent : true
} ) ;
return {
name : name . trim ( ) ,
version : version . trim ( )
} ;
} ) ;
const getMacOsInfo = ( ) => _ _awaiter ( void 0 , void 0 , void 0 , function * ( ) {
var _a , _b , _c , _d ;
const { stdout } = yield exec . getExecOutput ( 'sw_vers' , undefined , {
silent : true
} ) ;
const version = ( _b = ( _a = stdout . match ( /ProductVersion:\s*(.+)/ ) ) === null || _a === void 0 ? void 0 : _a [ 1 ] ) !== null && _b !== void 0 ? _b : '' ;
const name = ( _d = ( _c = stdout . match ( /ProductName:\s*(.+)/ ) ) === null || _c === void 0 ? void 0 : _c [ 1 ] ) !== null && _d !== void 0 ? _d : '' ;
return {
name ,
version
} ;
} ) ;
const getLinuxInfo = ( ) => _ _awaiter ( void 0 , void 0 , void 0 , function * ( ) {
const { stdout } = yield exec . getExecOutput ( 'lsb_release' , [ '-i' , '-r' , '-s' ] , {
silent : true
} ) ;
const [ name , version ] = stdout . trim ( ) . split ( '\n' ) ;
return {
name ,
version
} ;
} ) ;
exports . platform = os _1 . default . platform ( ) ;
exports . arch = os _1 . default . arch ( ) ;
exports . isWindows = exports . platform === 'win32' ;
exports . isMacOS = exports . platform === 'darwin' ;
exports . isLinux = exports . platform === 'linux' ;
function getDetails ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return Object . assign ( Object . assign ( { } , ( yield ( exports . isWindows
? getWindowsInfo ( )
: exports . isMacOS
? getMacOsInfo ( )
: getLinuxInfo ( ) ) ) ) , { platform : exports . platform ,
arch : exports . arch ,
isWindows : exports . isWindows ,
isMacOS : exports . isMacOS ,
isLinux : exports . isLinux } ) ;
} ) ;
}
exports . getDetails = getDetails ;
//# sourceMappingURL=platform.js.map
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 1847 :
2022-08-19 02:59:02 +00:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . summary = exports . markdownSummary = exports . SUMMARY _DOCS _URL = exports . SUMMARY _ENV _VAR = void 0 ;
2024-09-29 18:20:46 +01:00
const os _1 = _ _nccwpck _require _ _ ( 857 ) ;
const fs _1 = _ _nccwpck _require _ _ ( 9896 ) ;
2022-08-19 02:59:02 +00:00
const { access , appendFile , writeFile } = fs _1 . promises ;
exports . SUMMARY _ENV _VAR = 'GITHUB_STEP_SUMMARY' ;
exports . SUMMARY _DOCS _URL = 'https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#adding-a-job-summary' ;
class Summary {
constructor ( ) {
this . _buffer = '' ;
}
/ * *
* Finds the summary file path from the environment , rejects if env var is not found or file does not exist
* Also checks r / w permissions .
*
* @ returns step summary file path
* /
filePath ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( this . _filePath ) {
return this . _filePath ;
}
const pathFromEnv = process . env [ exports . SUMMARY _ENV _VAR ] ;
if ( ! pathFromEnv ) {
throw new Error ( ` Unable to find environment variable for $ ${ exports . SUMMARY _ENV _VAR } . Check if your runtime environment supports job summaries. ` ) ;
}
try {
yield access ( pathFromEnv , fs _1 . constants . R _OK | fs _1 . constants . W _OK ) ;
}
catch ( _a ) {
throw new Error ( ` Unable to access summary file: ' ${ pathFromEnv } '. Check if the file has correct read/write permissions. ` ) ;
}
this . _filePath = pathFromEnv ;
return this . _filePath ;
} ) ;
}
/ * *
* Wraps content in an HTML tag , adding any HTML attributes
*
* @ param { string } tag HTML tag to wrap
* @ param { string | null } content content within the tag
* @ param { [ attribute : string ] : string } attrs key - value list of HTML attributes to add
*
* @ returns { string } content wrapped in HTML element
* /
wrap ( tag , content , attrs = { } ) {
const htmlAttrs = Object . entries ( attrs )
. map ( ( [ key , value ] ) => ` ${ key } =" ${ value } " ` )
. join ( '' ) ;
if ( ! content ) {
return ` < ${ tag } ${ htmlAttrs } > ` ;
}
return ` < ${ tag } ${ htmlAttrs } > ${ content } </ ${ tag } > ` ;
}
/ * *
* Writes text in the buffer to the summary buffer file and empties buffer . Will append by default .
*
* @ param { SummaryWriteOptions } [ options ] ( optional ) options for write operation
*
* @ returns { Promise < Summary > } summary instance
* /
write ( options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const overwrite = ! ! ( options === null || options === void 0 ? void 0 : options . overwrite ) ;
const filePath = yield this . filePath ( ) ;
const writeFunc = overwrite ? writeFile : appendFile ;
yield writeFunc ( filePath , this . _buffer , { encoding : 'utf8' } ) ;
return this . emptyBuffer ( ) ;
} ) ;
}
/ * *
* Clears the summary buffer and wipes the summary file
*
* @ returns { Summary } summary instance
* /
clear ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . emptyBuffer ( ) . write ( { overwrite : true } ) ;
} ) ;
}
/ * *
* Returns the current summary buffer as a string
*
* @ returns { string } string of summary buffer
* /
stringify ( ) {
return this . _buffer ;
}
/ * *
* If the summary buffer is empty
*
* @ returns { boolen } true if the buffer is empty
* /
isEmptyBuffer ( ) {
return this . _buffer . length === 0 ;
}
/ * *
* Resets the summary buffer without writing to summary file
*
* @ returns { Summary } summary instance
* /
emptyBuffer ( ) {
this . _buffer = '' ;
return this ;
}
/ * *
* Adds raw text to the summary buffer
*
* @ param { string } text content to add
* @ param { boolean } [ addEOL = false ] ( optional ) append an EOL to the raw text ( default : false )
*
* @ returns { Summary } summary instance
* /
addRaw ( text , addEOL = false ) {
this . _buffer += text ;
return addEOL ? this . addEOL ( ) : this ;
}
/ * *
* Adds the operating system - specific end - of - line marker to the buffer
*
* @ returns { Summary } summary instance
* /
addEOL ( ) {
return this . addRaw ( os _1 . EOL ) ;
}
/ * *
* Adds an HTML codeblock to the summary buffer
*
* @ param { string } code content to render within fenced code block
* @ param { string } lang ( optional ) language to syntax highlight code
*
* @ returns { Summary } summary instance
* /
addCodeBlock ( code , lang ) {
const attrs = Object . assign ( { } , ( lang && { lang } ) ) ;
const element = this . wrap ( 'pre' , this . wrap ( 'code' , code ) , attrs ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML list to the summary buffer
*
* @ param { string [ ] } items list of items to render
* @ param { boolean } [ ordered = false ] ( optional ) if the rendered list should be ordered or not ( default : false )
*
* @ returns { Summary } summary instance
* /
addList ( items , ordered = false ) {
const tag = ordered ? 'ol' : 'ul' ;
const listItems = items . map ( item => this . wrap ( 'li' , item ) ) . join ( '' ) ;
const element = this . wrap ( tag , listItems ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML table to the summary buffer
*
* @ param { SummaryTableCell [ ] } rows table rows
*
* @ returns { Summary } summary instance
* /
addTable ( rows ) {
const tableBody = rows
. map ( row => {
const cells = row
. map ( cell => {
if ( typeof cell === 'string' ) {
return this . wrap ( 'td' , cell ) ;
}
const { header , data , colspan , rowspan } = cell ;
const tag = header ? 'th' : 'td' ;
const attrs = Object . assign ( Object . assign ( { } , ( colspan && { colspan } ) ) , ( rowspan && { rowspan } ) ) ;
return this . wrap ( tag , data , attrs ) ;
} )
. join ( '' ) ;
return this . wrap ( 'tr' , cells ) ;
} )
. join ( '' ) ;
const element = this . wrap ( 'table' , tableBody ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds a collapsable HTML details element to the summary buffer
*
* @ param { string } label text for the closed state
* @ param { string } content collapsable content
*
* @ returns { Summary } summary instance
* /
addDetails ( label , content ) {
const element = this . wrap ( 'details' , this . wrap ( 'summary' , label ) + content ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML image tag to the summary buffer
*
* @ param { string } src path to the image you to embed
* @ param { string } alt text description of the image
* @ param { SummaryImageOptions } options ( optional ) addition image attributes
*
* @ returns { Summary } summary instance
* /
addImage ( src , alt , options ) {
const { width , height } = options || { } ;
const attrs = Object . assign ( Object . assign ( { } , ( width && { width } ) ) , ( height && { height } ) ) ;
const element = this . wrap ( 'img' , null , Object . assign ( { src , alt } , attrs ) ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML section heading element
*
* @ param { string } text heading text
* @ param { number | string } [ level = 1 ] ( optional ) the heading level , default : 1
*
* @ returns { Summary } summary instance
* /
addHeading ( text , level ) {
const tag = ` h ${ level } ` ;
const allowedTag = [ 'h1' , 'h2' , 'h3' , 'h4' , 'h5' , 'h6' ] . includes ( tag )
? tag
: 'h1' ;
const element = this . wrap ( allowedTag , text ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML thematic break ( < hr > ) to the summary buffer
*
* @ returns { Summary } summary instance
* /
addSeparator ( ) {
const element = this . wrap ( 'hr' , null ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML line break ( < br > ) to the summary buffer
*
* @ returns { Summary } summary instance
* /
addBreak ( ) {
const element = this . wrap ( 'br' , null ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML blockquote to the summary buffer
*
* @ param { string } text quote text
* @ param { string } cite ( optional ) citation url
*
* @ returns { Summary } summary instance
* /
addQuote ( text , cite ) {
const attrs = Object . assign ( { } , ( cite && { cite } ) ) ;
const element = this . wrap ( 'blockquote' , text , attrs ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
/ * *
* Adds an HTML anchor tag to the summary buffer
*
* @ param { string } text link text / content
* @ param { string } href hyperlink
*
* @ returns { Summary } summary instance
* /
addLink ( text , href ) {
const element = this . wrap ( 'a' , text , { href } ) ;
return this . addRaw ( element ) . addEOL ( ) ;
}
}
const _summary = new Summary ( ) ;
/ * *
* @ deprecated use ` core.summary `
* /
exports . markdownSummary = _summary ;
exports . summary = _summary ;
//# sourceMappingURL=summary.js.map
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 302 :
2020-10-02 06:49:03 +00:00
/***/ ( ( _ _unused _webpack _module , exports ) => {
"use strict" ;
// We use any as a valid input type
/* eslint-disable @typescript-eslint/no-explicit-any */
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-09-02 13:50:05 +09:00
exports . toCommandProperties = exports . toCommandValue = void 0 ;
2020-10-02 06:49:03 +00:00
/ * *
* 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 ;
2021-09-02 13:50:05 +09:00
/ * *
*
* @ param annotationProperties
* @ returns The command properties to send with the actual annotation command
* See IssueCommandProperties : https : //github.com/actions/runner/blob/main/src/Runner.Worker/ActionCommandManager.cs#L646
* /
function toCommandProperties ( annotationProperties ) {
if ( ! Object . keys ( annotationProperties ) . length ) {
return { } ;
}
return {
title : annotationProperties . title ,
2021-10-07 01:39:26 +00:00
file : annotationProperties . file ,
2021-09-02 13:50:05 +09:00
line : annotationProperties . startLine ,
endLine : annotationProperties . endLine ,
col : annotationProperties . startColumn ,
endColumn : annotationProperties . endColumn
} ;
}
exports . toCommandProperties = toCommandProperties ;
2020-10-02 06:49:03 +00:00
//# sourceMappingURL=utils.js.map
2021-10-07 01:39:26 +00:00
/***/ } ) ,
2024-10-08 20:21:42 +01:00
/***/ 5236 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-10-07 01:39:26 +00:00
"use strict" ;
2024-10-08 20:21:42 +01: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 ;
} ;
2022-08-19 02:59:02 +00:00
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
2021-10-07 01:39:26 +00:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2024-10-08 20:21:42 +01:00
exports . getExecOutput = exports . exec = void 0 ;
const string _decoder _1 = _ _nccwpck _require _ _ ( 3193 ) ;
const tr = _ _importStar ( _ _nccwpck _require _ _ ( 6665 ) ) ;
/ * *
* Exec a command .
* Output will be streamed to the live console .
* Returns promise with return code
*
* @ param commandLine command to execute ( can include additional args ) . Must be correctly escaped .
* @ param args optional arguments for tool . Escaping is handled by the lib .
* @ param options optional exec options . See ExecOptions
* @ returns Promise < number > exit code
* /
function exec ( commandLine , args , options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const commandArgs = tr . argStringToArray ( commandLine ) ;
if ( commandArgs . length === 0 ) {
throw new Error ( ` Parameter 'commandLine' cannot be null or empty. ` ) ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
// Path to tool to execute should be first arg
const toolPath = commandArgs [ 0 ] ;
args = commandArgs . slice ( 1 ) . concat ( args || [ ] ) ;
const runner = new tr . ToolRunner ( toolPath , args , options ) ;
return runner . exec ( ) ;
} ) ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
exports . exec = exec ;
/ * *
* Exec a command and get the output .
* Output will be streamed to the live console .
* Returns promise with the exit code and collected stdout and stderr
*
* @ param commandLine command to execute ( can include additional args ) . Must be correctly escaped .
* @ param args optional arguments for tool . Escaping is handled by the lib .
* @ param options optional exec options . See ExecOptions
* @ returns Promise < ExecOutput > exit code , stdout , and stderr
* /
function getExecOutput ( commandLine , args , options ) {
var _a , _b ;
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
let stdout = '' ;
let stderr = '' ;
//Using string decoder covers the case where a mult-byte character is split
const stdoutDecoder = new string _decoder _1 . StringDecoder ( 'utf8' ) ;
const stderrDecoder = new string _decoder _1 . StringDecoder ( 'utf8' ) ;
const originalStdoutListener = ( _a = options === null || options === void 0 ? void 0 : options . listeners ) === null || _a === void 0 ? void 0 : _a . stdout ;
const originalStdErrListener = ( _b = options === null || options === void 0 ? void 0 : options . listeners ) === null || _b === void 0 ? void 0 : _b . stderr ;
const stdErrListener = ( data ) => {
stderr += stderrDecoder . write ( data ) ;
if ( originalStdErrListener ) {
originalStdErrListener ( data ) ;
}
} ;
const stdOutListener = ( data ) => {
stdout += stdoutDecoder . write ( data ) ;
if ( originalStdoutListener ) {
originalStdoutListener ( data ) ;
}
} ;
const listeners = Object . assign ( Object . assign ( { } , options === null || options === void 0 ? void 0 : options . listeners ) , { stdout : stdOutListener , stderr : stdErrListener } ) ;
const exitCode = yield exec ( commandLine , args , Object . assign ( Object . assign ( { } , options ) , { listeners } ) ) ;
//flush any remaining characters
stdout += stdoutDecoder . end ( ) ;
stderr += stderrDecoder . end ( ) ;
return {
exitCode ,
stdout ,
stderr
} ;
} ) ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
exports . getExecOutput = getExecOutput ;
//# sourceMappingURL=exec.js.map
2021-10-07 01:39:26 +00:00
/***/ } ) ,
2024-10-08 20:21:42 +01:00
/***/ 6665 :
2022-08-19 02:59:02 +00:00
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2021-10-07 01:39:26 +00:00
"use strict" ;
2022-08-19 02:59:02 +00:00
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
2021-10-07 01:39:26 +00:00
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2024-10-08 20:21:42 +01:00
exports . argStringToArray = exports . ToolRunner = void 0 ;
const os = _ _importStar ( _ _nccwpck _require _ _ ( 857 ) ) ;
const events = _ _importStar ( _ _nccwpck _require _ _ ( 4434 ) ) ;
const child = _ _importStar ( _ _nccwpck _require _ _ ( 5317 ) ) ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 6928 ) ) ;
const io = _ _importStar ( _ _nccwpck _require _ _ ( 4994 ) ) ;
const ioUtil = _ _importStar ( _ _nccwpck _require _ _ ( 5207 ) ) ;
const timers _1 = _ _nccwpck _require _ _ ( 3557 ) ;
/* eslint-disable @typescript-eslint/unbound-method */
const IS _WINDOWS = process . platform === 'win32' ;
/ *
* Class for running command line tools . Handles quoting and arg parsing in a platform agnostic way .
2021-10-07 01:39:26 +00:00
* /
2024-10-08 20:21:42 +01:00
class ToolRunner extends events . EventEmitter {
constructor ( toolPath , args , options ) {
super ( ) ;
if ( ! toolPath ) {
throw new Error ( "Parameter 'toolPath' cannot be null or empty." ) ;
}
this . toolPath = toolPath ;
this . args = args || [ ] ;
this . options = options || { } ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
_debug ( message ) {
if ( this . options . listeners && this . options . listeners . debug ) {
this . options . listeners . debug ( message ) ;
}
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
_getCommandString ( options , noPrefix ) {
const toolPath = this . _getSpawnFileName ( ) ;
const args = this . _getSpawnArgs ( options ) ;
let cmd = noPrefix ? '' : '[command]' ; // omit prefix when piped to a second tool
if ( IS _WINDOWS ) {
// Windows + cmd file
if ( this . _isCmdFile ( ) ) {
cmd += toolPath ;
for ( const a of args ) {
cmd += ` ${ a } ` ;
}
}
// Windows + verbatim
else if ( options . windowsVerbatimArguments ) {
cmd += ` " ${ toolPath } " ` ;
for ( const a of args ) {
cmd += ` ${ a } ` ;
}
}
// Windows (regular)
else {
cmd += this . _windowsQuoteCmdArg ( toolPath ) ;
for ( const a of args ) {
cmd += ` ${ this . _windowsQuoteCmdArg ( a ) } ` ;
}
}
}
else {
// OSX/Linux - this can likely be improved with some form of quoting.
// creating processes on Unix is fundamentally different than Windows.
// on Unix, execvp() takes an arg array.
cmd += toolPath ;
for ( const a of args ) {
cmd += ` ${ a } ` ;
}
}
return cmd ;
}
_processLineBuffer ( data , strBuffer , onLine ) {
try {
let s = strBuffer + data . toString ( ) ;
let n = s . indexOf ( os . EOL ) ;
while ( n > - 1 ) {
const line = s . substring ( 0 , n ) ;
onLine ( line ) ;
// the rest of the string ...
s = s . substring ( n + os . EOL . length ) ;
n = s . indexOf ( os . EOL ) ;
}
return s ;
}
catch ( err ) {
// streaming lines to console is best effort. Don't fail a build.
this . _debug ( ` error processing line. Failed with error ${ err } ` ) ;
return '' ;
}
}
_getSpawnFileName ( ) {
if ( IS _WINDOWS ) {
if ( this . _isCmdFile ( ) ) {
return process . env [ 'COMSPEC' ] || 'cmd.exe' ;
}
}
return this . toolPath ;
}
_getSpawnArgs ( options ) {
if ( IS _WINDOWS ) {
if ( this . _isCmdFile ( ) ) {
let argline = ` /D /S /C " ${ this . _windowsQuoteCmdArg ( this . toolPath ) } ` ;
for ( const a of this . args ) {
argline += ' ' ;
argline += options . windowsVerbatimArguments
? a
: this . _windowsQuoteCmdArg ( a ) ;
}
argline += '"' ;
return [ argline ] ;
}
}
return this . args ;
}
_endsWith ( str , end ) {
return str . endsWith ( end ) ;
}
_isCmdFile ( ) {
const upperToolPath = this . toolPath . toUpperCase ( ) ;
return ( this . _endsWith ( upperToolPath , '.CMD' ) ||
this . _endsWith ( upperToolPath , '.BAT' ) ) ;
}
_windowsQuoteCmdArg ( arg ) {
// for .exe, apply the normal quoting rules that libuv applies
if ( ! this . _isCmdFile ( ) ) {
return this . _uvQuoteCmdArg ( arg ) ;
}
// otherwise apply quoting rules specific to the cmd.exe command line parser.
// the libuv rules are generic and are not designed specifically for cmd.exe
// command line parser.
//
// for a detailed description of the cmd.exe command line parser, refer to
// http://stackoverflow.com/questions/4094699/how-does-the-windows-command-interpreter-cmd-exe-parse-scripts/7970912#7970912
// need quotes for empty arg
if ( ! arg ) {
return '""' ;
}
// determine whether the arg needs to be quoted
const cmdSpecialChars = [
' ' ,
'\t' ,
'&' ,
'(' ,
')' ,
'[' ,
']' ,
'{' ,
'}' ,
'^' ,
'=' ,
';' ,
'!' ,
"'" ,
'+' ,
',' ,
'`' ,
'~' ,
'|' ,
'<' ,
'>' ,
'"'
] ;
let needsQuotes = false ;
for ( const char of arg ) {
if ( cmdSpecialChars . some ( x => x === char ) ) {
needsQuotes = true ;
break ;
}
}
// short-circuit if quotes not needed
if ( ! needsQuotes ) {
return arg ;
}
// the following quoting rules are very similar to the rules that by libuv applies.
//
// 1) wrap the string in quotes
//
// 2) double-up quotes - i.e. " => ""
//
// this is different from the libuv quoting rules. libuv replaces " with \", which unfortunately
// doesn't work well with a cmd.exe command line.
//
// note, replacing " with "" also works well if the arg is passed to a downstream .NET console app.
// for example, the command line:
// foo.exe "myarg:""my val"""
// is parsed by a .NET console app into an arg array:
// [ "myarg:\"my val\"" ]
// which is the same end result when applying libuv quoting rules. although the actual
// command line from libuv quoting rules would look like:
// foo.exe "myarg:\"my val\""
//
// 3) double-up slashes that precede a quote,
// e.g. hello \world => "hello \world"
// hello\"world => "hello\\""world"
// hello\\"world => "hello\\\\""world"
// hello world\ => "hello world\\"
//
// technically this is not required for a cmd.exe command line, or the batch argument parser.
// the reasons for including this as a .cmd quoting rule are:
//
// a) this is optimized for the scenario where the argument is passed from the .cmd file to an
// external program. many programs (e.g. .NET console apps) rely on the slash-doubling rule.
//
// b) it's what we've been doing previously (by deferring to node default behavior) and we
// haven't heard any complaints about that aspect.
//
// note, a weakness of the quoting rules chosen here, is that % is not escaped. in fact, % cannot be
// escaped when used on the command line directly - even though within a .cmd file % can be escaped
// by using %%.
//
// the saving grace is, on the command line, %var% is left as-is if var is not defined. this contrasts
// the line parsing rules within a .cmd file, where if var is not defined it is replaced with nothing.
//
// one option that was explored was replacing % with ^% - i.e. %var% => ^%var^%. this hack would
// often work, since it is unlikely that var^ would exist, and the ^ character is removed when the
// variable is used. the problem, however, is that ^ is not removed when %* is used to pass the args
// to an external program.
//
// an unexplored potential solution for the % escaping problem, is to create a wrapper .cmd file.
// % can be escaped within a .cmd file.
let reverse = '"' ;
let quoteHit = true ;
for ( let i = arg . length ; i > 0 ; i -- ) {
// walk the string in reverse
reverse += arg [ i - 1 ] ;
if ( quoteHit && arg [ i - 1 ] === '\\' ) {
reverse += '\\' ; // double the slash
}
else if ( arg [ i - 1 ] === '"' ) {
quoteHit = true ;
reverse += '"' ; // double the quote
}
else {
quoteHit = false ;
}
}
reverse += '"' ;
return reverse
. split ( '' )
. reverse ( )
. join ( '' ) ;
}
_uvQuoteCmdArg ( arg ) {
// Tool runner wraps child_process.spawn() and needs to apply the same quoting as
// Node in certain cases where the undocumented spawn option windowsVerbatimArguments
// is used.
//
// Since this function is a port of quote_cmd_arg from Node 4.x (technically, lib UV,
// see https://github.com/nodejs/node/blob/v4.x/deps/uv/src/win/process.c for details),
// pasting copyright notice from Node within this function:
//
// Copyright Joyent, Inc. and other Node contributors. All rights reserved.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to
// deal in the Software without restriction, including without limitation the
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
// sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
// IN THE SOFTWARE.
if ( ! arg ) {
// Need double quotation for empty argument
return '""' ;
}
if ( ! arg . includes ( ' ' ) && ! arg . includes ( '\t' ) && ! arg . includes ( '"' ) ) {
// No quotation needed
return arg ;
}
if ( ! arg . includes ( '"' ) && ! arg . includes ( '\\' ) ) {
// No embedded double quotes or backslashes, so I can just wrap
// quote marks around the whole thing.
return ` " ${ arg } " ` ;
}
// Expected input/output:
// input : hello"world
// output: "hello\"world"
// input : hello""world
// output: "hello\"\"world"
// input : hello\world
// output: hello\world
// input : hello\\world
// output: hello\\world
// input : hello\"world
// output: "hello\\\"world"
// input : hello\\"world
// output: "hello\\\\\"world"
// input : hello world\
// output: "hello world\\" - note the comment in libuv actually reads "hello world\"
// but it appears the comment is wrong, it should be "hello world\\"
let reverse = '"' ;
let quoteHit = true ;
for ( let i = arg . length ; i > 0 ; i -- ) {
// walk the string in reverse
reverse += arg [ i - 1 ] ;
if ( quoteHit && arg [ i - 1 ] === '\\' ) {
reverse += '\\' ;
}
else if ( arg [ i - 1 ] === '"' ) {
quoteHit = true ;
reverse += '\\' ;
}
else {
quoteHit = false ;
}
}
reverse += '"' ;
return reverse
. split ( '' )
. reverse ( )
. join ( '' ) ;
}
_cloneExecOptions ( options ) {
options = options || { } ;
const result = {
cwd : options . cwd || process . cwd ( ) ,
env : options . env || process . env ,
silent : options . silent || false ,
windowsVerbatimArguments : options . windowsVerbatimArguments || false ,
failOnStdErr : options . failOnStdErr || false ,
ignoreReturnCode : options . ignoreReturnCode || false ,
delay : options . delay || 10000
} ;
result . outStream = options . outStream || process . stdout ;
result . errStream = options . errStream || process . stderr ;
return result ;
}
_getSpawnOptions ( options , toolPath ) {
options = options || { } ;
const result = { } ;
result . cwd = options . cwd ;
result . env = options . env ;
result [ 'windowsVerbatimArguments' ] =
options . windowsVerbatimArguments || this . _isCmdFile ( ) ;
if ( options . windowsVerbatimArguments ) {
result . argv0 = ` " ${ toolPath } " ` ;
}
return result ;
}
/ * *
* Exec a tool .
* Output will be streamed to the live console .
* Returns promise with return code
*
* @ param tool path to tool to exec
* @ param options optional exec options . See ExecOptions
* @ returns number
* /
exec ( ) {
2022-08-19 02:59:02 +00:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
2024-10-08 20:21:42 +01:00
// root the tool path if it is unrooted and contains relative pathing
if ( ! ioUtil . isRooted ( this . toolPath ) &&
( this . toolPath . includes ( '/' ) ||
( IS _WINDOWS && this . toolPath . includes ( '\\' ) ) ) ) {
// prefer options.cwd if it is specified, however options.cwd may also need to be rooted
this . toolPath = path . resolve ( process . cwd ( ) , this . options . cwd || process . cwd ( ) , this . toolPath ) ;
}
// if the tool is only a file name, then resolve it from the PATH
// otherwise verify it exists (add extension on Windows if necessary)
this . toolPath = yield io . which ( this . toolPath , true ) ;
return new Promise ( ( resolve , reject ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
this . _debug ( ` exec tool: ${ this . toolPath } ` ) ;
this . _debug ( 'arguments:' ) ;
for ( const arg of this . args ) {
this . _debug ( ` ${ arg } ` ) ;
}
const optionsNonNull = this . _cloneExecOptions ( this . options ) ;
if ( ! optionsNonNull . silent && optionsNonNull . outStream ) {
optionsNonNull . outStream . write ( this . _getCommandString ( optionsNonNull ) + os . EOL ) ;
}
const state = new ExecState ( optionsNonNull , this . toolPath ) ;
state . on ( 'debug' , ( message ) => {
this . _debug ( message ) ;
2022-08-19 02:59:02 +00:00
} ) ;
2024-10-08 20:21:42 +01:00
if ( this . options . cwd && ! ( yield ioUtil . exists ( this . options . cwd ) ) ) {
return reject ( new Error ( ` The cwd: ${ this . options . cwd } does not exist! ` ) ) ;
}
const fileName = this . _getSpawnFileName ( ) ;
const cp = child . spawn ( fileName , this . _getSpawnArgs ( optionsNonNull ) , this . _getSpawnOptions ( this . options , fileName ) ) ;
let stdbuffer = '' ;
if ( cp . stdout ) {
cp . stdout . on ( 'data' , ( data ) => {
if ( this . options . listeners && this . options . listeners . stdout ) {
this . options . listeners . stdout ( data ) ;
}
if ( ! optionsNonNull . silent && optionsNonNull . outStream ) {
optionsNonNull . outStream . write ( data ) ;
}
stdbuffer = this . _processLineBuffer ( data , stdbuffer , ( line ) => {
if ( this . options . listeners && this . options . listeners . stdline ) {
this . options . listeners . stdline ( line ) ;
}
} ) ;
} ) ;
}
let errbuffer = '' ;
if ( cp . stderr ) {
cp . stderr . on ( 'data' , ( data ) => {
state . processStderr = true ;
if ( this . options . listeners && this . options . listeners . stderr ) {
this . options . listeners . stderr ( data ) ;
}
if ( ! optionsNonNull . silent &&
optionsNonNull . errStream &&
optionsNonNull . outStream ) {
const s = optionsNonNull . failOnStdErr
? optionsNonNull . errStream
: optionsNonNull . outStream ;
s . write ( data ) ;
}
errbuffer = this . _processLineBuffer ( data , errbuffer , ( line ) => {
if ( this . options . listeners && this . options . listeners . errline ) {
this . options . listeners . errline ( line ) ;
}
} ) ;
} ) ;
}
cp . on ( 'error' , ( err ) => {
state . processError = err . message ;
state . processExited = true ;
state . processClosed = true ;
state . CheckComplete ( ) ;
} ) ;
cp . on ( 'exit' , ( code ) => {
state . processExitCode = code ;
state . processExited = true ;
this . _debug ( ` Exit code ${ code } received from tool ' ${ this . toolPath } ' ` ) ;
state . CheckComplete ( ) ;
} ) ;
cp . on ( 'close' , ( code ) => {
state . processExitCode = code ;
state . processExited = true ;
state . processClosed = true ;
this . _debug ( ` STDIO streams have closed for tool ' ${ this . toolPath } ' ` ) ;
state . CheckComplete ( ) ;
} ) ;
state . on ( 'done' , ( error , exitCode ) => {
if ( stdbuffer . length > 0 ) {
this . emit ( 'stdline' , stdbuffer ) ;
}
if ( errbuffer . length > 0 ) {
this . emit ( 'errline' , errbuffer ) ;
}
cp . removeAllListeners ( ) ;
if ( error ) {
reject ( error ) ;
}
else {
resolve ( exitCode ) ;
}
2022-08-19 02:59:02 +00:00
} ) ;
2024-10-08 20:21:42 +01:00
if ( this . options . input ) {
if ( ! cp . stdin ) {
throw new Error ( 'child process missing stdin' ) ;
}
cp . stdin . end ( this . options . input ) ;
}
2022-08-19 02:59:02 +00:00
} ) ) ;
2021-10-07 01:39:26 +00:00
} ) ;
}
}
2024-10-08 20:21:42 +01:00
exports . ToolRunner = ToolRunner ;
/ * *
* Convert an arg string to an array of args . Handles escaping
*
* @ param argString string of arguments
* @ returns string [ ] array of arguments
* /
function argStringToArray ( argString ) {
const args = [ ] ;
let inQuotes = false ;
let escaped = false ;
let arg = '' ;
function append ( c ) {
// we only escape double quotes.
if ( escaped && c !== '"' ) {
arg += '\\' ;
}
arg += c ;
escaped = false ;
}
for ( let i = 0 ; i < argString . length ; i ++ ) {
const c = argString . charAt ( i ) ;
if ( c === '"' ) {
if ( ! escaped ) {
inQuotes = ! inQuotes ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
else {
append ( c ) ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
continue ;
}
if ( c === '\\' && escaped ) {
append ( c ) ;
continue ;
}
if ( c === '\\' && inQuotes ) {
escaped = true ;
continue ;
}
if ( c === ' ' && ! inQuotes ) {
if ( arg . length > 0 ) {
args . push ( arg ) ;
arg = '' ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
continue ;
}
append ( c ) ;
}
if ( arg . length > 0 ) {
args . push ( arg . trim ( ) ) ;
}
return args ;
}
exports . argStringToArray = argStringToArray ;
class ExecState extends events . EventEmitter {
constructor ( options , toolPath ) {
super ( ) ;
this . processClosed = false ; // tracks whether the process has exited and stdio is closed
this . processError = '' ;
this . processExitCode = 0 ;
this . processExited = false ; // tracks whether the process has exited
this . processStderr = false ; // tracks whether stderr was written to
this . delay = 10000 ; // 10 seconds
this . done = false ;
this . timeout = null ;
if ( ! toolPath ) {
throw new Error ( 'toolPath must not be empty' ) ;
}
this . options = options ;
this . toolPath = toolPath ;
if ( options . delay ) {
this . delay = options . delay ;
}
}
CheckComplete ( ) {
if ( this . done ) {
return ;
}
if ( this . processClosed ) {
this . _setResult ( ) ;
}
else if ( this . processExited ) {
this . timeout = timers _1 . setTimeout ( ExecState . HandleTimeout , this . delay , this ) ;
}
}
_debug ( message ) {
this . emit ( 'debug' , message ) ;
}
_setResult ( ) {
// determine whether there is an error
let error ;
if ( this . processExited ) {
if ( this . processError ) {
error = new Error ( ` There was an error when attempting to execute the process ' ${ this . toolPath } '. This may indicate the process failed to start. Error: ${ this . processError } ` ) ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
else if ( this . processExitCode !== 0 && ! this . options . ignoreReturnCode ) {
error = new Error ( ` The process ' ${ this . toolPath } ' failed with exit code ${ this . processExitCode } ` ) ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
else if ( this . processStderr && this . options . failOnStdErr ) {
error = new Error ( ` The process ' ${ this . toolPath } ' failed because one or more lines were written to the STDERR stream ` ) ;
2021-10-07 01:39:26 +00:00
}
}
2024-10-08 20:21:42 +01:00
// clear the timeout
if ( this . timeout ) {
clearTimeout ( this . timeout ) ;
this . timeout = null ;
}
this . done = true ;
this . emit ( 'done' , error , this . processExitCode ) ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
static HandleTimeout ( state ) {
if ( state . done ) {
return ;
}
if ( ! state . processClosed && state . processExited ) {
const message = ` The STDIO streams did not close within ${ state . delay /
1000 } seconds of the exit event from process '${state.toolPath}' . This may indicate a child process inherited the STDIO streams and has not yet exited . ` ;
state . _debug ( message ) ;
}
state . _setResult ( ) ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
}
//# sourceMappingURL=toolrunner.js.map
/***/ } ) ,
/***/ 4552 :
/***/ ( function ( _ _unused _webpack _module , exports ) {
"use strict" ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . PersonalAccessTokenCredentialHandler = exports . BearerCredentialHandler = exports . BasicCredentialHandler = void 0 ;
class BasicCredentialHandler {
constructor ( username , password ) {
this . username = username ;
this . password = password ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
prepareRequest ( options ) {
if ( ! options . headers ) {
throw Error ( 'The request has no headers' ) ;
}
options . headers [ 'Authorization' ] = ` Basic ${ Buffer . from ( ` ${ this . username } : ${ this . password } ` ) . toString ( 'base64' ) } ` ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
// This handler cannot handle 401
canHandleAuthentication ( ) {
return false ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
handleAuthentication ( ) {
2022-08-19 02:59:02 +00:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
2024-10-08 20:21:42 +01:00
throw new Error ( 'not implemented' ) ;
2022-08-19 02:59:02 +00:00
} ) ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
}
exports . BasicCredentialHandler = BasicCredentialHandler ;
class BearerCredentialHandler {
constructor ( token ) {
this . token = token ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
// 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 } ` ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01:00
// This handler cannot handle 401
canHandleAuthentication ( ) {
return false ;
}
handleAuthentication ( ) {
2022-08-19 02:59:02 +00:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
2024-10-08 20:21:42 +01:00
throw new Error ( 'not implemented' ) ;
2022-08-19 02:59:02 +00:00
} ) ;
2021-10-07 01:39:26 +00:00
}
2024-10-08 20:21:42 +01: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
/***/ } ) ,
/***/ 4844 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
/* eslint-disable @typescript-eslint/no-explicit-any */
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . HttpClient = exports . isHttps = exports . HttpClientResponse = exports . HttpClientError = exports . getProxyUrl = exports . MediaTypes = exports . Headers = exports . HttpCodes = void 0 ;
const http = _ _importStar ( _ _nccwpck _require _ _ ( 8611 ) ) ;
const https = _ _importStar ( _ _nccwpck _require _ _ ( 5692 ) ) ;
const pm = _ _importStar ( _ _nccwpck _require _ _ ( 4988 ) ) ;
const tunnel = _ _importStar ( _ _nccwpck _require _ _ ( 770 ) ) ;
var HttpCodes ;
( function ( HttpCodes ) {
HttpCodes [ HttpCodes [ "OK" ] = 200 ] = "OK" ;
HttpCodes [ HttpCodes [ "MultipleChoices" ] = 300 ] = "MultipleChoices" ;
HttpCodes [ HttpCodes [ "MovedPermanently" ] = 301 ] = "MovedPermanently" ;
HttpCodes [ HttpCodes [ "ResourceMoved" ] = 302 ] = "ResourceMoved" ;
HttpCodes [ HttpCodes [ "SeeOther" ] = 303 ] = "SeeOther" ;
HttpCodes [ HttpCodes [ "NotModified" ] = 304 ] = "NotModified" ;
HttpCodes [ HttpCodes [ "UseProxy" ] = 305 ] = "UseProxy" ;
HttpCodes [ HttpCodes [ "SwitchProxy" ] = 306 ] = "SwitchProxy" ;
HttpCodes [ HttpCodes [ "TemporaryRedirect" ] = 307 ] = "TemporaryRedirect" ;
HttpCodes [ HttpCodes [ "PermanentRedirect" ] = 308 ] = "PermanentRedirect" ;
HttpCodes [ HttpCodes [ "BadRequest" ] = 400 ] = "BadRequest" ;
HttpCodes [ HttpCodes [ "Unauthorized" ] = 401 ] = "Unauthorized" ;
HttpCodes [ HttpCodes [ "PaymentRequired" ] = 402 ] = "PaymentRequired" ;
HttpCodes [ HttpCodes [ "Forbidden" ] = 403 ] = "Forbidden" ;
HttpCodes [ HttpCodes [ "NotFound" ] = 404 ] = "NotFound" ;
HttpCodes [ HttpCodes [ "MethodNotAllowed" ] = 405 ] = "MethodNotAllowed" ;
HttpCodes [ HttpCodes [ "NotAcceptable" ] = 406 ] = "NotAcceptable" ;
HttpCodes [ HttpCodes [ "ProxyAuthenticationRequired" ] = 407 ] = "ProxyAuthenticationRequired" ;
HttpCodes [ HttpCodes [ "RequestTimeout" ] = 408 ] = "RequestTimeout" ;
HttpCodes [ HttpCodes [ "Conflict" ] = 409 ] = "Conflict" ;
HttpCodes [ HttpCodes [ "Gone" ] = 410 ] = "Gone" ;
HttpCodes [ HttpCodes [ "TooManyRequests" ] = 429 ] = "TooManyRequests" ;
HttpCodes [ HttpCodes [ "InternalServerError" ] = 500 ] = "InternalServerError" ;
HttpCodes [ HttpCodes [ "NotImplemented" ] = 501 ] = "NotImplemented" ;
HttpCodes [ HttpCodes [ "BadGateway" ] = 502 ] = "BadGateway" ;
HttpCodes [ HttpCodes [ "ServiceUnavailable" ] = 503 ] = "ServiceUnavailable" ;
HttpCodes [ HttpCodes [ "GatewayTimeout" ] = 504 ] = "GatewayTimeout" ;
} ) ( HttpCodes = exports . HttpCodes || ( exports . HttpCodes = { } ) ) ;
var Headers ;
( function ( Headers ) {
Headers [ "Accept" ] = "accept" ;
Headers [ "ContentType" ] = "content-type" ;
} ) ( Headers = exports . Headers || ( exports . Headers = { } ) ) ;
var MediaTypes ;
( function ( MediaTypes ) {
MediaTypes [ "ApplicationJson" ] = "application/json" ;
} ) ( MediaTypes = exports . MediaTypes || ( exports . MediaTypes = { } ) ) ;
/ * *
* Returns the proxy URL , depending upon the supplied url and proxy environment variables .
* @ param serverUrl The server URL where the request will be sent . For example , https : //api.github.com
* /
function getProxyUrl ( serverUrl ) {
const proxyUrl = pm . getProxyUrl ( new URL ( serverUrl ) ) ;
return proxyUrl ? proxyUrl . href : '' ;
}
exports . getProxyUrl = getProxyUrl ;
const HttpRedirectCodes = [
HttpCodes . MovedPermanently ,
HttpCodes . ResourceMoved ,
HttpCodes . SeeOther ,
HttpCodes . TemporaryRedirect ,
HttpCodes . PermanentRedirect
] ;
const HttpResponseRetryCodes = [
HttpCodes . BadGateway ,
HttpCodes . ServiceUnavailable ,
HttpCodes . GatewayTimeout
] ;
const RetryableHttpVerbs = [ 'OPTIONS' , 'GET' , 'DELETE' , 'HEAD' ] ;
const ExponentialBackoffCeiling = 10 ;
const ExponentialBackoffTimeSlice = 5 ;
class HttpClientError extends Error {
constructor ( message , statusCode ) {
super ( message ) ;
this . name = 'HttpClientError' ;
this . statusCode = statusCode ;
Object . setPrototypeOf ( this , HttpClientError . prototype ) ;
}
}
exports . HttpClientError = HttpClientError ;
class HttpClientResponse {
constructor ( message ) {
this . message = message ;
}
readBody ( ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return new Promise ( ( resolve ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
let output = Buffer . alloc ( 0 ) ;
this . message . on ( 'data' , ( chunk ) => {
output = Buffer . concat ( [ output , chunk ] ) ;
} ) ;
this . message . on ( 'end' , ( ) => {
resolve ( output . toString ( ) ) ;
} ) ;
} ) ) ;
} ) ;
}
}
exports . HttpClientResponse = HttpClientResponse ;
function isHttps ( requestUrl ) {
const parsedUrl = new URL ( requestUrl ) ;
return parsedUrl . protocol === 'https:' ;
}
exports . isHttps = isHttps ;
class HttpClient {
constructor ( userAgent , handlers , requestOptions ) {
this . _ignoreSslError = false ;
this . _allowRedirects = true ;
this . _allowRedirectDowngrade = false ;
this . _maxRedirects = 50 ;
this . _allowRetries = false ;
this . _maxRetries = 1 ;
this . _keepAlive = false ;
this . _disposed = false ;
this . userAgent = userAgent ;
this . handlers = handlers || [ ] ;
this . requestOptions = requestOptions ;
if ( requestOptions ) {
if ( requestOptions . ignoreSslError != null ) {
this . _ignoreSslError = requestOptions . ignoreSslError ;
}
this . _socketTimeout = requestOptions . socketTimeout ;
if ( requestOptions . allowRedirects != null ) {
this . _allowRedirects = requestOptions . allowRedirects ;
}
if ( requestOptions . allowRedirectDowngrade != null ) {
this . _allowRedirectDowngrade = requestOptions . allowRedirectDowngrade ;
}
if ( requestOptions . maxRedirects != null ) {
this . _maxRedirects = Math . max ( requestOptions . maxRedirects , 0 ) ;
}
if ( requestOptions . keepAlive != null ) {
this . _keepAlive = requestOptions . keepAlive ;
}
if ( requestOptions . allowRetries != null ) {
this . _allowRetries = requestOptions . allowRetries ;
}
if ( requestOptions . maxRetries != null ) {
this . _maxRetries = requestOptions . maxRetries ;
}
}
}
options ( requestUrl , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'OPTIONS' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
}
get ( requestUrl , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'GET' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
}
del ( requestUrl , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'DELETE' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
}
post ( requestUrl , data , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'POST' , requestUrl , data , additionalHeaders || { } ) ;
} ) ;
}
patch ( requestUrl , data , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'PATCH' , requestUrl , data , additionalHeaders || { } ) ;
} ) ;
}
put ( requestUrl , data , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'PUT' , requestUrl , data , additionalHeaders || { } ) ;
} ) ;
}
head ( requestUrl , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( 'HEAD' , requestUrl , null , additionalHeaders || { } ) ;
} ) ;
}
sendStream ( verb , requestUrl , stream , additionalHeaders ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return this . request ( verb , requestUrl , stream , additionalHeaders ) ;
} ) ;
}
/ * *
* Gets a typed object from an endpoint
* Be aware that not found returns a null . Other errors ( 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 ) ;
2022-08-19 02:59:02 +00:00
const res = yield this . get ( requestUrl , additionalHeaders ) ;
return this . _processResponse ( res , this . requestOptions ) ;
} ) ;
}
postJson ( requestUrl , obj , additionalHeaders = { } ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const data = JSON . stringify ( obj , null , 2 ) ;
additionalHeaders [ Headers . Accept ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . Accept , MediaTypes . ApplicationJson ) ;
additionalHeaders [ Headers . ContentType ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . ContentType , MediaTypes . ApplicationJson ) ;
const res = yield this . post ( requestUrl , data , additionalHeaders ) ;
return this . _processResponse ( res , this . requestOptions ) ;
} ) ;
}
putJson ( requestUrl , obj , additionalHeaders = { } ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const data = JSON . stringify ( obj , null , 2 ) ;
additionalHeaders [ Headers . Accept ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . Accept , MediaTypes . ApplicationJson ) ;
additionalHeaders [ Headers . ContentType ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . ContentType , MediaTypes . ApplicationJson ) ;
const res = yield this . put ( requestUrl , data , additionalHeaders ) ;
return this . _processResponse ( res , this . requestOptions ) ;
} ) ;
}
patchJson ( requestUrl , obj , additionalHeaders = { } ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const data = JSON . stringify ( obj , null , 2 ) ;
additionalHeaders [ Headers . Accept ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . Accept , MediaTypes . ApplicationJson ) ;
additionalHeaders [ Headers . ContentType ] = this . _getExistingOrDefaultHeader ( additionalHeaders , Headers . ContentType , MediaTypes . ApplicationJson ) ;
const res = yield this . patch ( requestUrl , data , additionalHeaders ) ;
return this . _processResponse ( res , this . requestOptions ) ;
} ) ;
2021-10-07 01:39:26 +00:00
}
/ * *
* Makes a raw http request .
* All other methods such as get , post , patch , and request ultimately call this .
* Prefer get , del , post and patch
* /
2022-08-19 02:59:02 +00:00
request ( verb , requestUrl , data , headers ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( this . _disposed ) {
throw new Error ( 'Client has already been disposed.' ) ;
}
const parsedUrl = new URL ( requestUrl ) ;
let info = this . _prepareRequest ( verb , parsedUrl , headers ) ;
// Only perform retries on reads since writes may not be idempotent.
const maxTries = this . _allowRetries && RetryableHttpVerbs . includes ( verb )
? this . _maxRetries + 1
: 1 ;
let numTries = 0 ;
let response ;
do {
response = yield this . requestRaw ( info , data ) ;
// Check if it's an authentication challenge
if ( response &&
response . message &&
response . message . statusCode === HttpCodes . Unauthorized ) {
let authenticationHandler ;
for ( const handler of this . handlers ) {
if ( handler . canHandleAuthentication ( response ) ) {
authenticationHandler = handler ;
break ;
}
}
if ( authenticationHandler ) {
return authenticationHandler . handleAuthentication ( this , info , data ) ;
}
else {
// We have received an unauthorized response but have no handlers to handle it.
// Let the response return to the caller.
return response ;
2021-10-07 01:39:26 +00:00
}
}
2022-08-19 02:59:02 +00:00
let redirectsRemaining = this . _maxRedirects ;
while ( response . message . statusCode &&
HttpRedirectCodes . includes ( response . message . statusCode ) &&
this . _allowRedirects &&
redirectsRemaining > 0 ) {
const redirectUrl = response . message . headers [ 'location' ] ;
if ( ! redirectUrl ) {
// if there's no location to redirect to, we won't
break ;
}
const parsedRedirectUrl = new URL ( redirectUrl ) ;
if ( parsedUrl . protocol === 'https:' &&
parsedUrl . protocol !== parsedRedirectUrl . protocol &&
! this . _allowRedirectDowngrade ) {
throw new Error ( 'Redirect from HTTPS to HTTP protocol. This downgrade is not allowed for security reasons. If you want to allow this behavior, set the allowRedirectDowngrade option to true.' ) ;
}
// we need to finish reading the response before reassigning response
// which will leak the open socket.
yield response . readBody ( ) ;
// strip authorization header if redirected to a different hostname
if ( parsedRedirectUrl . hostname !== parsedUrl . hostname ) {
for ( const header in headers ) {
// header names are case insensitive
if ( header . toLowerCase ( ) === 'authorization' ) {
delete headers [ header ] ;
}
}
}
// let's make the request with the new redirectUrl
info = this . _prepareRequest ( verb , parsedRedirectUrl , headers ) ;
response = yield this . requestRaw ( info , data ) ;
redirectsRemaining -- ;
2021-10-07 01:39:26 +00:00
}
2022-08-19 02:59:02 +00:00
if ( ! response . message . statusCode ||
! HttpResponseRetryCodes . includes ( response . message . statusCode ) ) {
// If not a retry code, return immediately instead of retrying
2021-10-07 01:39:26 +00:00
return response ;
}
2022-08-19 02:59:02 +00:00
numTries += 1 ;
if ( numTries < maxTries ) {
yield response . readBody ( ) ;
yield this . _performExponentialBackoff ( numTries ) ;
2021-10-07 01:39:26 +00:00
}
2022-08-19 02:59:02 +00:00
} while ( numTries < maxTries ) ;
return response ;
} ) ;
2021-10-07 01:39:26 +00:00
}
/ * *
* Needs to be called if keepAlive is set to true in request options .
* /
dispose ( ) {
if ( this . _agent ) {
this . _agent . destroy ( ) ;
}
this . _disposed = true ;
}
/ * *
* Raw request .
* @ param info
* @ param data
* /
requestRaw ( info , data ) {
2022-08-19 02:59:02 +00:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return new Promise ( ( resolve , reject ) => {
function callbackForResult ( err , res ) {
if ( err ) {
reject ( err ) ;
}
else if ( ! res ) {
// If `err` is not passed, then `res` must be passed.
reject ( new Error ( 'Unknown error' ) ) ;
}
else {
resolve ( res ) ;
}
2021-10-07 01:39:26 +00:00
}
2022-08-19 02:59:02 +00:00
this . requestRawWithCallback ( info , data , callbackForResult ) ;
} ) ;
2021-10-07 01:39:26 +00:00
} ) ;
}
/ * *
* Raw request with callback .
* @ param info
* @ param data
* @ param onResult
* /
requestRawWithCallback ( info , data , onResult ) {
if ( typeof data === 'string' ) {
2022-08-19 02:59:02 +00:00
if ( ! info . options . headers ) {
info . options . headers = { } ;
}
2021-10-07 01:39:26 +00:00
info . options . headers [ 'Content-Length' ] = Buffer . byteLength ( data , 'utf8' ) ;
}
let callbackCalled = false ;
2022-08-19 02:59:02 +00:00
function handleResult ( err , res ) {
2021-10-07 01:39:26 +00:00
if ( ! callbackCalled ) {
callbackCalled = true ;
onResult ( err , res ) ;
}
2022-08-19 02:59:02 +00:00
}
const req = info . httpModule . request ( info . options , ( msg ) => {
const res = new HttpClientResponse ( msg ) ;
handleResult ( undefined , res ) ;
2021-10-07 01:39:26 +00:00
} ) ;
2022-08-19 02:59:02 +00:00
let socket ;
2021-10-07 01:39:26 +00:00
req . on ( 'socket' , sock => {
socket = sock ;
} ) ;
// If we ever get disconnected, we want the socket to timeout eventually
req . setTimeout ( this . _socketTimeout || 3 * 60000 , ( ) => {
if ( socket ) {
socket . end ( ) ;
}
2022-08-19 02:59:02 +00:00
handleResult ( new Error ( ` Request timeout: ${ info . options . path } ` ) ) ;
2021-10-07 01:39:26 +00:00
} ) ;
req . on ( 'error' , function ( err ) {
// err has statusCode property
// res should have headers
2022-08-19 02:59:02 +00:00
handleResult ( err ) ;
2021-10-07 01:39:26 +00:00
} ) ;
if ( data && typeof data === 'string' ) {
req . write ( data , 'utf8' ) ;
}
if ( data && typeof data !== 'string' ) {
data . on ( 'close' , function ( ) {
req . end ( ) ;
} ) ;
data . pipe ( req ) ;
}
else {
req . end ( ) ;
}
}
/ * *
* Gets an http agent . This function is useful when you need an http agent that handles
* routing through a proxy server - depending upon the url and proxy environment variables .
* @ param serverUrl The server URL where the request will be sent . For example , https : //api.github.com
* /
getAgent ( serverUrl ) {
2022-08-19 02:59:02 +00:00
const parsedUrl = new URL ( serverUrl ) ;
2021-10-07 01:39:26 +00:00
return this . _getAgent ( parsedUrl ) ;
}
_prepareRequest ( method , requestUrl , headers ) {
const info = { } ;
info . parsedUrl = requestUrl ;
const usingSsl = info . parsedUrl . protocol === 'https:' ;
info . httpModule = usingSsl ? https : http ;
const defaultPort = usingSsl ? 443 : 80 ;
info . options = { } ;
info . options . host = info . parsedUrl . hostname ;
info . options . port = info . parsedUrl . port
? parseInt ( info . parsedUrl . port )
: defaultPort ;
info . options . path =
( info . parsedUrl . pathname || '' ) + ( info . parsedUrl . search || '' ) ;
info . options . method = method ;
info . options . headers = this . _mergeHeaders ( headers ) ;
if ( this . userAgent != null ) {
info . options . headers [ 'user-agent' ] = this . userAgent ;
}
info . options . agent = this . _getAgent ( info . parsedUrl ) ;
// gives handlers an opportunity to participate
if ( this . handlers ) {
2022-08-19 02:59:02 +00:00
for ( const handler of this . handlers ) {
2021-10-07 01:39:26 +00:00
handler . prepareRequest ( info . options ) ;
2022-08-19 02:59:02 +00:00
}
2021-10-07 01:39:26 +00:00
}
return info ;
}
_mergeHeaders ( headers ) {
if ( this . requestOptions && this . requestOptions . headers ) {
2022-08-19 02:59:02 +00:00
return Object . assign ( { } , lowercaseKeys ( this . requestOptions . headers ) , lowercaseKeys ( headers || { } ) ) ;
2021-10-07 01:39:26 +00:00
}
return lowercaseKeys ( headers || { } ) ;
}
_getExistingOrDefaultHeader ( additionalHeaders , header , _default ) {
let clientHeader ;
if ( this . requestOptions && this . requestOptions . headers ) {
clientHeader = lowercaseKeys ( this . requestOptions . headers ) [ header ] ;
}
return additionalHeaders [ header ] || clientHeader || _default ;
}
_getAgent ( parsedUrl ) {
let agent ;
2022-08-19 02:59:02 +00:00
const proxyUrl = pm . getProxyUrl ( parsedUrl ) ;
const useProxy = proxyUrl && proxyUrl . hostname ;
2021-10-07 01:39:26 +00:00
if ( this . _keepAlive && useProxy ) {
agent = this . _proxyAgent ;
}
if ( this . _keepAlive && ! useProxy ) {
agent = this . _agent ;
}
// if agent is already assigned use that agent.
2022-08-19 02:59:02 +00:00
if ( agent ) {
2021-10-07 01:39:26 +00:00
return agent ;
}
const usingSsl = parsedUrl . protocol === 'https:' ;
let maxSockets = 100 ;
2022-08-19 02:59:02 +00:00
if ( this . requestOptions ) {
2021-10-07 01:39:26 +00:00
maxSockets = this . requestOptions . maxSockets || http . globalAgent . maxSockets ;
}
2022-08-19 02:59:02 +00:00
// This is `useProxy` again, but we need to check `proxyURl` directly for TypeScripts's flow analysis.
if ( proxyUrl && proxyUrl . hostname ) {
2021-10-07 01:39:26 +00:00
const agentOptions = {
2022-08-19 02:59:02 +00:00
maxSockets ,
2021-10-07 01:39:26 +00:00
keepAlive : this . _keepAlive ,
2022-08-19 02:59:02 +00:00
proxy : Object . assign ( Object . assign ( { } , ( ( proxyUrl . username || proxyUrl . password ) && {
proxyAuth : ` ${ proxyUrl . username } : ${ proxyUrl . password } `
} ) ) , { host : proxyUrl . hostname , port : proxyUrl . port } )
2021-10-07 01:39:26 +00:00
} ;
let tunnelAgent ;
const overHttps = proxyUrl . protocol === 'https:' ;
if ( usingSsl ) {
tunnelAgent = overHttps ? tunnel . httpsOverHttps : tunnel . httpsOverHttp ;
}
else {
tunnelAgent = overHttps ? tunnel . httpOverHttps : tunnel . httpOverHttp ;
}
agent = tunnelAgent ( agentOptions ) ;
this . _proxyAgent = agent ;
}
// if reusing agent across request and tunneling agent isn't assigned create a new agent
if ( this . _keepAlive && ! agent ) {
2022-08-19 02:59:02 +00:00
const options = { keepAlive : this . _keepAlive , maxSockets } ;
2021-10-07 01:39:26 +00:00
agent = usingSsl ? new https . Agent ( options ) : new http . Agent ( options ) ;
this . _agent = agent ;
}
// if not using private agent and tunnel agent isn't setup then use global agent
if ( ! agent ) {
agent = usingSsl ? https . globalAgent : http . globalAgent ;
}
if ( usingSsl && this . _ignoreSslError ) {
// we don't want to set NODE_TLS_REJECT_UNAUTHORIZED=0 since that will affect request for entire process
// http.RequestOptions doesn't expose a way to modify RequestOptions.agent.options
// we have to cast it to any and change it directly
agent . options = Object . assign ( agent . options || { } , {
rejectUnauthorized : false
} ) ;
}
return agent ;
}
_performExponentialBackoff ( retryNumber ) {
2022-08-19 02:59:02 +00:00
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
retryNumber = Math . min ( ExponentialBackoffCeiling , retryNumber ) ;
const ms = ExponentialBackoffTimeSlice * Math . pow ( 2 , retryNumber ) ;
return new Promise ( resolve => setTimeout ( ( ) => resolve ( ) , ms ) ) ;
} ) ;
}
_processResponse ( res , options ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
return new Promise ( ( resolve , reject ) => _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const statusCode = res . message . statusCode || 0 ;
const response = {
statusCode ,
result : null ,
headers : { }
} ;
// not found leads to null obj returned
if ( statusCode === HttpCodes . NotFound ) {
resolve ( response ) ;
}
// get the result from the body
function dateTimeDeserializer ( key , value ) {
if ( typeof value === 'string' ) {
const a = new Date ( value ) ;
if ( ! isNaN ( a . valueOf ( ) ) ) {
return a ;
}
2021-10-07 01:39:26 +00:00
}
2022-08-19 02:59:02 +00:00
return value ;
}
let obj ;
let contents ;
try {
contents = yield res . readBody ( ) ;
if ( contents && contents . length > 0 ) {
if ( options && options . deserializeDates ) {
obj = JSON . parse ( contents , dateTimeDeserializer ) ;
}
else {
obj = JSON . parse ( contents ) ;
}
response . result = obj ;
2021-10-07 01:39:26 +00:00
}
2022-08-19 02:59:02 +00:00
response . headers = res . message . headers ;
2021-10-07 01:39:26 +00:00
}
2022-08-19 02:59:02 +00:00
catch ( err ) {
// Invalid resource (contents not json); leaving result obj null
2021-10-07 01:39:26 +00:00
}
2022-08-19 02:59:02 +00:00
// note that 3xx redirects are handled by the http layer.
if ( statusCode > 299 ) {
let msg ;
// if exception/error in body, attempt to get better error
if ( obj && obj . message ) {
msg = obj . message ;
}
else if ( contents && contents . length > 0 ) {
// it may be the case that the exception is in the body message as string
msg = contents ;
}
else {
msg = ` Failed request: ( ${ statusCode } ) ` ;
}
const err = new HttpClientError ( msg , statusCode ) ;
err . result = response . result ;
reject ( err ) ;
2021-10-07 01:39:26 +00:00
}
else {
2022-08-19 02:59:02 +00:00
resolve ( response ) ;
2021-10-07 01:39:26 +00:00
}
2022-08-19 02:59:02 +00:00
} ) ) ;
2021-10-07 01:39:26 +00:00
} ) ;
}
}
exports . HttpClient = HttpClient ;
2022-08-19 02:59:02 +00:00
const lowercaseKeys = ( obj ) => Object . keys ( obj ) . reduce ( ( c , k ) => ( ( c [ k . toLowerCase ( ) ] = obj [ k ] ) , c ) , { } ) ;
//# sourceMappingURL=index.js.map
2021-10-07 01:39:26 +00:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 4988 :
2021-10-07 01:39:26 +00:00
/***/ ( ( _ _unused _webpack _module , exports ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2022-08-19 02:59:02 +00:00
exports . checkBypass = exports . getProxyUrl = void 0 ;
2021-10-07 01:39:26 +00:00
function getProxyUrl ( reqUrl ) {
2022-08-19 02:59:02 +00:00
const usingSsl = reqUrl . protocol === 'https:' ;
2021-10-07 01:39:26 +00:00
if ( checkBypass ( reqUrl ) ) {
2022-08-19 02:59:02 +00:00
return undefined ;
2021-10-07 01:39:26 +00:00
}
2022-08-19 02:59:02 +00:00
const proxyVar = ( ( ) => {
if ( usingSsl ) {
return process . env [ 'https_proxy' ] || process . env [ 'HTTPS_PROXY' ] ;
}
else {
return process . env [ 'http_proxy' ] || process . env [ 'HTTP_PROXY' ] ;
}
} ) ( ) ;
if ( proxyVar ) {
return new URL ( proxyVar ) ;
2021-10-07 01:39:26 +00:00
}
else {
2022-08-19 02:59:02 +00:00
return undefined ;
2021-10-07 01:39:26 +00:00
}
}
exports . getProxyUrl = getProxyUrl ;
function checkBypass ( reqUrl ) {
if ( ! reqUrl . hostname ) {
return false ;
}
2022-08-19 02:59:02 +00:00
const noProxy = process . env [ 'no_proxy' ] || process . env [ 'NO_PROXY' ] || '' ;
2021-10-07 01:39:26 +00:00
if ( ! noProxy ) {
return false ;
}
// Determine the request port
let reqPort ;
if ( reqUrl . port ) {
reqPort = Number ( reqUrl . port ) ;
}
else if ( reqUrl . protocol === 'http:' ) {
reqPort = 80 ;
}
else if ( reqUrl . protocol === 'https:' ) {
reqPort = 443 ;
}
// Format the request hostname and hostname with port
2022-08-19 02:59:02 +00:00
const upperReqHosts = [ reqUrl . hostname . toUpperCase ( ) ] ;
2021-10-07 01:39:26 +00:00
if ( typeof reqPort === 'number' ) {
upperReqHosts . push ( ` ${ upperReqHosts [ 0 ] } : ${ reqPort } ` ) ;
}
// Compare request host against noproxy
2022-08-19 02:59:02 +00:00
for ( const upperNoProxyItem of noProxy
2021-10-07 01:39:26 +00:00
. split ( ',' )
. map ( x => x . trim ( ) . toUpperCase ( ) )
. filter ( x => x ) ) {
if ( upperReqHosts . some ( x => x === upperNoProxyItem ) ) {
return true ;
}
}
return false ;
}
exports . checkBypass = checkBypass ;
2022-08-19 02:59:02 +00:00
//# sourceMappingURL=proxy.js.map
2021-10-07 01:39:26 +00:00
2020-10-02 06:49:03 +00:00
/***/ } ) ,
2024-10-08 20:21:42 +01:00
/***/ 5207 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
2020-09-23 15:58:52 +09:00
"use strict" ;
2024-10-08 20:21:42 +01: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 ( ) ) ;
} ) ;
} ;
var _a ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . getCmdPath = exports . tryGetExecutablePath = exports . isRooted = exports . isDirectory = exports . exists = exports . READONLY = exports . UV _FS _O _EXLOCK = exports . IS _WINDOWS = exports . unlink = exports . symlink = exports . stat = exports . rmdir = exports . rm = exports . rename = exports . readlink = exports . readdir = exports . open = exports . mkdir = exports . lstat = exports . copyFile = exports . chmod = void 0 ;
const fs = _ _importStar ( _ _nccwpck _require _ _ ( 9896 ) ) ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 6928 ) ) ;
_a = fs . promises
// export const {open} = 'fs'
, exports . chmod = _a . chmod , exports . copyFile = _a . copyFile , exports . lstat = _a . lstat , exports . mkdir = _a . mkdir , exports . open = _a . open , exports . readdir = _a . readdir , exports . readlink = _a . readlink , exports . rename = _a . rename , exports . rm = _a . rm , exports . rmdir = _a . rmdir , exports . stat = _a . stat , exports . symlink = _a . symlink , exports . unlink = _a . unlink ;
// export const {open} = 'fs'
exports . IS _WINDOWS = process . platform === 'win32' ;
// See https://github.com/nodejs/node/blob/d0153aee367422d0858105abec186da4dff0a0c5/deps/uv/include/uv/win.h#L691
exports . UV _FS _O _EXLOCK = 0x10000000 ;
exports . READONLY = fs . constants . O _RDONLY ;
function exists ( fsPath ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
try {
yield exports . stat ( fsPath ) ;
}
catch ( err ) {
if ( err . code === 'ENOENT' ) {
return false ;
}
throw err ;
}
return true ;
} ) ;
}
exports . exists = exists ;
function isDirectory ( fsPath , useStat = false ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const stats = useStat ? yield exports . stat ( fsPath ) : yield exports . lstat ( fsPath ) ;
return stats . isDirectory ( ) ;
} ) ;
}
exports . isDirectory = isDirectory ;
/ * *
* On OSX / Linux , true if path starts with '/' . On Windows , true for paths like :
* \ , \ hello , \ \ hello \ share , C : , and C : \ hello ( and corresponding alternate separator cases ) .
* /
function isRooted ( p ) {
p = normalizeSeparators ( p ) ;
if ( ! p ) {
throw new Error ( 'isRooted() parameter "p" cannot be empty' ) ;
}
if ( exports . IS _WINDOWS ) {
return ( p . startsWith ( '\\' ) || /^[A-Z]:/i . test ( p ) // e.g. \ or \hello or \\hello
) ; // e.g. C: or C:\hello
}
return p . startsWith ( '/' ) ;
}
exports . isRooted = isRooted ;
/ * *
* Best effort attempt to determine whether a file exists and is executable .
* @ param filePath file path to check
* @ param extensions additional file extensions to try
* @ return if file exists and is executable , returns the file path . otherwise empty string .
* /
function tryGetExecutablePath ( filePath , extensions ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
let stats = undefined ;
try {
// test file exists
stats = yield exports . stat ( filePath ) ;
}
catch ( err ) {
if ( err . code !== 'ENOENT' ) {
// eslint-disable-next-line no-console
console . log ( ` Unexpected error attempting to determine if executable file exists ' ${ filePath } ': ${ err } ` ) ;
}
}
if ( stats && stats . isFile ( ) ) {
if ( exports . IS _WINDOWS ) {
// on Windows, test for valid extension
const upperExt = path . extname ( filePath ) . toUpperCase ( ) ;
if ( extensions . some ( validExt => validExt . toUpperCase ( ) === upperExt ) ) {
return filePath ;
}
}
else {
if ( isUnixExecutable ( stats ) ) {
return filePath ;
}
}
}
// try each extension
const originalFilePath = filePath ;
for ( const extension of extensions ) {
filePath = originalFilePath + extension ;
stats = undefined ;
try {
stats = yield exports . stat ( filePath ) ;
}
catch ( err ) {
if ( err . code !== 'ENOENT' ) {
// eslint-disable-next-line no-console
console . log ( ` Unexpected error attempting to determine if executable file exists ' ${ filePath } ': ${ err } ` ) ;
}
}
if ( stats && stats . isFile ( ) ) {
if ( exports . IS _WINDOWS ) {
// preserve the case of the actual file (since an extension was appended)
try {
const directory = path . dirname ( filePath ) ;
const upperName = path . basename ( filePath ) . toUpperCase ( ) ;
for ( const actualName of yield exports . readdir ( directory ) ) {
if ( upperName === actualName . toUpperCase ( ) ) {
filePath = path . join ( directory , actualName ) ;
break ;
}
}
}
catch ( err ) {
// eslint-disable-next-line no-console
console . log ( ` Unexpected error attempting to determine the actual case of the file ' ${ filePath } ': ${ err } ` ) ;
}
return filePath ;
}
else {
if ( isUnixExecutable ( stats ) ) {
return filePath ;
}
}
}
}
return '' ;
} ) ;
}
exports . tryGetExecutablePath = tryGetExecutablePath ;
function normalizeSeparators ( p ) {
p = p || '' ;
if ( exports . IS _WINDOWS ) {
// convert slashes on Windows
p = p . replace ( /\//g , '\\' ) ;
// remove redundant slashes
return p . replace ( /\\\\+/g , '\\' ) ;
}
// remove redundant slashes
return p . replace ( /\/\/+/g , '/' ) ;
}
// on Mac/Linux, test the execute bit
// R W X R W X R W X
// 256 128 64 32 16 8 4 2 1
function isUnixExecutable ( stats ) {
return ( ( stats . mode & 1 ) > 0 ||
( ( stats . mode & 8 ) > 0 && stats . gid === process . getgid ( ) ) ||
( ( stats . mode & 64 ) > 0 && stats . uid === process . getuid ( ) ) ) ;
}
// Get the path of cmd.exe in windows
function getCmdPath ( ) {
var _a ;
return ( _a = process . env [ 'COMSPEC' ] ) !== null && _a !== void 0 ? _a : ` cmd.exe ` ;
}
exports . getCmdPath = getCmdPath ;
//# sourceMappingURL=io-util.js.map
/***/ } ) ,
/***/ 4994 :
/***/ ( function ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) {
"use strict" ;
var _ _createBinding = ( this && this . _ _createBinding ) || ( Object . create ? ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
Object . defineProperty ( o , k2 , { enumerable : true , get : function ( ) { return m [ k ] ; } } ) ;
} ) : ( function ( o , m , k , k2 ) {
if ( k2 === undefined ) k2 = k ;
o [ k2 ] = m [ k ] ;
} ) ) ;
var _ _setModuleDefault = ( this && this . _ _setModuleDefault ) || ( Object . create ? ( function ( o , v ) {
Object . defineProperty ( o , "default" , { enumerable : true , value : v } ) ;
} ) : function ( o , v ) {
o [ "default" ] = v ;
} ) ;
var _ _importStar = ( this && this . _ _importStar ) || function ( mod ) {
if ( mod && mod . _ _esModule ) return mod ;
var result = { } ;
if ( mod != null ) for ( var k in mod ) if ( k !== "default" && Object . hasOwnProperty . call ( mod , k ) ) _ _createBinding ( result , mod , k ) ;
_ _setModuleDefault ( result , mod ) ;
return result ;
} ;
var _ _awaiter = ( this && this . _ _awaiter ) || function ( thisArg , _arguments , P , generator ) {
function adopt ( value ) { return value instanceof P ? value : new P ( function ( resolve ) { resolve ( value ) ; } ) ; }
return new ( P || ( P = Promise ) ) ( function ( resolve , reject ) {
function fulfilled ( value ) { try { step ( generator . next ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function rejected ( value ) { try { step ( generator [ "throw" ] ( value ) ) ; } catch ( e ) { reject ( e ) ; } }
function step ( result ) { result . done ? resolve ( result . value ) : adopt ( result . value ) . then ( fulfilled , rejected ) ; }
step ( ( generator = generator . apply ( thisArg , _arguments || [ ] ) ) . next ( ) ) ;
} ) ;
} ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
exports . findInPath = exports . which = exports . mkdirP = exports . rmRF = exports . mv = exports . cp = void 0 ;
const assert _1 = _ _nccwpck _require _ _ ( 2613 ) ;
const path = _ _importStar ( _ _nccwpck _require _ _ ( 6928 ) ) ;
const ioUtil = _ _importStar ( _ _nccwpck _require _ _ ( 5207 ) ) ;
/ * *
* Copies a file or folder .
* Based off of shelljs - https : //github.com/shelljs/shelljs/blob/9237f66c52e5daa40458f94f9565e18e8132f5a6/src/cp.js
*
* @ param source source path
* @ param dest destination path
* @ param options optional . See CopyOptions .
* /
function cp ( source , dest , options = { } ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
const { force , recursive , copySourceDirectory } = readCopyOptions ( options ) ;
const destStat = ( yield ioUtil . exists ( dest ) ) ? yield ioUtil . stat ( dest ) : null ;
// Dest is an existing file, but not forcing
if ( destStat && destStat . isFile ( ) && ! force ) {
return ;
}
// If dest is an existing directory, should copy inside.
const newDest = destStat && destStat . isDirectory ( ) && copySourceDirectory
? path . join ( dest , path . basename ( source ) )
: dest ;
if ( ! ( yield ioUtil . exists ( source ) ) ) {
throw new Error ( ` no such file or directory: ${ source } ` ) ;
}
const sourceStat = yield ioUtil . stat ( source ) ;
if ( sourceStat . isDirectory ( ) ) {
if ( ! recursive ) {
throw new Error ( ` Failed to copy. ${ source } is a directory, but tried to copy without recursive flag. ` ) ;
}
else {
yield cpDirRecursive ( source , newDest , 0 , force ) ;
}
}
else {
if ( path . relative ( source , newDest ) === '' ) {
// a file cannot be copied to itself
throw new Error ( ` ' ${ newDest } ' and ' ${ source } ' are the same file ` ) ;
}
yield copyFile ( source , newDest , force ) ;
}
} ) ;
}
exports . cp = cp ;
/ * *
* Moves a path .
*
* @ param source source path
* @ param dest destination path
* @ param options optional . See MoveOptions .
* /
function mv ( source , dest , options = { } ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( yield ioUtil . exists ( dest ) ) {
let destExists = true ;
if ( yield ioUtil . isDirectory ( dest ) ) {
// If dest is directory copy src into dest
dest = path . join ( dest , path . basename ( source ) ) ;
destExists = yield ioUtil . exists ( dest ) ;
}
if ( destExists ) {
if ( options . force == null || options . force ) {
yield rmRF ( dest ) ;
}
else {
throw new Error ( 'Destination already exists' ) ;
}
}
}
yield mkdirP ( path . dirname ( dest ) ) ;
yield ioUtil . rename ( source , dest ) ;
} ) ;
}
exports . mv = mv ;
/ * *
* Remove a path recursively with force
*
* @ param inputPath path to remove
* /
function rmRF ( inputPath ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( ioUtil . IS _WINDOWS ) {
// Check for invalid characters
// https://docs.microsoft.com/en-us/windows/win32/fileio/naming-a-file
if ( /[*"<>|]/ . test ( inputPath ) ) {
throw new Error ( 'File path must not contain `*`, `"`, `<`, `>` or `|` on Windows' ) ;
}
}
try {
// note if path does not exist, error is silent
yield ioUtil . rm ( inputPath , {
force : true ,
maxRetries : 3 ,
recursive : true ,
retryDelay : 300
} ) ;
}
catch ( err ) {
throw new Error ( ` File was unable to be removed ${ err } ` ) ;
}
} ) ;
}
exports . rmRF = rmRF ;
/ * *
* Make a directory . Creates the full path with folders in between
* Will throw if it fails
*
* @ param fsPath path to create
* @ returns Promise < void >
* /
function mkdirP ( fsPath ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
assert _1 . ok ( fsPath , 'a path argument must be provided' ) ;
yield ioUtil . mkdir ( fsPath , { recursive : true } ) ;
} ) ;
}
exports . mkdirP = mkdirP ;
/ * *
* Returns path of a tool had the tool actually been invoked . Resolves via paths .
* If you check and the tool does not exist , it will throw .
*
* @ param tool name of the tool
* @ param check whether to check if tool exists
* @ returns Promise < string > path to tool
* /
function which ( tool , check ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( ! tool ) {
throw new Error ( "parameter 'tool' is required" ) ;
}
// recursive when check=true
if ( check ) {
const result = yield which ( tool , false ) ;
if ( ! result ) {
if ( ioUtil . IS _WINDOWS ) {
throw new Error ( ` Unable to locate executable file: ${ tool } . Please verify either the file path exists or the file can be found within a directory specified by the PATH environment variable. Also verify the file has a valid extension for an executable file. ` ) ;
}
else {
throw new Error ( ` Unable to locate executable file: ${ tool } . Please verify either the file path exists or the file can be found within a directory specified by the PATH environment variable. Also check the file mode to verify the file is executable. ` ) ;
}
}
return result ;
}
const matches = yield findInPath ( tool ) ;
if ( matches && matches . length > 0 ) {
return matches [ 0 ] ;
}
return '' ;
} ) ;
}
exports . which = which ;
/ * *
* Returns a list of all occurrences of the given tool on the system path .
*
* @ returns Promise < string [ ] > the paths of the tool
* /
function findInPath ( tool ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( ! tool ) {
throw new Error ( "parameter 'tool' is required" ) ;
}
// build the list of extensions to try
const extensions = [ ] ;
if ( ioUtil . IS _WINDOWS && process . env [ 'PATHEXT' ] ) {
for ( const extension of process . env [ 'PATHEXT' ] . split ( path . delimiter ) ) {
if ( extension ) {
extensions . push ( extension ) ;
}
}
}
// if it's rooted, return it if exists. otherwise return empty.
if ( ioUtil . isRooted ( tool ) ) {
const filePath = yield ioUtil . tryGetExecutablePath ( tool , extensions ) ;
if ( filePath ) {
return [ filePath ] ;
}
return [ ] ;
}
// if any path separators, return empty
if ( tool . includes ( path . sep ) ) {
return [ ] ;
}
// build the list of directories
//
// Note, technically "where" checks the current directory on Windows. From a toolkit perspective,
// it feels like we should not do this. Checking the current directory seems like more of a use
// case of a shell, and the which() function exposed by the toolkit should strive for consistency
// across platforms.
const directories = [ ] ;
if ( process . env . PATH ) {
for ( const p of process . env . PATH . split ( path . delimiter ) ) {
if ( p ) {
directories . push ( p ) ;
}
}
}
// find all matches
const matches = [ ] ;
for ( const directory of directories ) {
const filePath = yield ioUtil . tryGetExecutablePath ( path . join ( directory , tool ) , extensions ) ;
if ( filePath ) {
matches . push ( filePath ) ;
}
}
return matches ;
} ) ;
}
exports . findInPath = findInPath ;
function readCopyOptions ( options ) {
const force = options . force == null ? true : options . force ;
const recursive = Boolean ( options . recursive ) ;
const copySourceDirectory = options . copySourceDirectory == null
? true
: Boolean ( options . copySourceDirectory ) ;
return { force , recursive , copySourceDirectory } ;
}
function cpDirRecursive ( sourceDir , destDir , currentDepth , force ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
// Ensure there is not a run away recursive copy
if ( currentDepth >= 255 )
return ;
currentDepth ++ ;
yield mkdirP ( destDir ) ;
const files = yield ioUtil . readdir ( sourceDir ) ;
for ( const fileName of files ) {
const srcFile = ` ${ sourceDir } / ${ fileName } ` ;
const destFile = ` ${ destDir } / ${ fileName } ` ;
const srcFileStat = yield ioUtil . lstat ( srcFile ) ;
if ( srcFileStat . isDirectory ( ) ) {
// Recurse
yield cpDirRecursive ( srcFile , destFile , currentDepth , force ) ;
}
else {
yield copyFile ( srcFile , destFile , force ) ;
}
}
// Change the mode for the newly created directory
yield ioUtil . chmod ( destDir , ( yield ioUtil . stat ( sourceDir ) ) . mode ) ;
} ) ;
}
// Buffered file copy
function copyFile ( srcFile , destFile , force ) {
return _ _awaiter ( this , void 0 , void 0 , function * ( ) {
if ( ( yield ioUtil . lstat ( srcFile ) ) . isSymbolicLink ( ) ) {
// unlink/re-link it
try {
yield ioUtil . lstat ( destFile ) ;
yield ioUtil . unlink ( destFile ) ;
}
catch ( e ) {
// Try to override file permission
if ( e . code === 'EPERM' ) {
yield ioUtil . chmod ( destFile , '0666' ) ;
yield ioUtil . unlink ( destFile ) ;
}
// other errors = it doesn't exist, no work to do
}
// Copy over symlink
const symlinkFull = yield ioUtil . readlink ( srcFile ) ;
yield ioUtil . symlink ( symlinkFull , destFile , ioUtil . IS _WINDOWS ? 'junction' : null ) ;
}
else if ( ! ( yield ioUtil . exists ( destFile ) ) || force ) {
yield ioUtil . copyFile ( srcFile , destFile ) ;
}
} ) ;
}
//# sourceMappingURL=io.js.map
/***/ } ) ,
/***/ 6705 :
/***/ ( ( module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2020-09-23 15:58:52 +09:00
function _interopDefault ( ex ) { return ( ex && ( typeof ex === 'object' ) && 'default' in ex ) ? ex [ 'default' ] : ex ; }
2024-09-29 18:20:46 +01:00
var Stream = _interopDefault ( _ _nccwpck _require _ _ ( 2203 ) ) ;
var http = _interopDefault ( _ _nccwpck _require _ _ ( 8611 ) ) ;
var Url = _interopDefault ( _ _nccwpck _require _ _ ( 7016 ) ) ;
var whatwgUrl = _interopDefault ( _ _nccwpck _require _ _ ( 5973 ) ) ;
var https = _interopDefault ( _ _nccwpck _require _ _ ( 5692 ) ) ;
var zlib = _interopDefault ( _ _nccwpck _require _ _ ( 3106 ) ) ;
2020-09-23 15:58:52 +09:00
// Based on https://github.com/tmpvar/jsdom/blob/aa85b2abf07766ff7bf5c1f6daafb3726f2f2db5/lib/jsdom/living/blob.js
// fix for "Readable" isn't a named export issue
const Readable = Stream . Readable ;
const BUFFER = Symbol ( 'buffer' ) ;
const TYPE = Symbol ( 'type' ) ;
class Blob {
constructor ( ) {
this [ TYPE ] = '' ;
const blobParts = arguments [ 0 ] ;
const options = arguments [ 1 ] ;
const buffers = [ ] ;
let size = 0 ;
if ( blobParts ) {
const a = blobParts ;
const length = Number ( a . length ) ;
for ( let i = 0 ; i < length ; i ++ ) {
const element = a [ i ] ;
let buffer ;
if ( element instanceof Buffer ) {
buffer = element ;
} else if ( ArrayBuffer . isView ( element ) ) {
buffer = Buffer . from ( element . buffer , element . byteOffset , element . byteLength ) ;
} else if ( element instanceof ArrayBuffer ) {
buffer = Buffer . from ( element ) ;
} else if ( element instanceof Blob ) {
buffer = element [ BUFFER ] ;
} else {
buffer = Buffer . from ( typeof element === 'string' ? element : String ( element ) ) ;
}
size += buffer . length ;
buffers . push ( buffer ) ;
}
}
this [ BUFFER ] = Buffer . concat ( buffers ) ;
let type = options && options . type !== undefined && String ( options . type ) . toLowerCase ( ) ;
if ( type && ! /[^\u0020-\u007E]/ . test ( type ) ) {
this [ TYPE ] = type ;
}
}
get size ( ) {
return this [ BUFFER ] . length ;
}
get type ( ) {
return this [ TYPE ] ;
}
text ( ) {
return Promise . resolve ( this [ BUFFER ] . toString ( ) ) ;
}
arrayBuffer ( ) {
const buf = this [ BUFFER ] ;
const ab = buf . buffer . slice ( buf . byteOffset , buf . byteOffset + buf . byteLength ) ;
return Promise . resolve ( ab ) ;
}
stream ( ) {
const readable = new Readable ( ) ;
readable . _read = function ( ) { } ;
readable . push ( this [ BUFFER ] ) ;
readable . push ( null ) ;
return readable ;
}
toString ( ) {
return '[object Blob]' ;
}
slice ( ) {
const size = this . size ;
const start = arguments [ 0 ] ;
const end = arguments [ 1 ] ;
let relativeStart , relativeEnd ;
if ( start === undefined ) {
relativeStart = 0 ;
} else if ( start < 0 ) {
relativeStart = Math . max ( size + start , 0 ) ;
} else {
relativeStart = Math . min ( start , size ) ;
}
if ( end === undefined ) {
relativeEnd = size ;
} else if ( end < 0 ) {
relativeEnd = Math . max ( size + end , 0 ) ;
} else {
relativeEnd = Math . min ( end , size ) ;
}
const span = Math . max ( relativeEnd - relativeStart , 0 ) ;
const buffer = this [ BUFFER ] ;
const slicedBuffer = buffer . slice ( relativeStart , relativeStart + span ) ;
const blob = new Blob ( [ ] , { type : arguments [ 2 ] } ) ;
blob [ BUFFER ] = slicedBuffer ;
return blob ;
}
}
Object . defineProperties ( Blob . prototype , {
size : { enumerable : true } ,
type : { enumerable : true } ,
slice : { enumerable : true }
} ) ;
Object . defineProperty ( Blob . prototype , Symbol . toStringTag , {
value : 'Blob' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
/ * *
* fetch - error . js
*
* FetchError interface for operational errors
* /
/ * *
* 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 ) ;
this . message = message ;
this . type = type ;
// when err.type is `system`, err.code contains system error code
if ( systemError ) {
this . code = this . errno = systemError . code ;
}
// hide custom error implementation details from end-users
Error . captureStackTrace ( this , this . constructor ) ;
}
FetchError . prototype = Object . create ( Error . prototype ) ;
FetchError . prototype . constructor = FetchError ;
FetchError . prototype . name = 'FetchError' ;
let convert ;
try {
2024-09-29 18:20:46 +01:00
convert = ( _ _nccwpck _require _ _ ( 2078 ) . convert ) ;
2020-09-23 15:58:52 +09:00
} catch ( e ) { }
const INTERNALS = Symbol ( 'Body internals' ) ;
// fix an issue where "PassThrough" isn't a named export for node <10
const PassThrough = Stream . PassThrough ;
/ * *
* Body mixin
*
* Ref : https : //fetch.spec.whatwg.org/#body
*
* @ param Stream body Readable stream
* @ param Object opts Response options
* @ return Void
* /
function Body ( body ) {
var _this = this ;
var _ref = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : { } ,
_ref$size = _ref . size ;
let size = _ref$size === undefined ? 0 : _ref$size ;
var _ref$timeout = _ref . timeout ;
let timeout = _ref$timeout === undefined ? 0 : _ref$timeout ;
if ( body == null ) {
// body is undefined or null
body = null ;
} else if ( isURLSearchParams ( body ) ) {
// body is a URLSearchParams
body = Buffer . from ( body . toString ( ) ) ;
} else if ( isBlob ( body ) ) ; else if ( Buffer . isBuffer ( body ) ) ; else if ( Object . prototype . toString . call ( body ) === '[object ArrayBuffer]' ) {
// body is ArrayBuffer
body = Buffer . from ( body ) ;
} else if ( ArrayBuffer . isView ( body ) ) {
// body is ArrayBufferView
body = Buffer . from ( body . buffer , body . byteOffset , body . byteLength ) ;
} else if ( body instanceof Stream ) ; else {
// none of the above
// coerce to string then buffer
body = Buffer . from ( String ( body ) ) ;
}
this [ INTERNALS ] = {
body ,
disturbed : false ,
error : null
} ;
this . size = size ;
this . timeout = timeout ;
if ( body instanceof Stream ) {
body . on ( 'error' , function ( err ) {
const error = err . name === 'AbortError' ? err : new FetchError ( ` Invalid response body while trying to fetch ${ _this . url } : ${ err . message } ` , 'system' , err ) ;
_this [ INTERNALS ] . error = error ;
} ) ;
}
}
Body . prototype = {
get body ( ) {
return this [ INTERNALS ] . body ;
} ,
get bodyUsed ( ) {
return this [ INTERNALS ] . disturbed ;
} ,
/ * *
* Decode response as ArrayBuffer
*
* @ return Promise
* /
arrayBuffer ( ) {
return consumeBody . call ( this ) . then ( function ( buf ) {
return buf . buffer . slice ( buf . byteOffset , buf . byteOffset + buf . byteLength ) ;
} ) ;
} ,
/ * *
* Return raw response as Blob
*
* @ return Promise
* /
blob ( ) {
let ct = this . headers && this . headers . get ( 'content-type' ) || '' ;
return consumeBody . call ( this ) . then ( function ( buf ) {
return Object . assign (
// Prevent copying
new Blob ( [ ] , {
type : ct . toLowerCase ( )
} ) , {
[ BUFFER ] : buf
} ) ;
} ) ;
} ,
/ * *
* Decode response as json
*
* @ return Promise
* /
json ( ) {
var _this2 = this ;
return consumeBody . call ( this ) . then ( function ( buffer ) {
try {
return JSON . parse ( buffer . toString ( ) ) ;
} catch ( err ) {
return Body . Promise . reject ( new FetchError ( ` invalid json response body at ${ _this2 . url } reason: ${ err . message } ` , 'invalid-json' ) ) ;
}
} ) ;
} ,
/ * *
* Decode response as text
*
* @ return Promise
* /
text ( ) {
return consumeBody . call ( this ) . then ( function ( buffer ) {
return buffer . toString ( ) ;
} ) ;
} ,
/ * *
* Decode response as buffer ( non - spec api )
*
* @ return Promise
* /
buffer ( ) {
return consumeBody . call ( this ) ;
} ,
/ * *
* Decode response as text , while automatically detecting the encoding and
* trying to decode to UTF - 8 ( non - spec api )
*
* @ return Promise
* /
textConverted ( ) {
var _this3 = this ;
return consumeBody . call ( this ) . then ( function ( buffer ) {
return convertBody ( buffer , _this3 . headers ) ;
} ) ;
}
} ;
// 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 }
} ) ;
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 ) ;
}
}
} ;
/ * *
* 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 ;
if ( this [ INTERNALS ] . disturbed ) {
return Body . Promise . reject ( new TypeError ( ` body used already for: ${ this . url } ` ) ) ;
}
this [ INTERNALS ] . disturbed = true ;
if ( this [ INTERNALS ] . error ) {
return Body . Promise . reject ( this [ INTERNALS ] . error ) ;
}
let body = this . body ;
// body is null
if ( body === null ) {
return Body . Promise . resolve ( Buffer . alloc ( 0 ) ) ;
}
// body is blob
if ( isBlob ( body ) ) {
body = body . stream ( ) ;
}
// body is buffer
if ( Buffer . isBuffer ( body ) ) {
return Body . Promise . resolve ( body ) ;
}
// istanbul ignore if: should never happen
if ( ! ( body instanceof Stream ) ) {
return Body . Promise . resolve ( Buffer . alloc ( 0 ) ) ;
}
// body is stream
// get ready to actually consume the body
let accum = [ ] ;
let accumBytes = 0 ;
let abort = false ;
return new Body . Promise ( function ( resolve , reject ) {
let resTimeout ;
// allow timeout on slow response body
if ( _this4 . timeout ) {
resTimeout = setTimeout ( function ( ) {
abort = true ;
reject ( new FetchError ( ` Response timeout while trying to fetch ${ _this4 . url } (over ${ _this4 . timeout } ms) ` , 'body-timeout' ) ) ;
} , _this4 . timeout ) ;
}
// 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 ) ) ;
}
} ) ;
body . on ( 'data' , function ( chunk ) {
if ( abort || chunk === null ) {
return ;
}
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 ;
}
accumBytes += chunk . length ;
accum . push ( chunk ) ;
} ) ;
body . on ( 'end' , function ( ) {
if ( abort ) {
return ;
}
clearTimeout ( resTimeout ) ;
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 ) ) ;
}
} ) ;
} ) ;
}
/ * *
* 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' ) ;
}
const ct = headers . get ( 'content-type' ) ;
let charset = 'utf-8' ;
let res , str ;
// header
if ( ct ) {
res = /charset=([^;]*)/i . exec ( ct ) ;
}
// no charset in content type, peek at response body for at most 1024 bytes
str = buffer . slice ( 0 , 1024 ) . toString ( ) ;
// html5
if ( ! res && str ) {
res = /<meta.+?charset=(['"])(.+?)\1/i . exec ( str ) ;
}
// 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
}
}
if ( res ) {
res = /charset=(.*)/i . exec ( res . pop ( ) ) ;
}
}
// xml
if ( ! res && str ) {
res = /<\?xml.+?encoding=(['"])(.+?)\1/i . exec ( str ) ;
}
// found charset
if ( res ) {
charset = res . pop ( ) ;
// prevent decode issues when sites use incorrect encoding
// ref: https://hsivonen.fi/encoding-menu/
if ( charset === 'gb2312' || charset === 'gbk' ) {
charset = 'gb18030' ;
}
}
// turn raw buffers into a single utf-8 buffer
return convert ( buffer , 'UTF-8' , charset ) . toString ( ) ;
}
/ * *
* 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 ;
}
// 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' ;
}
/ * *
* 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 ] ) ;
}
/ * *
* 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 ;
// don't allow cloning a used body
if ( instance . bodyUsed ) {
throw new Error ( 'cannot clone body after it is used' ) ;
}
// check that body is a stream and not form-data object
// note: we can't clone the form-data object without having it as a dependency
if ( body instanceof Stream && typeof body . getBoundary !== 'function' ) {
// tee instance body
p1 = new PassThrough ( ) ;
p2 = new PassThrough ( ) ;
body . pipe ( p1 ) ;
body . pipe ( p2 ) ;
// set instance body to teed body and return the other teed body
instance [ INTERNALS ] . body = p1 ;
body = p2 ;
}
return body ;
}
/ * *
* 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' ;
}
}
/ * *
* The Fetch Standard treats this as if "total bytes" is a property on the body .
* For us , we have to explicitly get it with a function .
*
* ref : https : //fetch.spec.whatwg.org/#concept-body-total-bytes
*
* @ param Body instance Instance of Body
* @ return Number ? Number of bytes , or null if not possible
* /
function getTotalBytes ( instance ) {
const body = instance . body ;
if ( body === null ) {
// body is null
return 0 ;
} else if ( isBlob ( body ) ) {
return body . size ;
} else if ( Buffer . isBuffer ( body ) ) {
// body is buffer
return body . length ;
} else if ( body && typeof body . getLengthSync === 'function' ) {
// detect form data input from form-data module
if ( body . _lengthRetrievers && body . _lengthRetrievers . length == 0 || // 1.x
body . hasKnownLength && body . hasKnownLength ( ) ) {
// 2.x
return body . getLengthSync ( ) ;
}
return null ;
} else {
// body is stream
return null ;
}
}
/ * *
* Write a Body to a Node . js WritableStream ( e . g . http . Request ) object .
*
* @ param Body instance Instance of Body
* @ return Void
* /
function writeToStream ( dest , instance ) {
const body = instance . body ;
if ( body === null ) {
// body is null
dest . end ( ) ;
} else if ( isBlob ( body ) ) {
body . stream ( ) . pipe ( dest ) ;
} else if ( Buffer . isBuffer ( body ) ) {
// body is buffer
dest . write ( body ) ;
dest . end ( ) ;
} else {
// body is stream
body . pipe ( dest ) ;
}
}
// expose Promise
Body . Promise = global . Promise ;
/ * *
* headers . js
*
* Headers class offers convenient helpers
* /
const invalidTokenRegex = /[^\^_`a-zA-Z\-0-9!#$%&'*+.|~]/ ;
const invalidHeaderCharRegex = /[^\t\x20-\x7e\x80-\xff]/ ;
function validateName ( name ) {
name = ` ${ name } ` ;
if ( invalidTokenRegex . test ( name ) || name === '' ) {
throw new TypeError ( ` ${ name } is not a legal HTTP header name ` ) ;
}
}
function validateValue ( value ) {
value = ` ${ value } ` ;
if ( invalidHeaderCharRegex . test ( value ) ) {
throw new TypeError ( ` ${ value } is not a legal HTTP header value ` ) ;
}
}
/ * *
* 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 ;
}
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 ;
this [ MAP ] = Object . create ( null ) ;
if ( init instanceof Headers ) {
const rawHeaders = init . raw ( ) ;
const headerNames = Object . keys ( rawHeaders ) ;
for ( const headerName of headerNames ) {
for ( const value of rawHeaders [ headerName ] ) {
this . append ( headerName , value ) ;
}
}
return ;
}
// 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' ) ;
}
// 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 ) ) ;
}
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' ) ;
}
}
/ * *
* 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 ;
}
return this [ MAP ] [ key ] . join ( ', ' ) ;
}
/ * *
* Iterate over all headers
*
* @ param Function callback Executed for each item with parameters ( value , name , thisArg )
* @ param Boolean thisArg ` this ` context for callback function
* @ return Void
* /
forEach ( callback ) {
let thisArg = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : undefined ;
let pairs = getHeaders ( this ) ;
let i = 0 ;
while ( i < pairs . length ) {
var _pairs$i = pairs [ i ] ;
const name = _pairs$i [ 0 ] ,
value = _pairs$i [ 1 ] ;
callback . call ( thisArg , value , name , this ) ;
pairs = getHeaders ( this ) ;
i ++ ;
}
}
/ * *
* 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 ] ;
}
/ * *
* 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 ] ;
}
}
/ * *
* Check for header name existence
*
* @ param String name Header name
* @ return Boolean
* /
has ( name ) {
name = ` ${ name } ` ;
validateName ( name ) ;
return find ( this [ MAP ] , name ) !== undefined ;
}
/ * *
* 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 ] ;
}
}
/ * *
* Return raw headers ( non - spec api )
*
* @ return Object
* /
raw ( ) {
return this [ MAP ] ;
}
/ * *
* Get an iterator on keys .
*
* @ return Iterator
* /
keys ( ) {
return createHeadersIterator ( this , 'key' ) ;
}
/ * *
* Get an iterator on values .
*
* @ return Iterator
* /
values ( ) {
return createHeadersIterator ( this , 'value' ) ;
}
/ * *
* Get an iterator on entries .
*
* This is the default iterator of the Headers object .
*
* @ return Iterator
* /
[ Symbol . iterator ] ( ) {
return createHeadersIterator ( this , 'key+value' ) ;
}
}
Headers . prototype . entries = Headers . prototype [ Symbol . iterator ] ;
Object . defineProperty ( Headers . prototype , Symbol . toStringTag , {
value : 'Headers' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
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 }
} ) ;
function getHeaders ( headers ) {
let kind = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : 'key+value' ;
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 ( ', ' ) ] ;
} ) ;
}
const INTERNAL = Symbol ( 'internal' ) ;
function createHeadersIterator ( target , kind ) {
const iterator = Object . create ( HeadersIteratorPrototype ) ;
iterator [ INTERNAL ] = {
target ,
kind ,
index : 0
} ;
return iterator ;
}
const HeadersIteratorPrototype = Object . setPrototypeOf ( {
next ( ) {
// istanbul ignore if
if ( ! this || Object . getPrototypeOf ( this ) !== HeadersIteratorPrototype ) {
throw new TypeError ( 'Value of `this` is not a HeadersIterator' ) ;
}
var _INTERNAL = this [ INTERNAL ] ;
const target = _INTERNAL . target ,
kind = _INTERNAL . kind ,
index = _INTERNAL . index ;
const values = getHeaders ( target , kind ) ;
const len = values . length ;
if ( index >= len ) {
return {
value : undefined ,
done : true
} ;
}
this [ INTERNAL ] . index = index + 1 ;
return {
value : values [ index ] ,
done : false
} ;
}
} , Object . getPrototypeOf ( Object . getPrototypeOf ( [ ] [ Symbol . iterator ] ( ) ) ) ) ;
Object . defineProperty ( HeadersIteratorPrototype , Symbol . toStringTag , {
value : 'HeadersIterator' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
/ * *
* Export the Headers object in a form that Node . js can consume .
*
* @ param Headers headers
* @ return Object
* /
function exportNodeCompatibleHeaders ( headers ) {
const obj = Object . assign ( { _ _proto _ _ : null } , headers [ MAP ] ) ;
// http.request() only supports string as Host header. This hack makes
// specifying custom Host header possible.
const hostHeaderKey = find ( headers [ MAP ] , 'Host' ) ;
if ( hostHeaderKey !== undefined ) {
obj [ hostHeaderKey ] = obj [ hostHeaderKey ] [ 0 ] ;
}
return obj ;
}
/ * *
* 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 ;
}
const INTERNALS$1 = Symbol ( 'Response internals' ) ;
// fix an issue where "STATUS_CODES" aren't a named export for node <10
const STATUS _CODES = http . STATUS _CODES ;
/ * *
* 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 ] : { } ;
Body . call ( this , body , opts ) ;
const status = opts . status || 200 ;
const headers = new Headers ( opts . headers ) ;
if ( body != null && ! headers . has ( 'Content-Type' ) ) {
const contentType = extractContentType ( body ) ;
if ( contentType ) {
headers . append ( 'Content-Type' , contentType ) ;
}
}
this [ INTERNALS$1 ] = {
url : opts . url ,
status ,
statusText : opts . statusText || STATUS _CODES [ status ] ,
headers ,
counter : opts . counter
} ;
}
get url ( ) {
return this [ INTERNALS$1 ] . url || '' ;
}
get status ( ) {
return this [ INTERNALS$1 ] . status ;
}
/ * *
* Convenience property representing if the request ended normally
* /
get ok ( ) {
return this [ INTERNALS$1 ] . status >= 200 && this [ INTERNALS$1 ] . status < 300 ;
}
get redirected ( ) {
return this [ INTERNALS$1 ] . counter > 0 ;
}
get statusText ( ) {
return this [ INTERNALS$1 ] . statusText ;
}
get headers ( ) {
return this [ INTERNALS$1 ] . headers ;
}
/ * *
* 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
} ) ;
}
}
Body . mixIn ( Response . prototype ) ;
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 }
} ) ;
Object . defineProperty ( Response . prototype , Symbol . toStringTag , {
value : 'Response' ,
writable : false ,
enumerable : false ,
configurable : true
} ) ;
const INTERNALS$2 = Symbol ( 'Request internals' ) ;
2022-01-27 17:19:41 +09:00
const URL = Url . URL || whatwgUrl . URL ;
2020-09-23 15:58:52 +09: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-01-27 17:19:41 +09:00
/ * *
* Wrapper around ` new URL ` to handle arbitrary URLs
*
* @ param { string } urlStr
* @ return { void }
* /
function parseURL ( urlStr ) {
/ *
Check whether the URL is absolute or not
Scheme : https : //tools.ietf.org/html/rfc3986#section-3.1
Absolute URL : https : //tools.ietf.org/html/rfc3986#section-4.3
* /
if ( /^[a-zA-Z][a-zA-Z\d+\-.]*:/ . exec ( urlStr ) ) {
urlStr = new URL ( urlStr ) . toString ( ) ;
}
// Fallback to old implementation for arbitrary URLs
return parse _url ( urlStr ) ;
}
2020-09-23 15:58:52 +09:00
const streamDestructionSupported = 'destroy' in Stream . Readable . prototype ;
/ * *
* 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' ;
}
function isAbortSignal ( signal ) {
const proto = signal && typeof signal === 'object' && Object . getPrototypeOf ( signal ) ;
return ! ! ( proto && proto . constructor . name === 'AbortSignal' ) ;
}
/ * *
* Request class
*
* @ param Mixed input Url or Request instance
* @ param Object init Custom options
* @ return Void
* /
class Request {
constructor ( input ) {
let init = arguments . length > 1 && arguments [ 1 ] !== undefined ? arguments [ 1 ] : { } ;
let parsedURL ;
// normalize input
if ( ! isRequest ( input ) ) {
if ( input && input . href ) {
// in order to support Node.js' Url objects; though WHATWG's URL objects
// will fall into this branch also (since their `toString()` will return
// `href` property anyway)
2022-01-27 17:19:41 +09:00
parsedURL = parseURL ( input . href ) ;
2020-09-23 15:58:52 +09:00
} else {
// coerce input to a string before attempting to parse
2022-01-27 17:19:41 +09:00
parsedURL = parseURL ( ` ${ input } ` ) ;
2020-09-23 15:58:52 +09:00
}
input = { } ;
} else {
2022-01-27 17:19:41 +09:00
parsedURL = parseURL ( input . url ) ;
2020-09-23 15:58:52 +09:00
}
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 ) ;
}
}
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 ) ;
}
// HTTP-network fetch step 4.2
// chunked encoding is handled by Node.js
return Object . assign ( { } , parsedURL , {
method : request . method ,
headers : exportNodeCompatibleHeaders ( headers ) ,
agent
} ) ;
}
/ * *
* abort - error . js
*
* AbortError interface for cancelled requests
* /
/ * *
* Create AbortError instance
*
* @ param String message Error message for human
* @ return AbortError
* /
function AbortError ( message ) {
Error . call ( this , message ) ;
this . type = 'aborted' ;
this . message = message ;
// hide custom error implementation details from end-users
Error . captureStackTrace ( this , this . constructor ) ;
}
AbortError . prototype = Object . create ( Error . prototype ) ;
AbortError . prototype . constructor = AbortError ;
AbortError . prototype . name = 'AbortError' ;
2022-01-27 17:19:41 +09:00
const URL$1 = Url . URL || whatwgUrl . URL ;
2020-09-23 15:58:52 +09:00
// fix an issue where "PassThrough", "resolve" aren't a named export for node <10
const PassThrough$1 = Stream . PassThrough ;
2022-01-27 17:19:41 +09:00
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 ) ;
} ;
2020-09-23 15:58:52 +09:00
2023-01-16 07:55:16 +09:00
/ * *
* isSameProtocol reports whether the two provided URLs use the same protocol .
*
* Both domains must already be in canonical form .
* @ param { string | URL } original
* @ param { string | URL } destination
* /
const isSameProtocol = function isSameProtocol ( destination , original ) {
const orig = new URL$1 ( original ) . protocol ;
const dest = new URL$1 ( destination ) . protocol ;
return orig === dest ;
} ;
2020-09-23 15:58:52 +09:00
/ * *
* Fetch function
*
* @ param Mixed url Absolute url or Request instance
* @ param Object opts Fetch options
* @ return Promise
* /
function fetch ( url , opts ) {
// allow custom promise
if ( ! fetch . Promise ) {
throw new Error ( 'native promise missing, set fetch.Promise to your favorite alternative' ) ;
}
Body . Promise = fetch . Promise ;
// 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 ) ;
const send = ( options . protocol === 'https:' ? https : http ) . request ;
const signal = request . signal ;
let response = null ;
const abort = function abort ( ) {
let error = new AbortError ( 'The user aborted a request.' ) ;
reject ( error ) ;
if ( request . body && request . body instanceof Stream . Readable ) {
2023-01-16 07:55:16 +09:00
destroyStream ( request . body , error ) ;
2020-09-23 15:58:52 +09:00
}
if ( ! response || ! response . body ) return ;
response . body . emit ( 'error' , error ) ;
} ;
if ( signal && signal . aborted ) {
abort ( ) ;
return ;
}
const abortAndFinalize = function abortAndFinalize ( ) {
abort ( ) ;
finalize ( ) ;
} ;
// send request
const req = send ( options ) ;
let reqTimeout ;
if ( signal ) {
signal . addEventListener ( 'abort' , abortAndFinalize ) ;
}
function finalize ( ) {
req . abort ( ) ;
if ( signal ) signal . removeEventListener ( 'abort' , abortAndFinalize ) ;
clearTimeout ( reqTimeout ) ;
}
if ( request . timeout ) {
req . once ( 'socket' , function ( socket ) {
reqTimeout = setTimeout ( function ( ) {
reject ( new FetchError ( ` network timeout at: ${ request . url } ` , 'request-timeout' ) ) ;
finalize ( ) ;
} , request . timeout ) ;
} ) ;
}
req . on ( 'error' , function ( err ) {
reject ( new FetchError ( ` request to ${ request . url } failed, reason: ${ err . message } ` , 'system' , err ) ) ;
2023-01-16 07:55:16 +09:00
if ( response && response . body ) {
destroyStream ( response . body , err ) ;
}
2020-09-23 15:58:52 +09:00
finalize ( ) ;
} ) ;
2023-01-16 07:55:16 +09:00
fixResponseChunkedTransferBadEnding ( req , function ( err ) {
if ( signal && signal . aborted ) {
return ;
}
2023-02-05 23:23:33 +09:00
if ( response && response . body ) {
destroyStream ( response . body , err ) ;
}
2023-01-16 07:55:16 +09:00
} ) ;
/* c8 ignore next 18 */
if ( parseInt ( process . version . substring ( 1 ) ) < 14 ) {
// Before Node.js 14, pipeline() does not fully support async iterators and does not always
// properly handle when the socket close/end events are out of order.
req . on ( 'socket' , function ( s ) {
s . addListener ( 'close' , function ( hadError ) {
// if a data listener is still present we didn't end cleanly
const hasDataListener = s . listenerCount ( 'data' ) > 0 ;
// if end happened before close but the socket didn't emit an error, do it now
if ( response && hasDataListener && ! hadError && ! ( signal && signal . aborted ) ) {
const err = new Error ( 'Premature close' ) ;
err . code = 'ERR_STREAM_PREMATURE_CLOSE' ;
response . body . emit ( 'error' , err ) ;
}
} ) ;
} ) ;
}
2020-09-23 15:58:52 +09:00
req . on ( 'response' , function ( res ) {
clearTimeout ( reqTimeout ) ;
const headers = createHeadersLenient ( res . headers ) ;
// HTTP fetch step 5
if ( fetch . isRedirect ( res . statusCode ) ) {
// HTTP fetch step 5.2
const location = headers . get ( 'Location' ) ;
// HTTP fetch step 5.3
2022-01-27 17:19:41 +09:00
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 ;
}
}
2020-09-23 15:58:52 +09:00
// HTTP fetch step 5.5
switch ( request . redirect ) {
case 'error' :
reject ( new FetchError ( ` uri requested responds with a redirect, redirect mode is set to error: ${ request . url } ` , 'no-redirect' ) ) ;
finalize ( ) ;
return ;
case 'manual' :
// node-fetch-specific step: make manual redirect a bit easier to use by setting the Location header value to the resolved URL.
if ( locationURL !== null ) {
// handle corrupted header
try {
headers . set ( 'Location' , locationURL ) ;
} catch ( err ) {
// istanbul ignore next: nodejs server prevent invalid response headers, we can't test this through normal request
reject ( err ) ;
}
}
break ;
case 'follow' :
// HTTP-redirect fetch step 2
if ( locationURL === null ) {
break ;
}
// HTTP-redirect fetch step 5
if ( request . counter >= request . follow ) {
reject ( new FetchError ( ` maximum redirect reached at: ${ request . url } ` , 'max-redirect' ) ) ;
finalize ( ) ;
return ;
}
// HTTP-redirect fetch step 6 (counter increment)
// Create a new Request object.
const requestOpts = {
headers : new Headers ( request . headers ) ,
follow : request . follow ,
counter : request . counter + 1 ,
agent : request . agent ,
compress : request . compress ,
method : request . method ,
body : request . body ,
signal : request . signal ,
timeout : request . timeout ,
size : request . size
} ;
2023-01-16 07:55:16 +09:00
if ( ! isDomainOrSubdomain ( request . url , locationURL ) || ! isSameProtocol ( request . url , locationURL ) ) {
2022-01-27 17:19:41 +09:00
for ( const name of [ 'authorization' , 'www-authenticate' , 'cookie' , 'cookie2' ] ) {
requestOpts . headers . delete ( name ) ;
}
}
2020-09-23 15:58:52 +09: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 ;
}
// HTTP-redirect fetch step 11
if ( res . statusCode === 303 || ( res . statusCode === 301 || res . statusCode === 302 ) && request . method === 'POST' ) {
requestOpts . method = 'GET' ;
requestOpts . body = undefined ;
requestOpts . headers . delete ( 'content-length' ) ;
}
// HTTP-redirect fetch step 15
resolve ( fetch ( new Request ( locationURL , requestOpts ) ) ) ;
finalize ( ) ;
return ;
}
}
// prepare response
res . once ( 'end' , function ( ) {
if ( signal ) signal . removeEventListener ( 'abort' , abortAndFinalize ) ;
} ) ;
let body = res . pipe ( new PassThrough$1 ( ) ) ;
const response _options = {
url : request . url ,
status : res . statusCode ,
statusText : res . statusMessage ,
headers : headers ,
size : request . size ,
timeout : request . timeout ,
counter : request . counter
} ;
// HTTP-network fetch step 12.1.1.3
const codings = headers . get ( 'Content-Encoding' ) ;
// HTTP-network fetch step 12.1.1.4: handle content codings
// in following scenarios we ignore compression support
// 1. compression support is disabled
// 2. HEAD request
// 3. no Content-Encoding header
// 4. no content response (204)
// 5. content not modified response (304)
if ( ! request . compress || request . method === 'HEAD' || codings === null || res . statusCode === 204 || res . statusCode === 304 ) {
response = new Response ( body , response _options ) ;
resolve ( response ) ;
return ;
}
// 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 ) ;
} ) ;
2023-01-16 07:55:16 +09:00
raw . on ( 'end' , function ( ) {
// some old IIS servers return zero-length OK deflate responses, so 'data' is never emitted.
if ( ! response ) {
response = new Response ( body , response _options ) ;
resolve ( response ) ;
}
} ) ;
2020-09-23 15:58:52 +09:00
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 ) ;
} ) ;
writeToStream ( req , request ) ;
} ) ;
}
2023-01-16 07:55:16 +09:00
function fixResponseChunkedTransferBadEnding ( request , errorCallback ) {
let socket ;
request . on ( 'socket' , function ( s ) {
socket = s ;
} ) ;
request . on ( 'response' , function ( response ) {
const headers = response . headers ;
if ( headers [ 'transfer-encoding' ] === 'chunked' && ! headers [ 'content-length' ] ) {
response . once ( 'close' , function ( hadError ) {
2023-07-04 09:44:17 +09:00
// tests for socket presence, as in some situations the
// the 'socket' event is not triggered for the request
// (happens in deno), avoids `TypeError`
2023-01-16 07:55:16 +09:00
// if a data listener is still present we didn't end cleanly
2023-07-04 09:44:17 +09:00
const hasDataListener = socket && socket . listenerCount ( 'data' ) > 0 ;
2023-01-16 07:55:16 +09:00
if ( hasDataListener && ! hadError ) {
const err = new Error ( 'Premature close' ) ;
err . code = 'ERR_STREAM_PREMATURE_CLOSE' ;
errorCallback ( err ) ;
}
} ) ;
}
} ) ;
}
function destroyStream ( stream , err ) {
if ( stream . destroy ) {
stream . destroy ( err ) ;
} else {
// node < 8
stream . emit ( 'error' , err ) ;
stream . end ( ) ;
}
}
2020-09-23 15:58:52 +09: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 ;
} ;
// expose Promise
fetch . Promise = global . Promise ;
module . exports = exports = fetch ;
Object . defineProperty ( exports , "__esModule" , ( { value : true } ) ) ;
2021-12-02 01:33:50 +00:00
exports [ "default" ] = exports ;
2020-09-23 15:58:52 +09:00
exports . Headers = Headers ;
exports . Request = Request ;
exports . Response = Response ;
exports . FetchError = FetchError ;
2023-09-04 18:49:58 +09:00
exports . AbortError = AbortError ;
2020-09-23 15:58:52 +09:00
2022-01-27 17:19:41 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 1733 :
2022-01-27 17:19:41 +09:00
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
2024-09-29 18:20:46 +01:00
var punycode = _ _nccwpck _require _ _ ( 4876 ) ;
var mappingTable = _ _nccwpck _require _ _ ( 7963 ) ;
2022-01-27 17:19:41 +09:00
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 ;
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 1364 :
2022-01-27 17:19:41 +09:00
/***/ ( ( 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 ) ;
return function ( V , opts ) {
if ( ! opts ) opts = { } ;
let x = + V ;
if ( opts . enforceRange ) {
if ( ! Number . isFinite ( x ) ) {
throw new TypeError ( "Argument is not a finite number" ) ;
}
x = sign ( x ) * Math . floor ( Math . abs ( x ) ) ;
if ( x < lowerBound || x > upperBound ) {
throw new TypeError ( "Argument is not in byte range" ) ;
}
return x ;
}
if ( ! isNaN ( x ) && opts . clamp ) {
x = evenRound ( x ) ;
if ( x < lowerBound ) x = lowerBound ;
if ( x > upperBound ) x = upperBound ;
return x ;
}
if ( ! Number . isFinite ( x ) || x === 0 ) {
return 0 ;
}
x = sign ( x ) * Math . floor ( Math . abs ( x ) ) ;
x = x % moduloVal ;
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 ;
}
}
return x ;
}
}
conversions [ "void" ] = function ( ) {
return undefined ;
} ;
conversions [ "boolean" ] = function ( val ) {
return ! ! val ;
} ;
conversions [ "byte" ] = createNumberConversion ( 8 , { unsigned : false } ) ;
conversions [ "octet" ] = createNumberConversion ( 8 , { unsigned : true } ) ;
conversions [ "short" ] = createNumberConversion ( 16 , { unsigned : false } ) ;
conversions [ "unsigned short" ] = createNumberConversion ( 16 , { unsigned : true } ) ;
conversions [ "long" ] = createNumberConversion ( 32 , { unsigned : false } ) ;
conversions [ "unsigned long" ] = createNumberConversion ( 32 , { unsigned : true } ) ;
conversions [ "long long" ] = createNumberConversion ( 32 , { unsigned : false , moduloBitLength : 64 } ) ;
conversions [ "unsigned long long" ] = createNumberConversion ( 32 , { unsigned : true , moduloBitLength : 64 } ) ;
conversions [ "double" ] = function ( V ) {
const x = + V ;
if ( ! Number . isFinite ( x ) ) {
throw new TypeError ( "Argument is not a finite floating-point value" ) ;
}
return x ;
} ;
conversions [ "unrestricted double" ] = function ( V ) {
const x = + V ;
if ( isNaN ( x ) ) {
throw new TypeError ( "Argument is NaN" ) ;
}
return x ;
} ;
// not quite valid, but good enough for JS
conversions [ "float" ] = conversions [ "double" ] ;
conversions [ "unrestricted float" ] = conversions [ "unrestricted double" ] ;
conversions [ "DOMString" ] = function ( V , opts ) {
if ( ! opts ) opts = { } ;
if ( opts . treatNullAsEmptyString && V === null ) {
return "" ;
}
return String ( V ) ;
} ;
conversions [ "ByteString" ] = function ( V , opts ) {
const x = String ( V ) ;
let c = undefined ;
for ( let i = 0 ; ( c = x . codePointAt ( i ) ) !== undefined ; ++ i ) {
if ( c > 255 ) {
throw new TypeError ( "Argument is not a valid bytestring" ) ;
}
}
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 ) ) ;
}
}
}
}
return U . join ( '' ) ;
} ;
conversions [ "Date" ] = function ( V , opts ) {
if ( ! ( V instanceof Date ) ) {
throw new TypeError ( "Argument is not a Date object" ) ;
}
if ( isNaN ( V ) ) {
return undefined ;
}
return V ;
} ;
conversions [ "RegExp" ] = function ( V , opts ) {
if ( ! ( V instanceof RegExp ) ) {
V = new RegExp ( V ) ;
}
return V ;
} ;
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 291 :
2022-01-27 17:19:41 +09:00
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
2024-09-29 18:20:46 +01:00
const usm = _ _nccwpck _require _ _ ( 7704 ) ;
2022-01-27 17:19:41 +09:00
exports . implementation = class URLImpl {
constructor ( constructorArgs ) {
const url = constructorArgs [ 0 ] ;
const base = constructorArgs [ 1 ] ;
let parsedBase = null ;
if ( base !== undefined ) {
parsedBase = usm . basicURLParse ( base ) ;
if ( parsedBase === "failure" ) {
throw new TypeError ( "Invalid base URL" ) ;
}
}
const parsedURL = usm . basicURLParse ( url , { baseURL : parsedBase } ) ;
if ( parsedURL === "failure" ) {
throw new TypeError ( "Invalid URL" ) ;
}
this . _url = parsedURL ;
// TODO: query stuff
}
get href ( ) {
return usm . serializeURL ( this . _url ) ;
}
set href ( v ) {
const parsedURL = usm . basicURLParse ( v ) ;
if ( parsedURL === "failure" ) {
throw new TypeError ( "Invalid URL" ) ;
}
this . _url = parsedURL ;
}
get origin ( ) {
return usm . serializeURLOrigin ( this . _url ) ;
}
get protocol ( ) {
return this . _url . scheme + ":" ;
}
set protocol ( v ) {
usm . basicURLParse ( v + ":" , { url : this . _url , stateOverride : "scheme start" } ) ;
}
get username ( ) {
return this . _url . username ;
}
set username ( v ) {
if ( usm . cannotHaveAUsernamePasswordPort ( this . _url ) ) {
return ;
}
usm . setTheUsername ( this . _url , v ) ;
}
get password ( ) {
return this . _url . password ;
}
set password ( v ) {
if ( usm . cannotHaveAUsernamePasswordPort ( this . _url ) ) {
return ;
}
usm . setThePassword ( this . _url , v ) ;
}
get host ( ) {
const url = this . _url ;
if ( url . host === null ) {
return "" ;
}
if ( url . port === null ) {
return usm . serializeHost ( url . host ) ;
}
return usm . serializeHost ( url . host ) + ":" + usm . serializeInteger ( url . port ) ;
}
set host ( v ) {
if ( this . _url . cannotBeABaseURL ) {
return ;
}
usm . basicURLParse ( v , { url : this . _url , stateOverride : "host" } ) ;
}
get hostname ( ) {
if ( this . _url . host === null ) {
return "" ;
}
return usm . serializeHost ( this . _url . host ) ;
}
set hostname ( v ) {
if ( this . _url . cannotBeABaseURL ) {
return ;
}
usm . basicURLParse ( v , { url : this . _url , stateOverride : "hostname" } ) ;
}
get port ( ) {
if ( this . _url . port === null ) {
return "" ;
}
return usm . serializeInteger ( this . _url . port ) ;
}
set port ( v ) {
if ( usm . cannotHaveAUsernamePasswordPort ( this . _url ) ) {
return ;
}
if ( v === "" ) {
this . _url . port = null ;
} else {
usm . basicURLParse ( v , { url : this . _url , stateOverride : "port" } ) ;
}
}
get pathname ( ) {
if ( this . _url . cannotBeABaseURL ) {
return this . _url . path [ 0 ] ;
}
if ( this . _url . path . length === 0 ) {
return "" ;
}
return "/" + this . _url . path . join ( "/" ) ;
}
set pathname ( v ) {
if ( this . _url . cannotBeABaseURL ) {
return ;
}
this . _url . path = [ ] ;
usm . basicURLParse ( v , { url : this . _url , stateOverride : "path start" } ) ;
}
get search ( ) {
if ( this . _url . query === null || this . _url . query === "" ) {
return "" ;
}
return "?" + this . _url . query ;
}
set search ( v ) {
// TODO: query stuff
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 "" ;
}
return "#" + this . _url . fragment ;
}
set hash ( v ) {
if ( v === "" ) {
this . _url . fragment = null ;
return ;
}
const input = v [ 0 ] === "#" ? v . substring ( 1 ) : v ;
this . _url . fragment = "" ;
usm . basicURLParse ( input , { url : this . _url , stateOverride : "fragment" } ) ;
}
toJSON ( ) {
return this . href ;
}
} ;
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 1860 :
2022-01-27 17:19:41 +09:00
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
2024-09-29 18:20:46 +01:00
const conversions = _ _nccwpck _require _ _ ( 1364 ) ;
const utils = _ _nccwpck _require _ _ ( 6880 ) ;
const Impl = _ _nccwpck _require _ _ ( 291 ) ;
2022-01-27 17:19:41 +09:00
const impl = utils . implSymbol ;
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 ] ) ;
}
module . exports . setup ( this , args ) ;
}
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
} ) ;
URL . prototype . toString = function ( ) {
if ( ! this || ! module . exports . is ( this ) ) {
throw new TypeError ( "Illegal invocation" ) ;
}
return this . href ;
} ;
Object . defineProperty ( URL . prototype , "origin" , {
get ( ) {
return this [ impl ] . origin ;
} ,
enumerable : true ,
configurable : true
} ) ;
Object . defineProperty ( URL . prototype , "protocol" , {
get ( ) {
return this [ impl ] . protocol ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . protocol = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
Object . defineProperty ( URL . prototype , "username" , {
get ( ) {
return this [ impl ] . username ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . username = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
Object . defineProperty ( URL . prototype , "password" , {
get ( ) {
return this [ impl ] . password ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . password = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
Object . defineProperty ( URL . prototype , "host" , {
get ( ) {
return this [ impl ] . host ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . host = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
Object . defineProperty ( URL . prototype , "hostname" , {
get ( ) {
return this [ impl ] . hostname ;
} ,
set ( V ) {
V = conversions [ "USVString" ] ( V ) ;
this [ impl ] . hostname = V ;
} ,
enumerable : true ,
configurable : true
} ) ;
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 }
}
} ;
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 5973 :
2022-01-27 17:19:41 +09:00
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
2024-09-29 18:20:46 +01:00
exports . URL = _ _nccwpck _require _ _ ( 1860 ) [ "interface" ] ;
exports . serializeURL = _ _nccwpck _require _ _ ( 7704 ) . serializeURL ;
exports . serializeURLOrigin = _ _nccwpck _require _ _ ( 7704 ) . serializeURLOrigin ;
exports . basicURLParse = _ _nccwpck _require _ _ ( 7704 ) . basicURLParse ;
exports . setTheUsername = _ _nccwpck _require _ _ ( 7704 ) . setTheUsername ;
exports . setThePassword = _ _nccwpck _require _ _ ( 7704 ) . setThePassword ;
exports . serializeHost = _ _nccwpck _require _ _ ( 7704 ) . serializeHost ;
exports . serializeInteger = _ _nccwpck _require _ _ ( 7704 ) . serializeInteger ;
exports . parseURL = _ _nccwpck _require _ _ ( 7704 ) . parseURL ;
2022-01-27 17:19:41 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 7704 :
2022-01-27 17:19:41 +09:00
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
2024-09-29 18:20:46 +01:00
const punycode = _ _nccwpck _require _ _ ( 4876 ) ;
const tr46 = _ _nccwpck _require _ _ ( 1733 ) ;
2022-01-27 17:19:41 +09:00
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" :
2024-10-08 20:21:42 +01:00
// spec says "exercise to the reader", chrome says "file://"
return "file://" ;
default :
// serializing an opaque origin returns "null"
return "null" ;
}
} ;
module . exports . basicURLParse = function ( input , options ) {
if ( options === undefined ) {
options = { } ;
}
const usm = new URLStateMachine ( input , options . baseURL , options . encodingOverride , options . url , options . stateOverride ) ;
if ( usm . failure ) {
return "failure" ;
}
return usm . url ;
} ;
module . exports . setTheUsername = function ( url , username ) {
url . username = "" ;
const decoded = punycode . ucs2 . decode ( username ) ;
for ( let i = 0 ; i < decoded . length ; ++ i ) {
url . username += percentEncodeChar ( decoded [ i ] , isUserinfoPercentEncode ) ;
}
} ;
module . exports . setThePassword = function ( url , password ) {
url . password = "" ;
const decoded = punycode . ucs2 . decode ( password ) ;
for ( let i = 0 ; i < decoded . length ; ++ i ) {
url . password += percentEncodeChar ( decoded [ i ] , isUserinfoPercentEncode ) ;
}
} ;
module . exports . serializeHost = serializeHost ;
module . exports . cannotHaveAUsernamePasswordPort = cannotHaveAUsernamePasswordPort ;
module . exports . serializeInteger = function ( integer ) {
return String ( integer ) ;
} ;
module . exports . parseURL = function ( input , options ) {
if ( options === undefined ) {
options = { } ;
}
// We don't handle blobs, so this just delegates:
return module . exports . basicURLParse ( input , { baseURL : options . baseURL , encodingOverride : options . encodingOverride } ) ;
} ;
2022-08-19 02:59:02 +00:00
/***/ } ) ,
2024-10-08 20:21:42 +01:00
/***/ 6880 :
/***/ ( ( module ) => {
2022-08-19 02:59:02 +00:00
"use strict" ;
2024-10-08 20:21:42 +01:00
module . exports . mixin = function mixin ( target , source ) {
const keys = Object . getOwnPropertyNames ( source ) ;
for ( let i = 0 ; i < keys . length ; ++ i ) {
Object . defineProperty ( target , keys [ i ] , Object . getOwnPropertyDescriptor ( source , keys [ i ] ) ) ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
} ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
module . exports . wrapperSymbol = Symbol ( "wrapper" ) ;
module . exports . implSymbol = Symbol ( "impl" ) ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
module . exports . wrapperForImpl = function ( impl ) {
return impl [ module . exports . wrapperSymbol ] ;
} ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
module . exports . implForWrapper = function ( wrapper ) {
return wrapper [ module . exports . implSymbol ] ;
} ;
2022-08-19 02:59:02 +00:00
/***/ } ) ,
2024-10-08 20:21:42 +01:00
/***/ 770 :
/***/ ( ( module , _ _unused _webpack _exports , _ _nccwpck _require _ _ ) => {
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
module . exports = _ _nccwpck _require _ _ ( 218 ) ;
2022-08-19 02:59:02 +00:00
/***/ } ) ,
2024-10-08 20:21:42 +01:00
/***/ 218 :
2022-08-19 02:59:02 +00:00
/***/ ( ( _ _unused _webpack _module , exports , _ _nccwpck _require _ _ ) => {
"use strict" ;
2024-10-08 20:21:42 +01:00
var net = _ _nccwpck _require _ _ ( 9278 ) ;
var tls = _ _nccwpck _require _ _ ( 4756 ) ;
var http = _ _nccwpck _require _ _ ( 8611 ) ;
var https = _ _nccwpck _require _ _ ( 5692 ) ;
var events = _ _nccwpck _require _ _ ( 4434 ) ;
var assert = _ _nccwpck _require _ _ ( 2613 ) ;
var util = _ _nccwpck _require _ _ ( 9023 ) ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
exports . httpOverHttp = httpOverHttp ;
exports . httpsOverHttp = httpsOverHttp ;
exports . httpOverHttps = httpOverHttps ;
exports . httpsOverHttps = httpsOverHttps ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
function httpOverHttp ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = http . request ;
return agent ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
function httpsOverHttp ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = http . request ;
agent . createSocket = createSecureSocket ;
agent . defaultPort = 443 ;
return agent ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
function httpOverHttps ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = https . request ;
return agent ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
function httpsOverHttps ( options ) {
var agent = new TunnelingAgent ( options ) ;
agent . request = https . request ;
agent . createSocket = createSecureSocket ;
agent . defaultPort = 443 ;
return agent ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
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 = [ ] ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
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 ;
}
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
socket . destroy ( ) ;
self . removeSocket ( socket ) ;
} ) ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
util . inherits ( TunnelingAgent , events . EventEmitter ) ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
TunnelingAgent . prototype . addRequest = function addRequest ( req , host , port , localAddress ) {
var self = this ;
var options = mergeOptions ( { request : req } , self . options , toOptions ( host , port , localAddress ) ) ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
if ( self . sockets . length >= this . maxSockets ) {
// We are over limit so we'll add it to the queue.
self . requests . push ( options ) ;
return ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
// 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 ) ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
function onFree ( ) {
self . emit ( 'free' , socket , options ) ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
function onCloseOrRemove ( err ) {
self . removeSocket ( socket ) ;
socket . removeListener ( 'free' , onFree ) ;
socket . removeListener ( 'close' , onCloseOrRemove ) ;
socket . removeListener ( 'agentRemove' , onCloseOrRemove ) ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
} ) ;
} ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
TunnelingAgent . prototype . createSocket = function createSocket ( options , cb ) {
var self = this ;
var placeholder = { } ;
self . sockets . push ( placeholder ) ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
var connectOptions = mergeOptions ( { } , self . proxyOptions , {
method : 'CONNECT' ,
path : options . host + ':' + options . port ,
agent : false ,
headers : {
host : options . host + ':' + options . port
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
} ) ;
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' ) ;
}
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
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 ( ) ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
function onResponse ( res ) {
// Very hacky. This is necessary to avoid http-parser leaks.
res . upgrade = true ;
}
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
function onUpgrade ( res , socket , head ) {
// Hacky.
process . nextTick ( function ( ) {
onConnect ( res , socket , head ) ;
} ) ;
}
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
function onConnect ( res , socket , head ) {
connectReq . removeAllListeners ( ) ;
socket . removeAllListeners ( ) ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
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 ) ;
}
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
function onError ( cause ) {
connectReq . removeAllListeners ( ) ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
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 ) ;
}
} ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
TunnelingAgent . prototype . removeSocket = function removeSocket ( socket ) {
var pos = this . sockets . indexOf ( socket )
if ( pos === - 1 ) {
return ;
}
this . sockets . splice ( pos , 1 ) ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
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 ) ;
} ) ;
}
} ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
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
} ) ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
// 0 is dummy port for v0.6
var secureSocket = tls . connect ( 0 , tlsOptions ) ;
self . sockets [ self . sockets . indexOf ( socket ) ] = secureSocket ;
cb ( secureSocket ) ;
} ) ;
}
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
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
}
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
function mergeOptions ( target ) {
for ( var i = 1 , len = arguments . length ; i < len ; ++ i ) {
var overrides = arguments [ i ] ;
if ( typeof overrides === 'object' ) {
var keys = Object . keys ( overrides ) ;
for ( var j = 0 , keyLen = keys . length ; j < keyLen ; ++ j ) {
var k = keys [ j ] ;
if ( overrides [ k ] !== undefined ) {
target [ k ] = overrides [ k ] ;
}
}
2022-08-19 02:59:02 +00:00
}
}
2024-10-08 20:21:42 +01:00
return target ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
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 ( ) { } ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
exports . debug = debug ; // for test
2022-08-19 02:59:02 +00:00
/***/ } ) ,
2024-10-08 20:21:42 +01:00
/***/ 3534 :
/***/ ( ( module ) => {
2022-08-19 02:59:02 +00:00
"use strict" ;
2024-10-08 20:21:42 +01:00
function charAt ( string , index ) {
var first = string . charCodeAt ( index ) ;
var second ;
if ( first >= 55296 && first <= 56319 && string . length > index + 1 ) {
second = string . charCodeAt ( index + 1 ) ;
if ( second >= 56320 && second <= 57343 ) {
return string . substring ( index , index + 2 ) ;
}
}
return string [ index ] ;
}
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
function slice ( string , start , end ) {
var accumulator = "" ;
var character ;
var stringIndex = 0 ;
var unicodeIndex = 0 ;
var length = string . length ;
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
while ( stringIndex < length ) {
character = charAt ( string , stringIndex ) ;
if ( unicodeIndex >= start && unicodeIndex < end ) {
accumulator += character ;
}
stringIndex += character . length ;
unicodeIndex += 1 ;
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
return accumulator ;
}
2022-08-19 02:59:02 +00:00
2024-10-08 20:21:42 +01:00
function toNumber ( value , fallback ) {
if ( value === undefined ) {
return fallback ;
} else {
return Number ( value ) ;
}
2022-08-19 02:59:02 +00:00
}
2024-10-08 20:21:42 +01:00
module . exports = function ( string , start , end ) {
var realStart = toNumber ( start , 0 ) ;
var realEnd = toNumber ( end , string . length ) ;
if ( realEnd == realStart ) {
return "" ;
} else if ( realEnd > realStart ) {
return slice ( string , realStart , realEnd ) ;
} else {
return slice ( string , realEnd , realStart ) ;
}
} ;
2022-08-19 02:59:02 +00:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 2078 :
2020-09-23 15:58:52 +09:00
/***/ ( ( module ) => {
module . exports = eval ( "require" ) ( "encoding" ) ;
2021-10-07 01:39:26 +00:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 2613 :
2021-10-07 01:39:26 +00:00
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "assert" ) ;
/***/ } ) ,
2024-10-08 20:21:42 +01:00
/***/ 5317 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "child_process" ) ;
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 6982 :
2022-08-19 02:59:02 +00:00
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "crypto" ) ;
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 4434 :
2021-10-07 01:39:26 +00:00
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "events" ) ;
2020-09-23 15:58:52 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 9896 :
2020-09-23 15:58:52 +09:00
/***/ ( ( module ) => {
"use strict" ;
2021-07-22 01:59:05 +00:00
module . exports = require ( "fs" ) ;
2020-09-23 15:58:52 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 8611 :
2020-09-23 15:58:52 +09:00
/***/ ( ( module ) => {
"use strict" ;
2021-07-22 01:59:05 +00:00
module . exports = require ( "http" ) ;
2020-09-23 15:58:52 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 5692 :
2020-09-23 15:58:52 +09:00
/***/ ( ( module ) => {
"use strict" ;
2021-07-22 01:59:05 +00:00
module . exports = require ( "https" ) ;
2020-09-23 15:58:52 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 9278 :
2021-10-07 01:39:26 +00:00
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "net" ) ;
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 857 :
2020-09-23 15:58:52 +09:00
/***/ ( ( module ) => {
"use strict" ;
2021-07-22 01:59:05 +00:00
module . exports = require ( "os" ) ;
2020-09-23 15:58:52 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 6928 :
2020-09-23 15:58:52 +09:00
/***/ ( ( module ) => {
"use strict" ;
2021-07-22 01:59:05 +00:00
module . exports = require ( "path" ) ;
2020-09-23 15:58:52 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 4876 :
2022-01-27 17:19:41 +09:00
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "punycode" ) ;
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 2203 :
2020-09-23 15:58:52 +09:00
/***/ ( ( module ) => {
"use strict" ;
2021-07-22 01:59:05 +00:00
module . exports = require ( "stream" ) ;
2020-09-23 15:58:52 +09:00
/***/ } ) ,
2021-10-07 01:39:26 +00:00
2024-10-08 20:21:42 +01:00
/***/ 3193 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "string_decoder" ) ;
/***/ } ) ,
/***/ 3557 :
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "timers" ) ;
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 4756 :
2021-10-07 01:39:26 +00:00
/***/ ( ( module ) => {
"use strict" ;
module . exports = require ( "tls" ) ;
/***/ } ) ,
2020-09-23 15:58:52 +09:00
2024-09-29 18:20:46 +01:00
/***/ 7016 :
2020-09-23 15:58:52 +09:00
/***/ ( ( module ) => {
"use strict" ;
2021-07-22 01:59:05 +00:00
module . exports = require ( "url" ) ;
2020-09-23 15:58:52 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 9023 :
2020-09-23 15:58:52 +09:00
/***/ ( ( module ) => {
"use strict" ;
2021-07-22 01:59:05 +00:00
module . exports = require ( "util" ) ;
2020-09-23 15:58:52 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 3106 :
2020-09-23 15:58:52 +09:00
/***/ ( ( module ) => {
"use strict" ;
2021-07-22 01:59:05 +00:00
module . exports = require ( "zlib" ) ;
2020-09-23 15:58:52 +09:00
2022-01-27 17:19:41 +09:00
/***/ } ) ,
2024-09-29 18:20:46 +01:00
/***/ 7963 :
2022-01-27 17:19:41 +09:00
/***/ ( ( module ) => {
"use strict" ;
2024-09-29 18:20:46 +01:00
module . exports = /*#__PURE__*/ 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 , 3
2022-01-27 17:19:41 +09:00
2020-09-23 15:58:52 +09:00
/***/ } )
/******/ } ) ;
/************************************************************************/
/******/ // The module cache
/******/ var _ _webpack _module _cache _ _ = { } ;
/******/
/******/ // The require function
2021-02-25 02:15:04 +00:00
/******/ function _ _nccwpck _require _ _ ( moduleId ) {
2020-09-23 15:58:52 +09:00
/******/ // Check if module is in cache
2021-06-15 04:47:25 +00:00
/******/ var cachedModule = _ _webpack _module _cache _ _ [ moduleId ] ;
/******/ if ( cachedModule !== undefined ) {
/******/ return cachedModule . exports ;
2020-09-23 15:58:52 +09:00
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = _ _webpack _module _cache _ _ [ moduleId ] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports : { }
/******/ } ;
/******/
/******/ // Execute the module function
/******/ var threw = true ;
/******/ try {
2021-02-25 02:15:04 +00:00
/******/ _ _webpack _modules _ _ [ moduleId ] . call ( module . exports , module , module . exports , _ _nccwpck _require _ _ ) ;
2020-09-23 15:58:52 +09:00
/******/ threw = false ;
/******/ } finally {
/******/ if ( threw ) delete _ _webpack _module _cache _ _ [ moduleId ] ;
/******/ }
/******/
/******/ // Return the exports of the module
/******/ return module . exports ;
/******/ }
/******/
/************************************************************************/
/******/ /* webpack/runtime/compat */
/******/
2021-07-22 01:59:05 +00:00
/******/ if ( typeof _ _nccwpck _require _ _ !== 'undefined' ) _ _nccwpck _require _ _ . ab = _ _dirname + "/" ;
/******/
/************************************************************************/
2021-06-15 04:47:25 +00:00
/******/
2020-09-23 15:58:52 +09:00
/******/ // startup
/******/ // Load entry module and return exports
2021-06-15 04:47:25 +00:00
/******/ // This entry module is referenced by other modules so it can't be inlined
2024-09-29 18:20:46 +01:00
/******/ var _ _webpack _exports _ _ = _ _nccwpck _require _ _ ( 5915 ) ;
2021-06-15 04:47:25 +00:00
/******/ module . exports = _ _webpack _exports _ _ ;
/******/
2020-09-23 15:58:52 +09:00
/******/ } ) ( )
;