mc-publish/dist/index.js

23028 lines
1,010 KiB
JavaScript
Raw Normal View History

2021-09-26 15:31:45 -04:00
require('./sourcemap-register.js');/******/ (() => { // webpackBootstrap
/******/ var __webpack_modules__ = ({
/***/ 7351:
/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.issue = exports.issueCommand = void 0;
2022-05-31 14:18:28 -04:00
const os = __importStar(__nccwpck_require__(2037));
2021-09-26 15:31:45 -04:00
const utils_1 = __nccwpck_require__(5278);
/**
* Commands
*
* Command Format:
* ::name key=value,key=value::message
*
* Examples:
* ::warning::This is the message
* ::set-env name=MY_VAR::some value
*/
function issueCommand(command, properties, message) {
const cmd = new Command(command, properties, message);
process.stdout.write(cmd.toString() + os.EOL);
}
exports.issueCommand = issueCommand;
function issue(name, message = '') {
issueCommand(name, {}, message);
}
exports.issue = issue;
const CMD_STRING = '::';
class Command {
constructor(command, properties, message) {
if (!command) {
command = 'missing.command';
}
this.command = command;
this.properties = properties;
this.message = message;
}
toString() {
let cmdStr = CMD_STRING + this.command;
if (this.properties && Object.keys(this.properties).length > 0) {
cmdStr += ' ';
let first = true;
for (const key in this.properties) {
if (this.properties.hasOwnProperty(key)) {
const val = this.properties[key];
if (val) {
if (first) {
first = false;
}
else {
cmdStr += ',';
}
cmdStr += `${key}=${escapeProperty(val)}`;
}
}
}
}
cmdStr += `${CMD_STRING}${escapeData(this.message)}`;
return cmdStr;
}
}
function escapeData(s) {
return utils_1.toCommandValue(s)
.replace(/%/g, '%25')
.replace(/\r/g, '%0D')
.replace(/\n/g, '%0A');
}
function escapeProperty(s) {
return utils_1.toCommandValue(s)
.replace(/%/g, '%25')
.replace(/\r/g, '%0D')
.replace(/\n/g, '%0A')
.replace(/:/g, '%3A')
.replace(/,/g, '%2C');
}
//# sourceMappingURL=command.js.map
/***/ }),
/***/ 2186:
/***/ (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 }));
2021-10-01 09:38:36 -04:00
exports.getIDToken = exports.getState = exports.saveState = exports.group = exports.endGroup = exports.startGroup = exports.info = exports.notice = exports.warning = exports.error = exports.debug = exports.isDebug = exports.setFailed = exports.setCommandEcho = exports.setOutput = exports.getBooleanInput = exports.getMultilineInput = exports.getInput = exports.addPath = exports.setSecret = exports.exportVariable = exports.ExitCode = void 0;
2021-09-26 15:31:45 -04:00
const command_1 = __nccwpck_require__(7351);
const file_command_1 = __nccwpck_require__(717);
const utils_1 = __nccwpck_require__(5278);
2022-05-31 14:18:28 -04:00
const os = __importStar(__nccwpck_require__(2037));
const path = __importStar(__nccwpck_require__(1017));
2021-10-01 09:38:36 -04:00
const oidc_utils_1 = __nccwpck_require__(8041);
2021-09-26 15:31:45 -04: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";
})(ExitCode = exports.ExitCode || (exports.ExitCode = {}));
//-----------------------------------------------------------------------
// Variables
//-----------------------------------------------------------------------
/**
* Sets env variable for this action and future actions in the job
* @param name the name of the variable to set
* @param val the value of the variable. Non-string values will be converted to a string via JSON.stringify
*/
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function exportVariable(name, val) {
const convertedVal = utils_1.toCommandValue(val);
process.env[name] = convertedVal;
const filePath = process.env['GITHUB_ENV'] || '';
if (filePath) {
const delimiter = '_GitHubActionsFileCommandDelimeter_';
const commandValue = `${name}<<${delimiter}${os.EOL}${convertedVal}${os.EOL}${delimiter}`;
file_command_1.issueCommand('ENV', commandValue);
}
else {
command_1.issueCommand('set-env', { name }, convertedVal);
}
}
exports.exportVariable = exportVariable;
/**
* Registers a secret which will get masked from logs
* @param secret value of the secret
*/
function setSecret(secret) {
command_1.issueCommand('add-mask', {}, secret);
}
exports.setSecret = setSecret;
/**
* Prepends inputPath to the PATH (for this action and future actions)
* @param inputPath
*/
function addPath(inputPath) {
const filePath = process.env['GITHUB_PATH'] || '';
if (filePath) {
file_command_1.issueCommand('PATH', inputPath);
}
else {
command_1.issueCommand('add-path', {}, inputPath);
}
process.env['PATH'] = `${inputPath}${path.delimiter}${process.env['PATH']}`;
}
exports.addPath = addPath;
/**
* Gets the value of an input.
* Unless trimWhitespace is set to false in InputOptions, the value is also trimmed.
* Returns an empty string if the value is not defined.
*
* @param name name of the input to get
* @param options optional. See InputOptions.
* @returns string
*/
function getInput(name, options) {
const val = process.env[`INPUT_${name.replace(/ /g, '_').toUpperCase()}`] || '';
if (options && options.required && !val) {
throw new Error(`Input required and not supplied: ${name}`);
}
if (options && options.trimWhitespace === false) {
return val;
}
return val.trim();
}
exports.getInput = getInput;
/**
* Gets the values of an multiline input. Each value is also trimmed.
*
* @param name name of the input to get
* @param options optional. See InputOptions.
* @returns string[]
*
*/
function getMultilineInput(name, options) {
const inputs = getInput(name, options)
.split('\n')
.filter(x => x !== '');
return inputs;
}
exports.getMultilineInput = getMultilineInput;
/**
* Gets the input value of the boolean type in the YAML 1.2 "core schema" specification.
* Support boolean input list: `true | True | TRUE | false | False | FALSE` .
* The return value is also in boolean type.
* ref: https://yaml.org/spec/1.2/spec.html#id2804923
*
* @param name name of the input to get
* @param options optional. See InputOptions.
* @returns boolean
*/
function getBooleanInput(name, options) {
const trueValue = ['true', 'True', 'TRUE'];
const falseValue = ['false', 'False', 'FALSE'];
const val = getInput(name, options);
if (trueValue.includes(val))
return true;
if (falseValue.includes(val))
return false;
throw new TypeError(`Input does not meet YAML 1.2 "Core Schema" specification: ${name}\n` +
`Support boolean input list: \`true | True | TRUE | false | False | FALSE\``);
}
exports.getBooleanInput = getBooleanInput;
/**
* Sets the value of an output.
*
* @param name name of the output to set
* @param value value to store. Non-string values will be converted to a string via JSON.stringify
*/
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function setOutput(name, value) {
process.stdout.write(os.EOL);
command_1.issueCommand('set-output', { name }, value);
}
exports.setOutput = setOutput;
/**
* Enables or disables the echoing of commands into stdout for the rest of the step.
* Echoing is disabled by default if ACTIONS_STEP_DEBUG is not set.
*
*/
function setCommandEcho(enabled) {
command_1.issue('echo', enabled ? 'on' : 'off');
}
exports.setCommandEcho = setCommandEcho;
//-----------------------------------------------------------------------
// Results
//-----------------------------------------------------------------------
/**
* Sets the action status to failed.
* When the action exits it will be with an exit code of 1
* @param message add error issue message
*/
function setFailed(message) {
process.exitCode = ExitCode.Failure;
error(message);
}
exports.setFailed = setFailed;
//-----------------------------------------------------------------------
// Logging Commands
//-----------------------------------------------------------------------
/**
* Gets whether Actions Step Debug is on or not
*/
function isDebug() {
return process.env['RUNNER_DEBUG'] === '1';
}
exports.isDebug = isDebug;
/**
* Writes debug message to user log
* @param message debug message
*/
function debug(message) {
command_1.issueCommand('debug', {}, message);
}
exports.debug = debug;
/**
* Adds an error issue
* @param message error issue message. Errors will be converted to string via toString()
* @param properties optional properties to add to the annotation.
*/
function error(message, properties = {}) {
command_1.issueCommand('error', utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);
}
exports.error = error;
/**
* Adds a warning issue
* @param message warning issue message. Errors will be converted to string via toString()
* @param properties optional properties to add to the annotation.
*/
function warning(message, properties = {}) {
command_1.issueCommand('warning', utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);
}
exports.warning = warning;
/**
* Adds a notice issue
* @param message notice issue message. Errors will be converted to string via toString()
* @param properties optional properties to add to the annotation.
*/
function notice(message, properties = {}) {
command_1.issueCommand('notice', utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);
}
exports.notice = notice;
/**
* Writes info to log with console.log.
* @param message info message
*/
function info(message) {
process.stdout.write(message + os.EOL);
}
exports.info = info;
/**
* Begin an output group.
*
* Output until the next `groupEnd` will be foldable in this group
*
* @param name The name of the output group
*/
function startGroup(name) {
command_1.issue('group', name);
}
exports.startGroup = startGroup;
/**
* End an output group.
*/
function endGroup() {
command_1.issue('endgroup');
}
exports.endGroup = endGroup;
/**
* Wrap an asynchronous function call in a group.
*
* Returns the same type as the function itself.
*
* @param name The name of the group
* @param fn The function to wrap in the group
*/
function group(name, fn) {
return __awaiter(this, void 0, void 0, function* () {
startGroup(name);
let result;
try {
result = yield fn();
}
finally {
endGroup();
}
return result;
});
}
exports.group = group;
//-----------------------------------------------------------------------
// Wrapper action state
//-----------------------------------------------------------------------
/**
* Saves state for current action, the state can only be retrieved by this action's post job execution.
*
* @param name name of the state to store
* @param value value to store. Non-string values will be converted to a string via JSON.stringify
*/
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function saveState(name, value) {
command_1.issueCommand('save-state', { name }, value);
}
exports.saveState = saveState;
/**
* Gets the value of an state set by this action's main execution.
*
* @param name name of the state to get
* @returns string
*/
function getState(name) {
return process.env[`STATE_${name}`] || '';
}
exports.getState = getState;
2021-10-01 09:38:36 -04:00
function getIDToken(aud) {
return __awaiter(this, void 0, void 0, function* () {
return yield oidc_utils_1.OidcClient.getIDToken(aud);
});
}
exports.getIDToken = getIDToken;
2022-05-31 14:18:28 -04:00
/**
* Summary exports
*/
var summary_1 = __nccwpck_require__(1327);
Object.defineProperty(exports, "summary", ({ enumerable: true, get: function () { return summary_1.summary; } }));
/**
* @deprecated use core.summary
*/
var summary_2 = __nccwpck_require__(1327);
Object.defineProperty(exports, "markdownSummary", ({ enumerable: true, get: function () { return summary_2.markdownSummary; } }));
2021-09-26 15:31:45 -04:00
//# sourceMappingURL=core.js.map
/***/ }),
/***/ 717:
/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
"use strict";
// For internal use, subject to change.
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.issueCommand = void 0;
// We use any as a valid input type
/* eslint-disable @typescript-eslint/no-explicit-any */
2022-05-31 14:18:28 -04:00
const fs = __importStar(__nccwpck_require__(7147));
const os = __importStar(__nccwpck_require__(2037));
2021-09-26 15:31:45 -04:00
const utils_1 = __nccwpck_require__(5278);
function issueCommand(command, message) {
const filePath = process.env[`GITHUB_${command}`];
if (!filePath) {
throw new Error(`Unable to find environment variable for file command ${command}`);
}
if (!fs.existsSync(filePath)) {
throw new Error(`Missing file at path: ${filePath}`);
}
fs.appendFileSync(filePath, `${utils_1.toCommandValue(message)}${os.EOL}`, {
encoding: 'utf8'
});
}
exports.issueCommand = issueCommand;
//# sourceMappingURL=file-command.js.map
/***/ }),
2021-10-01 09:38:36 -04:00
/***/ 8041:
/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.OidcClient = void 0;
2022-05-31 14:18:28 -04:00
const http_client_1 = __nccwpck_require__(6255);
const auth_1 = __nccwpck_require__(5526);
2021-10-01 09:38:36 -04:00
const core_1 = __nccwpck_require__(2186);
class OidcClient {
static createHttpClient(allowRetry = true, maxRetry = 10) {
const requestOptions = {
allowRetries: allowRetry,
maxRetries: maxRetry
};
return new http_client_1.HttpClient('actions/oidc-client', [new auth_1.BearerCredentialHandler(OidcClient.getRequestToken())], requestOptions);
}
static getRequestToken() {
const token = process.env['ACTIONS_ID_TOKEN_REQUEST_TOKEN'];
if (!token) {
throw new Error('Unable to get ACTIONS_ID_TOKEN_REQUEST_TOKEN env variable');
}
return token;
}
static getIDTokenUrl() {
const runtimeUrl = process.env['ACTIONS_ID_TOKEN_REQUEST_URL'];
if (!runtimeUrl) {
throw new Error('Unable to get ACTIONS_ID_TOKEN_REQUEST_URL env variable');
}
return runtimeUrl;
}
static getCall(id_token_url) {
var _a;
return __awaiter(this, void 0, void 0, function* () {
const httpclient = OidcClient.createHttpClient();
const res = yield httpclient
.getJson(id_token_url)
.catch(error => {
throw new Error(`Failed to get ID Token. \n
Error Code : ${error.statusCode}\n
Error Message: ${error.result.message}`);
});
const id_token = (_a = res.result) === null || _a === void 0 ? void 0 : _a.value;
if (!id_token) {
throw new Error('Response json body do not have ID Token field');
}
return id_token;
});
}
static getIDToken(audience) {
return __awaiter(this, void 0, void 0, function* () {
try {
// New ID Token is requested from action service
let id_token_url = OidcClient.getIDTokenUrl();
if (audience) {
const encodedAudience = encodeURIComponent(audience);
id_token_url = `${id_token_url}&audience=${encodedAudience}`;
}
core_1.debug(`ID token url is ${id_token_url}`);
const id_token = yield OidcClient.getCall(id_token_url);
core_1.setSecret(id_token);
return id_token;
}
catch (error) {
throw new Error(`Error message: ${error.message}`);
}
});
}
}
exports.OidcClient = OidcClient;
//# sourceMappingURL=oidc-utils.js.map
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 1327:
/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.summary = exports.markdownSummary = exports.SUMMARY_DOCS_URL = exports.SUMMARY_ENV_VAR = void 0;
const os_1 = __nccwpck_require__(2037);
const fs_1 = __nccwpck_require__(7147);
const { access, appendFile, writeFile } = fs_1.promises;
exports.SUMMARY_ENV_VAR = 'GITHUB_STEP_SUMMARY';
exports.SUMMARY_DOCS_URL = 'https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#adding-a-job-summary';
class Summary {
constructor() {
this._buffer = '';
}
/**
* Finds the summary file path from the environment, rejects if env var is not found or file does not exist
* Also checks r/w permissions.
*
* @returns step summary file path
*/
filePath() {
return __awaiter(this, void 0, void 0, function* () {
if (this._filePath) {
return this._filePath;
}
const pathFromEnv = process.env[exports.SUMMARY_ENV_VAR];
if (!pathFromEnv) {
throw new Error(`Unable to find environment variable for $${exports.SUMMARY_ENV_VAR}. Check if your runtime environment supports job summaries.`);
}
try {
yield access(pathFromEnv, fs_1.constants.R_OK | fs_1.constants.W_OK);
}
catch (_a) {
throw new Error(`Unable to access summary file: '${pathFromEnv}'. Check if the file has correct read/write permissions.`);
}
this._filePath = pathFromEnv;
return this._filePath;
});
}
/**
* Wraps content in an HTML tag, adding any HTML attributes
*
* @param {string} tag HTML tag to wrap
* @param {string | null} content content within the tag
* @param {[attribute: string]: string} attrs key-value list of HTML attributes to add
*
* @returns {string} content wrapped in HTML element
*/
wrap(tag, content, attrs = {}) {
const htmlAttrs = Object.entries(attrs)
.map(([key, value]) => ` ${key}="${value}"`)
.join('');
if (!content) {
return `<${tag}${htmlAttrs}>`;
}
return `<${tag}${htmlAttrs}>${content}</${tag}>`;
}
/**
* Writes text in the buffer to the summary buffer file and empties buffer. Will append by default.
*
* @param {SummaryWriteOptions} [options] (optional) options for write operation
*
* @returns {Promise<Summary>} summary instance
*/
write(options) {
return __awaiter(this, void 0, void 0, function* () {
const overwrite = !!(options === null || options === void 0 ? void 0 : options.overwrite);
const filePath = yield this.filePath();
const writeFunc = overwrite ? writeFile : appendFile;
yield writeFunc(filePath, this._buffer, { encoding: 'utf8' });
return this.emptyBuffer();
});
}
/**
* Clears the summary buffer and wipes the summary file
*
* @returns {Summary} summary instance
*/
clear() {
return __awaiter(this, void 0, void 0, function* () {
return this.emptyBuffer().write({ overwrite: true });
});
}
/**
* Returns the current summary buffer as a string
*
* @returns {string} string of summary buffer
*/
stringify() {
return this._buffer;
}
/**
* If the summary buffer is empty
*
* @returns {boolen} true if the buffer is empty
*/
isEmptyBuffer() {
return this._buffer.length === 0;
}
/**
* Resets the summary buffer without writing to summary file
*
* @returns {Summary} summary instance
*/
emptyBuffer() {
this._buffer = '';
return this;
}
/**
* Adds raw text to the summary buffer
*
* @param {string} text content to add
* @param {boolean} [addEOL=false] (optional) append an EOL to the raw text (default: false)
*
* @returns {Summary} summary instance
*/
addRaw(text, addEOL = false) {
this._buffer += text;
return addEOL ? this.addEOL() : this;
}
/**
* Adds the operating system-specific end-of-line marker to the buffer
*
* @returns {Summary} summary instance
*/
addEOL() {
return this.addRaw(os_1.EOL);
}
/**
* Adds an HTML codeblock to the summary buffer
*
* @param {string} code content to render within fenced code block
* @param {string} lang (optional) language to syntax highlight code
*
* @returns {Summary} summary instance
*/
addCodeBlock(code, lang) {
const attrs = Object.assign({}, (lang && { lang }));
const element = this.wrap('pre', this.wrap('code', code), attrs);
return this.addRaw(element).addEOL();
}
/**
* Adds an HTML list to the summary buffer
*
* @param {string[]} items list of items to render
* @param {boolean} [ordered=false] (optional) if the rendered list should be ordered or not (default: false)
*
* @returns {Summary} summary instance
*/
addList(items, ordered = false) {
const tag = ordered ? 'ol' : 'ul';
const listItems = items.map(item => this.wrap('li', item)).join('');
const element = this.wrap(tag, listItems);
return this.addRaw(element).addEOL();
}
/**
* Adds an HTML table to the summary buffer
*
* @param {SummaryTableCell[]} rows table rows
*
* @returns {Summary} summary instance
*/
addTable(rows) {
const tableBody = rows
.map(row => {
const cells = row
.map(cell => {
if (typeof cell === 'string') {
return this.wrap('td', cell);
}
const { header, data, colspan, rowspan } = cell;
const tag = header ? 'th' : 'td';
const attrs = Object.assign(Object.assign({}, (colspan && { colspan })), (rowspan && { rowspan }));
return this.wrap(tag, data, attrs);
})
.join('');
return this.wrap('tr', cells);
})
.join('');
const element = this.wrap('table', tableBody);
return this.addRaw(element).addEOL();
}
/**
* Adds a collapsable HTML details element to the summary buffer
*
* @param {string} label text for the closed state
* @param {string} content collapsable content
*
* @returns {Summary} summary instance
*/
addDetails(label, content) {
const element = this.wrap('details', this.wrap('summary', label) + content);
return this.addRaw(element).addEOL();
}
/**
* Adds an HTML image tag to the summary buffer
*
* @param {string} src path to the image you to embed
* @param {string} alt text description of the image
* @param {SummaryImageOptions} options (optional) addition image attributes
*
* @returns {Summary} summary instance
*/
addImage(src, alt, options) {
const { width, height } = options || {};
const attrs = Object.assign(Object.assign({}, (width && { width })), (height && { height }));
const element = this.wrap('img', null, Object.assign({ src, alt }, attrs));
return this.addRaw(element).addEOL();
}
/**
* Adds an HTML section heading element
*
* @param {string} text heading text
* @param {number | string} [level=1] (optional) the heading level, default: 1
*
* @returns {Summary} summary instance
*/
addHeading(text, level) {
const tag = `h${level}`;
const allowedTag = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6'].includes(tag)
? tag
: 'h1';
const element = this.wrap(allowedTag, text);
return this.addRaw(element).addEOL();
}
/**
* Adds an HTML thematic break (<hr>) to the summary buffer
*
* @returns {Summary} summary instance
*/
addSeparator() {
const element = this.wrap('hr', null);
return this.addRaw(element).addEOL();
}
/**
* Adds an HTML line break (<br>) to the summary buffer
*
* @returns {Summary} summary instance
*/
addBreak() {
const element = this.wrap('br', null);
return this.addRaw(element).addEOL();
}
/**
* Adds an HTML blockquote to the summary buffer
*
* @param {string} text quote text
* @param {string} cite (optional) citation url
*
* @returns {Summary} summary instance
*/
addQuote(text, cite) {
const attrs = Object.assign({}, (cite && { cite }));
const element = this.wrap('blockquote', text, attrs);
return this.addRaw(element).addEOL();
}
/**
* Adds an HTML anchor tag to the summary buffer
*
* @param {string} text link text/content
* @param {string} href hyperlink
*
* @returns {Summary} summary instance
*/
addLink(text, href) {
const element = this.wrap('a', text, { href });
return this.addRaw(element).addEOL();
}
}
const _summary = new Summary();
/**
* @deprecated use `core.summary`
*/
exports.markdownSummary = _summary;
exports.summary = _summary;
//# sourceMappingURL=summary.js.map
/***/ }),
2021-09-26 15:31:45 -04:00
/***/ 5278:
/***/ ((__unused_webpack_module, exports) => {
"use strict";
// We use any as a valid input type
/* eslint-disable @typescript-eslint/no-explicit-any */
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.toCommandProperties = exports.toCommandValue = void 0;
/**
* Sanitizes an input into a string so it can be passed into issueCommand safely
* @param input input to sanitize into a string
*/
function toCommandValue(input) {
if (input === null || input === undefined) {
return '';
}
else if (typeof input === 'string' || input instanceof String) {
return input;
}
return JSON.stringify(input);
}
exports.toCommandValue = toCommandValue;
/**
*
* @param annotationProperties
* @returns The command properties to send with the actual annotation command
* See IssueCommandProperties: https://github.com/actions/runner/blob/main/src/Runner.Worker/ActionCommandManager.cs#L646
*/
function toCommandProperties(annotationProperties) {
if (!Object.keys(annotationProperties).length) {
return {};
}
return {
title: annotationProperties.title,
2021-10-01 09:38:36 -04:00
file: annotationProperties.file,
2021-09-26 15:31:45 -04:00
line: annotationProperties.startLine,
endLine: annotationProperties.endLine,
col: annotationProperties.startColumn,
endColumn: annotationProperties.endColumn
};
}
exports.toCommandProperties = toCommandProperties;
//# sourceMappingURL=utils.js.map
/***/ }),
/***/ 4087:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.Context = void 0;
2022-05-31 14:18:28 -04:00
const fs_1 = __nccwpck_require__(7147);
const os_1 = __nccwpck_require__(2037);
2021-09-26 15:31:45 -04:00
class Context {
/**
* Hydrate the context from the environment
*/
constructor() {
var _a, _b, _c;
this.payload = {};
if (process.env.GITHUB_EVENT_PATH) {
if (fs_1.existsSync(process.env.GITHUB_EVENT_PATH)) {
this.payload = JSON.parse(fs_1.readFileSync(process.env.GITHUB_EVENT_PATH, { encoding: 'utf8' }));
}
else {
const path = process.env.GITHUB_EVENT_PATH;
process.stdout.write(`GITHUB_EVENT_PATH ${path} does not exist${os_1.EOL}`);
}
}
this.eventName = process.env.GITHUB_EVENT_NAME;
this.sha = process.env.GITHUB_SHA;
this.ref = process.env.GITHUB_REF;
this.workflow = process.env.GITHUB_WORKFLOW;
this.action = process.env.GITHUB_ACTION;
this.actor = process.env.GITHUB_ACTOR;
this.job = process.env.GITHUB_JOB;
this.runNumber = parseInt(process.env.GITHUB_RUN_NUMBER, 10);
this.runId = parseInt(process.env.GITHUB_RUN_ID, 10);
this.apiUrl = (_a = process.env.GITHUB_API_URL) !== null && _a !== void 0 ? _a : `https://api.github.com`;
this.serverUrl = (_b = process.env.GITHUB_SERVER_URL) !== null && _b !== void 0 ? _b : `https://github.com`;
this.graphqlUrl = (_c = process.env.GITHUB_GRAPHQL_URL) !== null && _c !== void 0 ? _c : `https://api.github.com/graphql`;
}
get issue() {
const payload = this.payload;
return Object.assign(Object.assign({}, this.repo), { number: (payload.issue || payload.pull_request || payload).number });
}
get repo() {
if (process.env.GITHUB_REPOSITORY) {
const [owner, repo] = process.env.GITHUB_REPOSITORY.split('/');
return { owner, repo };
}
if (this.payload.repository) {
return {
owner: this.payload.repository.owner.login,
repo: this.payload.repository.name
};
}
throw new Error("context.repo requires a GITHUB_REPOSITORY environment variable like 'owner/repo'");
}
}
exports.Context = Context;
//# sourceMappingURL=context.js.map
/***/ }),
/***/ 5438:
/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.getOctokit = exports.context = void 0;
const Context = __importStar(__nccwpck_require__(4087));
const utils_1 = __nccwpck_require__(3030);
exports.context = new Context.Context();
/**
* Returns a hydrated octokit ready to use for GitHub Actions
*
* @param token the repo PAT or GITHUB_TOKEN
* @param options other options to set
*/
function getOctokit(token, options) {
return new utils_1.GitHub(utils_1.getOctokitOptions(token, options));
}
exports.getOctokit = getOctokit;
//# sourceMappingURL=github.js.map
/***/ }),
/***/ 7914:
/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.getApiBaseUrl = exports.getProxyAgent = exports.getAuthString = void 0;
2022-05-31 14:18:28 -04:00
const httpClient = __importStar(__nccwpck_require__(6255));
2021-09-26 15:31:45 -04:00
function getAuthString(token, options) {
if (!token && !options.auth) {
throw new Error('Parameter token or opts.auth is required');
}
else if (token && options.auth) {
throw new Error('Parameters token and opts.auth may not both be specified');
}
return typeof options.auth === 'string' ? options.auth : `token ${token}`;
}
exports.getAuthString = getAuthString;
function getProxyAgent(destinationUrl) {
const hc = new httpClient.HttpClient();
return hc.getAgent(destinationUrl);
}
exports.getProxyAgent = getProxyAgent;
function getApiBaseUrl() {
return process.env['GITHUB_API_URL'] || 'https://api.github.com';
}
exports.getApiBaseUrl = getApiBaseUrl;
//# sourceMappingURL=utils.js.map
/***/ }),
/***/ 3030:
/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.getOctokitOptions = exports.GitHub = exports.context = void 0;
const Context = __importStar(__nccwpck_require__(4087));
const Utils = __importStar(__nccwpck_require__(7914));
// octokit + plugins
const core_1 = __nccwpck_require__(6762);
const plugin_rest_endpoint_methods_1 = __nccwpck_require__(3044);
const plugin_paginate_rest_1 = __nccwpck_require__(4193);
exports.context = new Context.Context();
const baseUrl = Utils.getApiBaseUrl();
const defaults = {
baseUrl,
request: {
agent: Utils.getProxyAgent(baseUrl)
}
};
exports.GitHub = core_1.Octokit.plugin(plugin_rest_endpoint_methods_1.restEndpointMethods, plugin_paginate_rest_1.paginateRest).defaults(defaults);
/**
* Convience function to correctly format Octokit Options to pass into the constructor.
*
* @param token the repo PAT or GITHUB_TOKEN
* @param options other options to set
*/
function getOctokitOptions(token, options) {
const opts = Object.assign({}, options || {}); // Shallow clone - don't mutate the object provided by the caller
// Auth
const auth = Utils.getAuthString(token, opts);
if (auth) {
opts.auth = auth;
}
return opts;
}
exports.getOctokitOptions = getOctokitOptions;
//# sourceMappingURL=utils.js.map
2021-10-01 09:38:36 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 5526:
/***/ (function(__unused_webpack_module, exports) {
2021-10-01 09:38:36 -04:00
"use strict";
2022-05-31 14:18:28 -04:00
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
2021-10-01 09:38:36 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
2022-05-31 14:18:28 -04:00
exports.PersonalAccessTokenCredentialHandler = exports.BearerCredentialHandler = exports.BasicCredentialHandler = void 0;
2021-10-01 09:38:36 -04:00
class BasicCredentialHandler {
constructor(username, password) {
this.username = username;
this.password = password;
}
prepareRequest(options) {
2022-05-31 14:18:28 -04:00
if (!options.headers) {
throw Error('The request has no headers');
}
options.headers['Authorization'] = `Basic ${Buffer.from(`${this.username}:${this.password}`).toString('base64')}`;
2021-10-01 09:38:36 -04:00
}
// This handler cannot handle 401
2022-05-31 14:18:28 -04:00
canHandleAuthentication() {
2021-10-01 09:38:36 -04:00
return false;
}
2022-05-31 14:18:28 -04:00
handleAuthentication() {
return __awaiter(this, void 0, void 0, function* () {
throw new Error('not implemented');
});
2021-10-01 09:38:36 -04:00
}
}
exports.BasicCredentialHandler = BasicCredentialHandler;
class BearerCredentialHandler {
constructor(token) {
this.token = token;
}
// currently implements pre-authorization
// TODO: support preAuth = false where it hooks on 401
prepareRequest(options) {
2022-05-31 14:18:28 -04:00
if (!options.headers) {
throw Error('The request has no headers');
}
options.headers['Authorization'] = `Bearer ${this.token}`;
2021-10-01 09:38:36 -04:00
}
// This handler cannot handle 401
2022-05-31 14:18:28 -04:00
canHandleAuthentication() {
2021-10-01 09:38:36 -04:00
return false;
}
2022-05-31 14:18:28 -04:00
handleAuthentication() {
return __awaiter(this, void 0, void 0, function* () {
throw new Error('not implemented');
});
2021-10-01 09:38:36 -04:00
}
}
exports.BearerCredentialHandler = BearerCredentialHandler;
class PersonalAccessTokenCredentialHandler {
constructor(token) {
this.token = token;
}
// currently implements pre-authorization
// TODO: support preAuth = false where it hooks on 401
prepareRequest(options) {
2022-05-31 14:18:28 -04:00
if (!options.headers) {
throw Error('The request has no headers');
}
options.headers['Authorization'] = `Basic ${Buffer.from(`PAT:${this.token}`).toString('base64')}`;
2021-10-01 09:38:36 -04:00
}
// This handler cannot handle 401
2022-05-31 14:18:28 -04:00
canHandleAuthentication() {
2021-10-01 09:38:36 -04:00
return false;
}
2022-05-31 14:18:28 -04:00
handleAuthentication() {
return __awaiter(this, void 0, void 0, function* () {
throw new Error('not implemented');
});
2021-10-01 09:38:36 -04:00
}
}
exports.PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHandler;
2022-05-31 14:18:28 -04:00
//# sourceMappingURL=auth.js.map
2021-10-01 09:38:36 -04:00
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 6255:
/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
2021-09-26 15:31:45 -04:00
"use strict";
2022-05-31 14:18:28 -04:00
/* eslint-disable @typescript-eslint/no-explicit-any */
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
2021-09-26 15:31:45 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
2022-05-31 14:18:28 -04:00
exports.HttpClient = exports.isHttps = exports.HttpClientResponse = exports.HttpClientError = exports.getProxyUrl = exports.MediaTypes = exports.Headers = exports.HttpCodes = void 0;
const http = __importStar(__nccwpck_require__(3685));
const https = __importStar(__nccwpck_require__(5687));
const pm = __importStar(__nccwpck_require__(9835));
const tunnel = __importStar(__nccwpck_require__(4294));
2021-09-26 15:31:45 -04:00
var HttpCodes;
(function (HttpCodes) {
HttpCodes[HttpCodes["OK"] = 200] = "OK";
HttpCodes[HttpCodes["MultipleChoices"] = 300] = "MultipleChoices";
HttpCodes[HttpCodes["MovedPermanently"] = 301] = "MovedPermanently";
HttpCodes[HttpCodes["ResourceMoved"] = 302] = "ResourceMoved";
HttpCodes[HttpCodes["SeeOther"] = 303] = "SeeOther";
HttpCodes[HttpCodes["NotModified"] = 304] = "NotModified";
HttpCodes[HttpCodes["UseProxy"] = 305] = "UseProxy";
HttpCodes[HttpCodes["SwitchProxy"] = 306] = "SwitchProxy";
HttpCodes[HttpCodes["TemporaryRedirect"] = 307] = "TemporaryRedirect";
HttpCodes[HttpCodes["PermanentRedirect"] = 308] = "PermanentRedirect";
HttpCodes[HttpCodes["BadRequest"] = 400] = "BadRequest";
HttpCodes[HttpCodes["Unauthorized"] = 401] = "Unauthorized";
HttpCodes[HttpCodes["PaymentRequired"] = 402] = "PaymentRequired";
HttpCodes[HttpCodes["Forbidden"] = 403] = "Forbidden";
HttpCodes[HttpCodes["NotFound"] = 404] = "NotFound";
HttpCodes[HttpCodes["MethodNotAllowed"] = 405] = "MethodNotAllowed";
HttpCodes[HttpCodes["NotAcceptable"] = 406] = "NotAcceptable";
HttpCodes[HttpCodes["ProxyAuthenticationRequired"] = 407] = "ProxyAuthenticationRequired";
HttpCodes[HttpCodes["RequestTimeout"] = 408] = "RequestTimeout";
HttpCodes[HttpCodes["Conflict"] = 409] = "Conflict";
HttpCodes[HttpCodes["Gone"] = 410] = "Gone";
HttpCodes[HttpCodes["TooManyRequests"] = 429] = "TooManyRequests";
HttpCodes[HttpCodes["InternalServerError"] = 500] = "InternalServerError";
HttpCodes[HttpCodes["NotImplemented"] = 501] = "NotImplemented";
HttpCodes[HttpCodes["BadGateway"] = 502] = "BadGateway";
HttpCodes[HttpCodes["ServiceUnavailable"] = 503] = "ServiceUnavailable";
HttpCodes[HttpCodes["GatewayTimeout"] = 504] = "GatewayTimeout";
})(HttpCodes = exports.HttpCodes || (exports.HttpCodes = {}));
var Headers;
(function (Headers) {
Headers["Accept"] = "accept";
Headers["ContentType"] = "content-type";
})(Headers = exports.Headers || (exports.Headers = {}));
var MediaTypes;
(function (MediaTypes) {
MediaTypes["ApplicationJson"] = "application/json";
})(MediaTypes = exports.MediaTypes || (exports.MediaTypes = {}));
/**
* Returns the proxy URL, depending upon the supplied url and proxy environment variables.
* @param serverUrl The server URL where the request will be sent. For example, https://api.github.com
*/
function getProxyUrl(serverUrl) {
2022-05-31 14:18:28 -04:00
const proxyUrl = pm.getProxyUrl(new URL(serverUrl));
2021-09-26 15:31:45 -04:00
return proxyUrl ? proxyUrl.href : '';
}
exports.getProxyUrl = getProxyUrl;
const HttpRedirectCodes = [
HttpCodes.MovedPermanently,
HttpCodes.ResourceMoved,
HttpCodes.SeeOther,
HttpCodes.TemporaryRedirect,
HttpCodes.PermanentRedirect
];
const HttpResponseRetryCodes = [
HttpCodes.BadGateway,
HttpCodes.ServiceUnavailable,
HttpCodes.GatewayTimeout
];
const RetryableHttpVerbs = ['OPTIONS', 'GET', 'DELETE', 'HEAD'];
const ExponentialBackoffCeiling = 10;
const ExponentialBackoffTimeSlice = 5;
class HttpClientError extends Error {
constructor(message, statusCode) {
super(message);
this.name = 'HttpClientError';
this.statusCode = statusCode;
Object.setPrototypeOf(this, HttpClientError.prototype);
}
}
exports.HttpClientError = HttpClientError;
class HttpClientResponse {
constructor(message) {
this.message = message;
}
readBody() {
2022-05-31 14:18:28 -04:00
return __awaiter(this, void 0, void 0, function* () {
return new Promise((resolve) => __awaiter(this, void 0, void 0, function* () {
let output = Buffer.alloc(0);
this.message.on('data', (chunk) => {
output = Buffer.concat([output, chunk]);
});
this.message.on('end', () => {
resolve(output.toString());
});
}));
2021-09-26 15:31:45 -04:00
});
}
}
exports.HttpClientResponse = HttpClientResponse;
function isHttps(requestUrl) {
2022-05-31 14:18:28 -04:00
const parsedUrl = new URL(requestUrl);
2021-09-26 15:31:45 -04:00
return parsedUrl.protocol === 'https:';
}
exports.isHttps = isHttps;
class HttpClient {
constructor(userAgent, handlers, requestOptions) {
this._ignoreSslError = false;
this._allowRedirects = true;
this._allowRedirectDowngrade = false;
this._maxRedirects = 50;
this._allowRetries = false;
this._maxRetries = 1;
this._keepAlive = false;
this._disposed = false;
this.userAgent = userAgent;
this.handlers = handlers || [];
this.requestOptions = requestOptions;
if (requestOptions) {
if (requestOptions.ignoreSslError != null) {
this._ignoreSslError = requestOptions.ignoreSslError;
}
this._socketTimeout = requestOptions.socketTimeout;
if (requestOptions.allowRedirects != null) {
this._allowRedirects = requestOptions.allowRedirects;
}
if (requestOptions.allowRedirectDowngrade != null) {
this._allowRedirectDowngrade = requestOptions.allowRedirectDowngrade;
}
if (requestOptions.maxRedirects != null) {
this._maxRedirects = Math.max(requestOptions.maxRedirects, 0);
}
if (requestOptions.keepAlive != null) {
this._keepAlive = requestOptions.keepAlive;
}
if (requestOptions.allowRetries != null) {
this._allowRetries = requestOptions.allowRetries;
}
if (requestOptions.maxRetries != null) {
this._maxRetries = requestOptions.maxRetries;
}
}
}
options(requestUrl, additionalHeaders) {
2022-05-31 14:18:28 -04:00
return __awaiter(this, void 0, void 0, function* () {
return this.request('OPTIONS', requestUrl, null, additionalHeaders || {});
});
2021-09-26 15:31:45 -04:00
}
get(requestUrl, additionalHeaders) {
2022-05-31 14:18:28 -04:00
return __awaiter(this, void 0, void 0, function* () {
return this.request('GET', requestUrl, null, additionalHeaders || {});
});
2021-09-26 15:31:45 -04:00
}
del(requestUrl, additionalHeaders) {
2022-05-31 14:18:28 -04:00
return __awaiter(this, void 0, void 0, function* () {
return this.request('DELETE', requestUrl, null, additionalHeaders || {});
});
2021-09-26 15:31:45 -04:00
}
post(requestUrl, data, additionalHeaders) {
2022-05-31 14:18:28 -04:00
return __awaiter(this, void 0, void 0, function* () {
return this.request('POST', requestUrl, data, additionalHeaders || {});
});
2021-09-26 15:31:45 -04:00
}
patch(requestUrl, data, additionalHeaders) {
2022-05-31 14:18:28 -04:00
return __awaiter(this, void 0, void 0, function* () {
return this.request('PATCH', requestUrl, data, additionalHeaders || {});
});
2021-09-26 15:31:45 -04:00
}
put(requestUrl, data, additionalHeaders) {
2022-05-31 14:18:28 -04:00
return __awaiter(this, void 0, void 0, function* () {
return this.request('PUT', requestUrl, data, additionalHeaders || {});
});
2021-09-26 15:31:45 -04:00
}
head(requestUrl, additionalHeaders) {
2022-05-31 14:18:28 -04:00
return __awaiter(this, void 0, void 0, function* () {
return this.request('HEAD', requestUrl, null, additionalHeaders || {});
});
2021-09-26 15:31:45 -04:00
}
sendStream(verb, requestUrl, stream, additionalHeaders) {
2022-05-31 14:18:28 -04:00
return __awaiter(this, void 0, void 0, function* () {
return this.request(verb, requestUrl, stream, additionalHeaders);
});
2021-09-26 15:31:45 -04:00
}
/**
* Gets a typed object from an endpoint
* Be aware that not found returns a null. Other errors (4xx, 5xx) reject the promise
*/
2022-05-31 14:18:28 -04:00
getJson(requestUrl, additionalHeaders = {}) {
return __awaiter(this, void 0, void 0, function* () {
additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);
const res = yield this.get(requestUrl, additionalHeaders);
return this._processResponse(res, this.requestOptions);
});
}
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-09-26 15:31:45 -04:00
}
/**
* Makes a raw http request.
* All other methods such as get, post, patch, and request ultimately call this.
* Prefer get, del, post and patch
*/
2022-05-31 14:18:28 -04: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-09-26 15:31:45 -04:00
}
}
2022-05-31 14:18:28 -04:00
let redirectsRemaining = this._maxRedirects;
while (response.message.statusCode &&
HttpRedirectCodes.includes(response.message.statusCode) &&
this._allowRedirects &&
redirectsRemaining > 0) {
const redirectUrl = response.message.headers['location'];
if (!redirectUrl) {
// if there's no location to redirect to, we won't
break;
}
const parsedRedirectUrl = new URL(redirectUrl);
if (parsedUrl.protocol === 'https:' &&
parsedUrl.protocol !== parsedRedirectUrl.protocol &&
!this._allowRedirectDowngrade) {
throw new Error('Redirect from HTTPS to HTTP protocol. This downgrade is not allowed for security reasons. If you want to allow this behavior, set the allowRedirectDowngrade option to true.');
}
// we need to finish reading the response before reassigning response
// which will leak the open socket.
yield response.readBody();
// strip authorization header if redirected to a different hostname
if (parsedRedirectUrl.hostname !== parsedUrl.hostname) {
for (const header in headers) {
// header names are case insensitive
if (header.toLowerCase() === 'authorization') {
delete headers[header];
}
}
}
// let's make the request with the new redirectUrl
info = this._prepareRequest(verb, parsedRedirectUrl, headers);
response = yield this.requestRaw(info, data);
redirectsRemaining--;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (!response.message.statusCode ||
!HttpResponseRetryCodes.includes(response.message.statusCode)) {
// If not a retry code, return immediately instead of retrying
2021-09-26 15:31:45 -04:00
return response;
}
2022-05-31 14:18:28 -04:00
numTries += 1;
if (numTries < maxTries) {
yield response.readBody();
yield this._performExponentialBackoff(numTries);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
} while (numTries < maxTries);
return response;
});
2021-09-26 15:31:45 -04:00
}
/**
* Needs to be called if keepAlive is set to true in request options.
*/
dispose() {
if (this._agent) {
this._agent.destroy();
}
this._disposed = true;
}
/**
* Raw request.
* @param info
* @param data
*/
requestRaw(info, data) {
2022-05-31 14:18:28 -04:00
return __awaiter(this, void 0, void 0, function* () {
return new Promise((resolve, reject) => {
function callbackForResult(err, res) {
if (err) {
reject(err);
}
else if (!res) {
// If `err` is not passed, then `res` must be passed.
reject(new Error('Unknown error'));
}
else {
resolve(res);
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
this.requestRawWithCallback(info, data, callbackForResult);
});
2021-09-26 15:31:45 -04:00
});
}
/**
* Raw request with callback.
* @param info
* @param data
* @param onResult
*/
requestRawWithCallback(info, data, onResult) {
if (typeof data === 'string') {
2022-05-31 14:18:28 -04:00
if (!info.options.headers) {
info.options.headers = {};
}
2021-09-26 15:31:45 -04:00
info.options.headers['Content-Length'] = Buffer.byteLength(data, 'utf8');
}
let callbackCalled = false;
2022-05-31 14:18:28 -04:00
function handleResult(err, res) {
2021-09-26 15:31:45 -04:00
if (!callbackCalled) {
callbackCalled = true;
onResult(err, res);
}
2022-05-31 14:18:28 -04:00
}
const req = info.httpModule.request(info.options, (msg) => {
const res = new HttpClientResponse(msg);
handleResult(undefined, res);
2021-09-26 15:31:45 -04:00
});
2022-05-31 14:18:28 -04:00
let socket;
2021-09-26 15:31:45 -04:00
req.on('socket', sock => {
socket = sock;
});
// If we ever get disconnected, we want the socket to timeout eventually
req.setTimeout(this._socketTimeout || 3 * 60000, () => {
if (socket) {
socket.end();
}
2022-05-31 14:18:28 -04:00
handleResult(new Error(`Request timeout: ${info.options.path}`));
2021-09-26 15:31:45 -04:00
});
req.on('error', function (err) {
// err has statusCode property
// res should have headers
2022-05-31 14:18:28 -04:00
handleResult(err);
2021-09-26 15:31:45 -04:00
});
if (data && typeof data === 'string') {
req.write(data, 'utf8');
}
if (data && typeof data !== 'string') {
data.on('close', function () {
req.end();
});
data.pipe(req);
}
else {
req.end();
}
}
/**
* Gets an http agent. This function is useful when you need an http agent that handles
* routing through a proxy server - depending upon the url and proxy environment variables.
* @param serverUrl The server URL where the request will be sent. For example, https://api.github.com
*/
getAgent(serverUrl) {
2022-05-31 14:18:28 -04:00
const parsedUrl = new URL(serverUrl);
2021-09-26 15:31:45 -04:00
return this._getAgent(parsedUrl);
}
_prepareRequest(method, requestUrl, headers) {
const info = {};
info.parsedUrl = requestUrl;
const usingSsl = info.parsedUrl.protocol === 'https:';
info.httpModule = usingSsl ? https : http;
const defaultPort = usingSsl ? 443 : 80;
info.options = {};
info.options.host = info.parsedUrl.hostname;
info.options.port = info.parsedUrl.port
? parseInt(info.parsedUrl.port)
: defaultPort;
info.options.path =
(info.parsedUrl.pathname || '') + (info.parsedUrl.search || '');
info.options.method = method;
info.options.headers = this._mergeHeaders(headers);
if (this.userAgent != null) {
info.options.headers['user-agent'] = this.userAgent;
}
info.options.agent = this._getAgent(info.parsedUrl);
// gives handlers an opportunity to participate
if (this.handlers) {
2022-05-31 14:18:28 -04:00
for (const handler of this.handlers) {
2021-09-26 15:31:45 -04:00
handler.prepareRequest(info.options);
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
}
return info;
}
_mergeHeaders(headers) {
if (this.requestOptions && this.requestOptions.headers) {
2022-05-31 14:18:28 -04:00
return Object.assign({}, lowercaseKeys(this.requestOptions.headers), lowercaseKeys(headers || {}));
2021-09-26 15:31:45 -04:00
}
return lowercaseKeys(headers || {});
}
_getExistingOrDefaultHeader(additionalHeaders, header, _default) {
let clientHeader;
if (this.requestOptions && this.requestOptions.headers) {
clientHeader = lowercaseKeys(this.requestOptions.headers)[header];
}
return additionalHeaders[header] || clientHeader || _default;
}
_getAgent(parsedUrl) {
let agent;
2022-05-31 14:18:28 -04:00
const proxyUrl = pm.getProxyUrl(parsedUrl);
const useProxy = proxyUrl && proxyUrl.hostname;
2021-09-26 15:31:45 -04:00
if (this._keepAlive && useProxy) {
agent = this._proxyAgent;
}
if (this._keepAlive && !useProxy) {
agent = this._agent;
}
// if agent is already assigned use that agent.
2022-05-31 14:18:28 -04:00
if (agent) {
2021-09-26 15:31:45 -04:00
return agent;
}
const usingSsl = parsedUrl.protocol === 'https:';
let maxSockets = 100;
2022-05-31 14:18:28 -04:00
if (this.requestOptions) {
2021-09-26 15:31:45 -04:00
maxSockets = this.requestOptions.maxSockets || http.globalAgent.maxSockets;
}
2022-05-31 14:18:28 -04:00
// This is `useProxy` again, but we need to check `proxyURl` directly for TypeScripts's flow analysis.
if (proxyUrl && proxyUrl.hostname) {
2021-09-26 15:31:45 -04:00
const agentOptions = {
2022-05-31 14:18:28 -04:00
maxSockets,
2021-09-26 15:31:45 -04:00
keepAlive: this._keepAlive,
2022-05-31 14:18:28 -04:00
proxy: Object.assign(Object.assign({}, ((proxyUrl.username || proxyUrl.password) && {
proxyAuth: `${proxyUrl.username}:${proxyUrl.password}`
})), { host: proxyUrl.hostname, port: proxyUrl.port })
2021-09-26 15:31:45 -04:00
};
let tunnelAgent;
const overHttps = proxyUrl.protocol === 'https:';
if (usingSsl) {
tunnelAgent = overHttps ? tunnel.httpsOverHttps : tunnel.httpsOverHttp;
}
else {
tunnelAgent = overHttps ? tunnel.httpOverHttps : tunnel.httpOverHttp;
}
agent = tunnelAgent(agentOptions);
this._proxyAgent = agent;
}
// if reusing agent across request and tunneling agent isn't assigned create a new agent
if (this._keepAlive && !agent) {
2022-05-31 14:18:28 -04:00
const options = { keepAlive: this._keepAlive, maxSockets };
2021-09-26 15:31:45 -04:00
agent = usingSsl ? new https.Agent(options) : new http.Agent(options);
this._agent = agent;
}
// if not using private agent and tunnel agent isn't setup then use global agent
if (!agent) {
agent = usingSsl ? https.globalAgent : http.globalAgent;
}
if (usingSsl && this._ignoreSslError) {
// we don't want to set NODE_TLS_REJECT_UNAUTHORIZED=0 since that will affect request for entire process
// http.RequestOptions doesn't expose a way to modify RequestOptions.agent.options
// we have to cast it to any and change it directly
agent.options = Object.assign(agent.options || {}, {
rejectUnauthorized: false
});
}
return agent;
}
_performExponentialBackoff(retryNumber) {
2022-05-31 14:18:28 -04:00
return __awaiter(this, void 0, void 0, function* () {
retryNumber = Math.min(ExponentialBackoffCeiling, retryNumber);
const ms = ExponentialBackoffTimeSlice * Math.pow(2, retryNumber);
return new Promise(resolve => setTimeout(() => resolve(), ms));
});
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_processResponse(res, options) {
return __awaiter(this, void 0, void 0, function* () {
return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {
const statusCode = res.message.statusCode || 0;
const response = {
statusCode,
result: null,
headers: {}
};
// not found leads to null obj returned
if (statusCode === HttpCodes.NotFound) {
resolve(response);
}
// get the result from the body
function dateTimeDeserializer(key, value) {
if (typeof value === 'string') {
const a = new Date(value);
if (!isNaN(a.valueOf())) {
return a;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return value;
}
let obj;
let contents;
try {
contents = yield res.readBody();
if (contents && contents.length > 0) {
if (options && options.deserializeDates) {
obj = JSON.parse(contents, dateTimeDeserializer);
}
else {
obj = JSON.parse(contents);
}
response.result = obj;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
response.headers = res.message.headers;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
catch (err) {
// Invalid resource (contents not json); leaving result obj null
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
// note that 3xx redirects are handled by the http layer.
if (statusCode > 299) {
let msg;
// if exception/error in body, attempt to get better error
if (obj && obj.message) {
msg = obj.message;
}
else if (contents && contents.length > 0) {
// it may be the case that the exception is in the body message as string
msg = contents;
}
else {
msg = `Failed request: (${statusCode})`;
}
const err = new HttpClientError(msg, statusCode);
err.result = response.result;
reject(err);
2021-09-26 15:31:45 -04:00
}
else {
2022-05-31 14:18:28 -04:00
resolve(response);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}));
2021-09-26 15:31:45 -04:00
});
}
}
exports.HttpClient = HttpClient;
2022-05-31 14:18:28 -04:00
const lowercaseKeys = (obj) => Object.keys(obj).reduce((c, k) => ((c[k.toLowerCase()] = obj[k]), c), {});
//# sourceMappingURL=index.js.map
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 9835:
2021-09-26 15:31:45 -04:00
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
2022-05-31 14:18:28 -04:00
exports.checkBypass = exports.getProxyUrl = void 0;
2021-09-26 15:31:45 -04:00
function getProxyUrl(reqUrl) {
2022-05-31 14:18:28 -04:00
const usingSsl = reqUrl.protocol === 'https:';
2021-09-26 15:31:45 -04:00
if (checkBypass(reqUrl)) {
2022-05-31 14:18:28 -04:00
return undefined;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
const proxyVar = (() => {
if (usingSsl) {
return process.env['https_proxy'] || process.env['HTTPS_PROXY'];
}
else {
return process.env['http_proxy'] || process.env['HTTP_PROXY'];
}
})();
if (proxyVar) {
return new URL(proxyVar);
2021-09-26 15:31:45 -04:00
}
else {
2022-05-31 14:18:28 -04:00
return undefined;
2021-09-26 15:31:45 -04:00
}
}
exports.getProxyUrl = getProxyUrl;
function checkBypass(reqUrl) {
if (!reqUrl.hostname) {
return false;
}
2022-05-31 14:18:28 -04:00
const noProxy = process.env['no_proxy'] || process.env['NO_PROXY'] || '';
2021-09-26 15:31:45 -04:00
if (!noProxy) {
return false;
}
// Determine the request port
let reqPort;
if (reqUrl.port) {
reqPort = Number(reqUrl.port);
}
else if (reqUrl.protocol === 'http:') {
reqPort = 80;
}
else if (reqUrl.protocol === 'https:') {
reqPort = 443;
}
// Format the request hostname and hostname with port
2022-05-31 14:18:28 -04:00
const upperReqHosts = [reqUrl.hostname.toUpperCase()];
2021-09-26 15:31:45 -04:00
if (typeof reqPort === 'number') {
upperReqHosts.push(`${upperReqHosts[0]}:${reqPort}`);
}
// Compare request host against noproxy
2022-05-31 14:18:28 -04:00
for (const upperNoProxyItem of noProxy
2021-09-26 15:31:45 -04:00
.split(',')
.map(x => x.trim().toUpperCase())
.filter(x => x)) {
if (upperReqHosts.some(x => x === upperNoProxyItem)) {
return true;
}
}
return false;
}
exports.checkBypass = checkBypass;
2022-05-31 14:18:28 -04:00
//# sourceMappingURL=proxy.js.map
2021-09-26 15:31:45 -04:00
/***/ }),
/***/ 3803:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.createFileSystemAdapter = exports.FILE_SYSTEM_ADAPTER = void 0;
2022-05-31 14:18:28 -04:00
const fs = __nccwpck_require__(7147);
2021-09-26 15:31:45 -04:00
exports.FILE_SYSTEM_ADAPTER = {
lstat: fs.lstat,
stat: fs.stat,
lstatSync: fs.lstatSync,
statSync: fs.statSync,
readdir: fs.readdir,
readdirSync: fs.readdirSync
};
function createFileSystemAdapter(fsMethods) {
if (fsMethods === undefined) {
return exports.FILE_SYSTEM_ADAPTER;
}
return Object.assign(Object.assign({}, exports.FILE_SYSTEM_ADAPTER), fsMethods);
}
exports.createFileSystemAdapter = createFileSystemAdapter;
/***/ }),
/***/ 8838:
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.IS_SUPPORT_READDIR_WITH_FILE_TYPES = void 0;
const NODE_PROCESS_VERSION_PARTS = process.versions.node.split('.');
if (NODE_PROCESS_VERSION_PARTS[0] === undefined || NODE_PROCESS_VERSION_PARTS[1] === undefined) {
throw new Error(`Unexpected behavior. The 'process.versions.node' variable has invalid value: ${process.versions.node}`);
}
const MAJOR_VERSION = Number.parseInt(NODE_PROCESS_VERSION_PARTS[0], 10);
const MINOR_VERSION = Number.parseInt(NODE_PROCESS_VERSION_PARTS[1], 10);
const SUPPORTED_MAJOR_VERSION = 10;
const SUPPORTED_MINOR_VERSION = 10;
const IS_MATCHED_BY_MAJOR = MAJOR_VERSION > SUPPORTED_MAJOR_VERSION;
const IS_MATCHED_BY_MAJOR_AND_MINOR = MAJOR_VERSION === SUPPORTED_MAJOR_VERSION && MINOR_VERSION >= SUPPORTED_MINOR_VERSION;
/**
* IS `true` for Node.js 10.10 and greater.
*/
exports.IS_SUPPORT_READDIR_WITH_FILE_TYPES = IS_MATCHED_BY_MAJOR || IS_MATCHED_BY_MAJOR_AND_MINOR;
/***/ }),
/***/ 5667:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.Settings = exports.scandirSync = exports.scandir = void 0;
const async = __nccwpck_require__(4507);
const sync = __nccwpck_require__(9560);
const settings_1 = __nccwpck_require__(8662);
exports.Settings = settings_1.default;
function scandir(path, optionsOrSettingsOrCallback, callback) {
if (typeof optionsOrSettingsOrCallback === 'function') {
async.read(path, getSettings(), optionsOrSettingsOrCallback);
return;
}
async.read(path, getSettings(optionsOrSettingsOrCallback), callback);
}
exports.scandir = scandir;
function scandirSync(path, optionsOrSettings) {
const settings = getSettings(optionsOrSettings);
return sync.read(path, settings);
}
exports.scandirSync = scandirSync;
function getSettings(settingsOrOptions = {}) {
if (settingsOrOptions instanceof settings_1.default) {
return settingsOrOptions;
}
return new settings_1.default(settingsOrOptions);
}
/***/ }),
/***/ 4507:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.readdir = exports.readdirWithFileTypes = exports.read = void 0;
const fsStat = __nccwpck_require__(109);
const rpl = __nccwpck_require__(5288);
const constants_1 = __nccwpck_require__(8838);
const utils = __nccwpck_require__(6297);
const common = __nccwpck_require__(3847);
function read(directory, settings, callback) {
if (!settings.stats && constants_1.IS_SUPPORT_READDIR_WITH_FILE_TYPES) {
readdirWithFileTypes(directory, settings, callback);
return;
}
readdir(directory, settings, callback);
}
exports.read = read;
function readdirWithFileTypes(directory, settings, callback) {
settings.fs.readdir(directory, { withFileTypes: true }, (readdirError, dirents) => {
if (readdirError !== null) {
callFailureCallback(callback, readdirError);
return;
}
const entries = dirents.map((dirent) => ({
dirent,
name: dirent.name,
path: common.joinPathSegments(directory, dirent.name, settings.pathSegmentSeparator)
}));
if (!settings.followSymbolicLinks) {
callSuccessCallback(callback, entries);
return;
}
const tasks = entries.map((entry) => makeRplTaskEntry(entry, settings));
rpl(tasks, (rplError, rplEntries) => {
if (rplError !== null) {
callFailureCallback(callback, rplError);
return;
}
callSuccessCallback(callback, rplEntries);
});
});
}
exports.readdirWithFileTypes = readdirWithFileTypes;
function makeRplTaskEntry(entry, settings) {
return (done) => {
if (!entry.dirent.isSymbolicLink()) {
done(null, entry);
return;
}
settings.fs.stat(entry.path, (statError, stats) => {
if (statError !== null) {
if (settings.throwErrorOnBrokenSymbolicLink) {
done(statError);
return;
}
done(null, entry);
return;
}
entry.dirent = utils.fs.createDirentFromStats(entry.name, stats);
done(null, entry);
});
};
}
function readdir(directory, settings, callback) {
settings.fs.readdir(directory, (readdirError, names) => {
if (readdirError !== null) {
callFailureCallback(callback, readdirError);
return;
}
const tasks = names.map((name) => {
const path = common.joinPathSegments(directory, name, settings.pathSegmentSeparator);
return (done) => {
fsStat.stat(path, settings.fsStatSettings, (error, stats) => {
if (error !== null) {
done(error);
return;
}
const entry = {
name,
path,
dirent: utils.fs.createDirentFromStats(name, stats)
};
if (settings.stats) {
entry.stats = stats;
}
done(null, entry);
});
};
});
rpl(tasks, (rplError, entries) => {
if (rplError !== null) {
callFailureCallback(callback, rplError);
return;
}
callSuccessCallback(callback, entries);
});
});
}
exports.readdir = readdir;
function callFailureCallback(callback, error) {
callback(error);
}
function callSuccessCallback(callback, result) {
callback(null, result);
}
/***/ }),
/***/ 3847:
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.joinPathSegments = void 0;
function joinPathSegments(a, b, separator) {
/**
* The correct handling of cases when the first segment is a root (`/`, `C:/`) or UNC path (`//?/C:/`).
*/
if (a.endsWith(separator)) {
return a + b;
}
return a + separator + b;
}
exports.joinPathSegments = joinPathSegments;
/***/ }),
/***/ 9560:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.readdir = exports.readdirWithFileTypes = exports.read = void 0;
const fsStat = __nccwpck_require__(109);
const constants_1 = __nccwpck_require__(8838);
const utils = __nccwpck_require__(6297);
const common = __nccwpck_require__(3847);
function read(directory, settings) {
if (!settings.stats && constants_1.IS_SUPPORT_READDIR_WITH_FILE_TYPES) {
return readdirWithFileTypes(directory, settings);
}
return readdir(directory, settings);
}
exports.read = read;
function readdirWithFileTypes(directory, settings) {
const dirents = settings.fs.readdirSync(directory, { withFileTypes: true });
return dirents.map((dirent) => {
const entry = {
dirent,
name: dirent.name,
path: common.joinPathSegments(directory, dirent.name, settings.pathSegmentSeparator)
};
if (entry.dirent.isSymbolicLink() && settings.followSymbolicLinks) {
try {
const stats = settings.fs.statSync(entry.path);
entry.dirent = utils.fs.createDirentFromStats(entry.name, stats);
}
catch (error) {
if (settings.throwErrorOnBrokenSymbolicLink) {
throw error;
}
}
}
return entry;
});
}
exports.readdirWithFileTypes = readdirWithFileTypes;
function readdir(directory, settings) {
const names = settings.fs.readdirSync(directory);
return names.map((name) => {
const entryPath = common.joinPathSegments(directory, name, settings.pathSegmentSeparator);
const stats = fsStat.statSync(entryPath, settings.fsStatSettings);
const entry = {
name,
path: entryPath,
dirent: utils.fs.createDirentFromStats(name, stats)
};
if (settings.stats) {
entry.stats = stats;
}
return entry;
});
}
exports.readdir = readdir;
/***/ }),
/***/ 8662:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
2022-05-31 14:18:28 -04:00
const path = __nccwpck_require__(1017);
2021-09-26 15:31:45 -04:00
const fsStat = __nccwpck_require__(109);
const fs = __nccwpck_require__(3803);
class Settings {
constructor(_options = {}) {
this._options = _options;
this.followSymbolicLinks = this._getValue(this._options.followSymbolicLinks, false);
this.fs = fs.createFileSystemAdapter(this._options.fs);
this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path.sep);
this.stats = this._getValue(this._options.stats, false);
this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, true);
this.fsStatSettings = new fsStat.Settings({
followSymbolicLink: this.followSymbolicLinks,
fs: this.fs,
throwErrorOnBrokenSymbolicLink: this.throwErrorOnBrokenSymbolicLink
});
}
_getValue(option, value) {
return option !== null && option !== void 0 ? option : value;
}
}
2022-05-31 14:18:28 -04:00
exports["default"] = Settings;
2021-09-26 15:31:45 -04:00
/***/ }),
/***/ 883:
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.createDirentFromStats = void 0;
class DirentFromStats {
constructor(name, stats) {
this.name = name;
this.isBlockDevice = stats.isBlockDevice.bind(stats);
this.isCharacterDevice = stats.isCharacterDevice.bind(stats);
this.isDirectory = stats.isDirectory.bind(stats);
this.isFIFO = stats.isFIFO.bind(stats);
this.isFile = stats.isFile.bind(stats);
this.isSocket = stats.isSocket.bind(stats);
this.isSymbolicLink = stats.isSymbolicLink.bind(stats);
}
}
function createDirentFromStats(name, stats) {
return new DirentFromStats(name, stats);
}
exports.createDirentFromStats = createDirentFromStats;
/***/ }),
/***/ 6297:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.fs = void 0;
const fs = __nccwpck_require__(883);
exports.fs = fs;
/***/ }),
/***/ 2987:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.createFileSystemAdapter = exports.FILE_SYSTEM_ADAPTER = void 0;
2022-05-31 14:18:28 -04:00
const fs = __nccwpck_require__(7147);
2021-09-26 15:31:45 -04:00
exports.FILE_SYSTEM_ADAPTER = {
lstat: fs.lstat,
stat: fs.stat,
lstatSync: fs.lstatSync,
statSync: fs.statSync
};
function createFileSystemAdapter(fsMethods) {
if (fsMethods === undefined) {
return exports.FILE_SYSTEM_ADAPTER;
}
return Object.assign(Object.assign({}, exports.FILE_SYSTEM_ADAPTER), fsMethods);
}
exports.createFileSystemAdapter = createFileSystemAdapter;
/***/ }),
/***/ 109:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.statSync = exports.stat = exports.Settings = void 0;
const async = __nccwpck_require__(4147);
const sync = __nccwpck_require__(4527);
const settings_1 = __nccwpck_require__(2410);
exports.Settings = settings_1.default;
function stat(path, optionsOrSettingsOrCallback, callback) {
if (typeof optionsOrSettingsOrCallback === 'function') {
async.read(path, getSettings(), optionsOrSettingsOrCallback);
return;
}
async.read(path, getSettings(optionsOrSettingsOrCallback), callback);
}
exports.stat = stat;
function statSync(path, optionsOrSettings) {
const settings = getSettings(optionsOrSettings);
return sync.read(path, settings);
}
exports.statSync = statSync;
function getSettings(settingsOrOptions = {}) {
if (settingsOrOptions instanceof settings_1.default) {
return settingsOrOptions;
}
return new settings_1.default(settingsOrOptions);
}
/***/ }),
/***/ 4147:
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.read = void 0;
function read(path, settings, callback) {
settings.fs.lstat(path, (lstatError, lstat) => {
if (lstatError !== null) {
callFailureCallback(callback, lstatError);
return;
}
if (!lstat.isSymbolicLink() || !settings.followSymbolicLink) {
callSuccessCallback(callback, lstat);
return;
}
settings.fs.stat(path, (statError, stat) => {
if (statError !== null) {
if (settings.throwErrorOnBrokenSymbolicLink) {
callFailureCallback(callback, statError);
return;
}
callSuccessCallback(callback, lstat);
return;
}
if (settings.markSymbolicLink) {
stat.isSymbolicLink = () => true;
}
callSuccessCallback(callback, stat);
});
});
}
exports.read = read;
function callFailureCallback(callback, error) {
callback(error);
}
function callSuccessCallback(callback, result) {
callback(null, result);
}
/***/ }),
/***/ 4527:
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.read = void 0;
function read(path, settings) {
const lstat = settings.fs.lstatSync(path);
if (!lstat.isSymbolicLink() || !settings.followSymbolicLink) {
return lstat;
}
try {
const stat = settings.fs.statSync(path);
if (settings.markSymbolicLink) {
stat.isSymbolicLink = () => true;
}
return stat;
}
catch (error) {
if (!settings.throwErrorOnBrokenSymbolicLink) {
return lstat;
}
throw error;
}
}
exports.read = read;
/***/ }),
/***/ 2410:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
const fs = __nccwpck_require__(2987);
class Settings {
constructor(_options = {}) {
this._options = _options;
this.followSymbolicLink = this._getValue(this._options.followSymbolicLink, true);
this.fs = fs.createFileSystemAdapter(this._options.fs);
this.markSymbolicLink = this._getValue(this._options.markSymbolicLink, false);
this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, true);
}
_getValue(option, value) {
return option !== null && option !== void 0 ? option : value;
}
}
2022-05-31 14:18:28 -04:00
exports["default"] = Settings;
2021-09-26 15:31:45 -04:00
/***/ }),
/***/ 6026:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.Settings = exports.walkStream = exports.walkSync = exports.walk = void 0;
const async_1 = __nccwpck_require__(7523);
const stream_1 = __nccwpck_require__(6737);
const sync_1 = __nccwpck_require__(3068);
const settings_1 = __nccwpck_require__(141);
exports.Settings = settings_1.default;
function walk(directory, optionsOrSettingsOrCallback, callback) {
if (typeof optionsOrSettingsOrCallback === 'function') {
new async_1.default(directory, getSettings()).read(optionsOrSettingsOrCallback);
return;
}
new async_1.default(directory, getSettings(optionsOrSettingsOrCallback)).read(callback);
}
exports.walk = walk;
function walkSync(directory, optionsOrSettings) {
const settings = getSettings(optionsOrSettings);
const provider = new sync_1.default(directory, settings);
return provider.read();
}
exports.walkSync = walkSync;
function walkStream(directory, optionsOrSettings) {
const settings = getSettings(optionsOrSettings);
const provider = new stream_1.default(directory, settings);
return provider.read();
}
exports.walkStream = walkStream;
function getSettings(settingsOrOptions = {}) {
if (settingsOrOptions instanceof settings_1.default) {
return settingsOrOptions;
}
return new settings_1.default(settingsOrOptions);
}
/***/ }),
/***/ 7523:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
const async_1 = __nccwpck_require__(5732);
class AsyncProvider {
constructor(_root, _settings) {
this._root = _root;
this._settings = _settings;
this._reader = new async_1.default(this._root, this._settings);
this._storage = [];
}
read(callback) {
this._reader.onError((error) => {
callFailureCallback(callback, error);
});
this._reader.onEntry((entry) => {
this._storage.push(entry);
});
this._reader.onEnd(() => {
callSuccessCallback(callback, this._storage);
});
this._reader.read();
}
}
2022-05-31 14:18:28 -04:00
exports["default"] = AsyncProvider;
2021-09-26 15:31:45 -04:00
function callFailureCallback(callback, error) {
callback(error);
}
function callSuccessCallback(callback, entries) {
callback(null, entries);
}
/***/ }),
/***/ 6737:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
2022-05-31 14:18:28 -04:00
const stream_1 = __nccwpck_require__(2781);
2021-09-26 15:31:45 -04:00
const async_1 = __nccwpck_require__(5732);
class StreamProvider {
constructor(_root, _settings) {
this._root = _root;
this._settings = _settings;
this._reader = new async_1.default(this._root, this._settings);
this._stream = new stream_1.Readable({
objectMode: true,
read: () => { },
destroy: () => {
if (!this._reader.isDestroyed) {
this._reader.destroy();
}
}
});
}
read() {
this._reader.onError((error) => {
this._stream.emit('error', error);
});
this._reader.onEntry((entry) => {
this._stream.push(entry);
});
this._reader.onEnd(() => {
this._stream.push(null);
});
this._reader.read();
return this._stream;
}
}
2022-05-31 14:18:28 -04:00
exports["default"] = StreamProvider;
2021-09-26 15:31:45 -04:00
/***/ }),
/***/ 3068:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
const sync_1 = __nccwpck_require__(3595);
class SyncProvider {
constructor(_root, _settings) {
this._root = _root;
this._settings = _settings;
this._reader = new sync_1.default(this._root, this._settings);
}
read() {
return this._reader.read();
}
}
2022-05-31 14:18:28 -04:00
exports["default"] = SyncProvider;
2021-09-26 15:31:45 -04:00
/***/ }),
/***/ 5732:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
2022-05-31 14:18:28 -04:00
const events_1 = __nccwpck_require__(2361);
2021-09-26 15:31:45 -04:00
const fsScandir = __nccwpck_require__(5667);
const fastq = __nccwpck_require__(7340);
const common = __nccwpck_require__(7988);
const reader_1 = __nccwpck_require__(8311);
class AsyncReader extends reader_1.default {
constructor(_root, _settings) {
super(_root, _settings);
this._settings = _settings;
this._scandir = fsScandir.scandir;
this._emitter = new events_1.EventEmitter();
this._queue = fastq(this._worker.bind(this), this._settings.concurrency);
this._isFatalError = false;
this._isDestroyed = false;
this._queue.drain = () => {
if (!this._isFatalError) {
this._emitter.emit('end');
}
};
}
read() {
this._isFatalError = false;
this._isDestroyed = false;
setImmediate(() => {
this._pushToQueue(this._root, this._settings.basePath);
});
return this._emitter;
}
get isDestroyed() {
return this._isDestroyed;
}
destroy() {
if (this._isDestroyed) {
throw new Error('The reader is already destroyed');
}
this._isDestroyed = true;
this._queue.killAndDrain();
}
onEntry(callback) {
this._emitter.on('entry', callback);
}
onError(callback) {
this._emitter.once('error', callback);
}
onEnd(callback) {
this._emitter.once('end', callback);
}
_pushToQueue(directory, base) {
const queueItem = { directory, base };
this._queue.push(queueItem, (error) => {
if (error !== null) {
this._handleError(error);
}
});
}
_worker(item, done) {
this._scandir(item.directory, this._settings.fsScandirSettings, (error, entries) => {
if (error !== null) {
done(error, undefined);
return;
}
for (const entry of entries) {
this._handleEntry(entry, item.base);
}
done(null, undefined);
});
}
_handleError(error) {
if (this._isDestroyed || !common.isFatalError(this._settings, error)) {
return;
}
this._isFatalError = true;
this._isDestroyed = true;
this._emitter.emit('error', error);
}
_handleEntry(entry, base) {
if (this._isDestroyed || this._isFatalError) {
return;
}
const fullpath = entry.path;
if (base !== undefined) {
entry.path = common.joinPathSegments(base, entry.name, this._settings.pathSegmentSeparator);
}
if (common.isAppliedFilter(this._settings.entryFilter, entry)) {
this._emitEntry(entry);
}
if (entry.dirent.isDirectory() && common.isAppliedFilter(this._settings.deepFilter, entry)) {
this._pushToQueue(fullpath, base === undefined ? undefined : entry.path);
}
}
_emitEntry(entry) {
this._emitter.emit('entry', entry);
}
}
2022-05-31 14:18:28 -04:00
exports["default"] = AsyncReader;
2021-09-26 15:31:45 -04:00
/***/ }),
/***/ 7988:
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.joinPathSegments = exports.replacePathSegmentSeparator = exports.isAppliedFilter = exports.isFatalError = void 0;
function isFatalError(settings, error) {
if (settings.errorFilter === null) {
return true;
}
return !settings.errorFilter(error);
}
exports.isFatalError = isFatalError;
function isAppliedFilter(filter, value) {
return filter === null || filter(value);
}
exports.isAppliedFilter = isAppliedFilter;
function replacePathSegmentSeparator(filepath, separator) {
return filepath.split(/[/\\]/).join(separator);
}
exports.replacePathSegmentSeparator = replacePathSegmentSeparator;
function joinPathSegments(a, b, separator) {
if (a === '') {
return b;
}
/**
* The correct handling of cases when the first segment is a root (`/`, `C:/`) or UNC path (`//?/C:/`).
*/
if (a.endsWith(separator)) {
return a + b;
}
return a + separator + b;
}
exports.joinPathSegments = joinPathSegments;
/***/ }),
/***/ 8311:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
const common = __nccwpck_require__(7988);
class Reader {
constructor(_root, _settings) {
this._root = _root;
this._settings = _settings;
this._root = common.replacePathSegmentSeparator(_root, _settings.pathSegmentSeparator);
}
}
2022-05-31 14:18:28 -04:00
exports["default"] = Reader;
2021-09-26 15:31:45 -04:00
/***/ }),
/***/ 3595:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
const fsScandir = __nccwpck_require__(5667);
const common = __nccwpck_require__(7988);
const reader_1 = __nccwpck_require__(8311);
class SyncReader extends reader_1.default {
constructor() {
super(...arguments);
this._scandir = fsScandir.scandirSync;
this._storage = [];
this._queue = new Set();
}
read() {
this._pushToQueue(this._root, this._settings.basePath);
this._handleQueue();
return this._storage;
}
_pushToQueue(directory, base) {
this._queue.add({ directory, base });
}
_handleQueue() {
for (const item of this._queue.values()) {
this._handleDirectory(item.directory, item.base);
}
}
_handleDirectory(directory, base) {
try {
const entries = this._scandir(directory, this._settings.fsScandirSettings);
for (const entry of entries) {
this._handleEntry(entry, base);
}
}
catch (error) {
this._handleError(error);
}
}
_handleError(error) {
if (!common.isFatalError(this._settings, error)) {
return;
}
throw error;
}
_handleEntry(entry, base) {
const fullpath = entry.path;
if (base !== undefined) {
entry.path = common.joinPathSegments(base, entry.name, this._settings.pathSegmentSeparator);
}
if (common.isAppliedFilter(this._settings.entryFilter, entry)) {
this._pushToStorage(entry);
}
if (entry.dirent.isDirectory() && common.isAppliedFilter(this._settings.deepFilter, entry)) {
this._pushToQueue(fullpath, base === undefined ? undefined : entry.path);
}
}
_pushToStorage(entry) {
this._storage.push(entry);
}
}
2022-05-31 14:18:28 -04:00
exports["default"] = SyncReader;
2021-09-26 15:31:45 -04:00
/***/ }),
/***/ 141:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
2022-05-31 14:18:28 -04:00
const path = __nccwpck_require__(1017);
2021-09-26 15:31:45 -04:00
const fsScandir = __nccwpck_require__(5667);
class Settings {
constructor(_options = {}) {
this._options = _options;
this.basePath = this._getValue(this._options.basePath, undefined);
this.concurrency = this._getValue(this._options.concurrency, Number.POSITIVE_INFINITY);
this.deepFilter = this._getValue(this._options.deepFilter, null);
this.entryFilter = this._getValue(this._options.entryFilter, null);
this.errorFilter = this._getValue(this._options.errorFilter, null);
this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path.sep);
this.fsScandirSettings = new fsScandir.Settings({
followSymbolicLinks: this._options.followSymbolicLinks,
fs: this._options.fs,
pathSegmentSeparator: this._options.pathSegmentSeparator,
stats: this._options.stats,
throwErrorOnBrokenSymbolicLink: this._options.throwErrorOnBrokenSymbolicLink
});
}
_getValue(option, value) {
return option !== null && option !== void 0 ? option : value;
}
}
2022-05-31 14:18:28 -04:00
exports["default"] = Settings;
2021-09-26 15:31:45 -04:00
/***/ }),
/***/ 334:
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
const REGEX_IS_INSTALLATION_LEGACY = /^v1\./;
const REGEX_IS_INSTALLATION = /^ghs_/;
const REGEX_IS_USER_TO_SERVER = /^ghu_/;
async function auth(token) {
const isApp = token.split(/\./).length === 3;
const isInstallation = REGEX_IS_INSTALLATION_LEGACY.test(token) || REGEX_IS_INSTALLATION.test(token);
const isUserToServer = REGEX_IS_USER_TO_SERVER.test(token);
const tokenType = isApp ? "app" : isInstallation ? "installation" : isUserToServer ? "user-to-server" : "oauth";
return {
type: "token",
token: token,
tokenType
};
}
/**
* Prefix token for usage in the Authorization header
*
* @param token OAuth token or JSON Web Token
*/
function withAuthorizationPrefix(token) {
if (token.split(/\./).length === 3) {
return `bearer ${token}`;
}
return `token ${token}`;
}
async function hook(token, request, route, parameters) {
const endpoint = request.endpoint.merge(route, parameters);
endpoint.headers.authorization = withAuthorizationPrefix(token);
return request(endpoint);
}
const createTokenAuth = function createTokenAuth(token) {
if (!token) {
throw new Error("[@octokit/auth-token] No token passed to createTokenAuth");
}
if (typeof token !== "string") {
throw new Error("[@octokit/auth-token] Token passed to createTokenAuth is not a string");
}
token = token.replace(/^(token|bearer) +/i, "");
return Object.assign(auth.bind(null, token), {
hook: hook.bind(null, token)
});
};
exports.createTokenAuth = createTokenAuth;
//# sourceMappingURL=index.js.map
/***/ }),
/***/ 6762:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
var universalUserAgent = __nccwpck_require__(5030);
var beforeAfterHook = __nccwpck_require__(3682);
2021-10-01 09:38:36 -04:00
var request = __nccwpck_require__(5712);
2021-09-26 15:31:45 -04:00
var graphql = __nccwpck_require__(8467);
var authToken = __nccwpck_require__(334);
function _objectWithoutPropertiesLoose(source, excluded) {
if (source == null) return {};
var target = {};
var sourceKeys = Object.keys(source);
var key, i;
for (i = 0; i < sourceKeys.length; i++) {
key = sourceKeys[i];
if (excluded.indexOf(key) >= 0) continue;
target[key] = source[key];
}
return target;
}
function _objectWithoutProperties(source, excluded) {
if (source == null) return {};
var target = _objectWithoutPropertiesLoose(source, excluded);
var key, i;
if (Object.getOwnPropertySymbols) {
var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
for (i = 0; i < sourceSymbolKeys.length; i++) {
key = sourceSymbolKeys[i];
if (excluded.indexOf(key) >= 0) continue;
if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
target[key] = source[key];
}
}
return target;
}
2022-05-31 14:18:28 -04:00
const VERSION = "3.6.0";
2021-09-26 15:31:45 -04:00
const _excluded = ["authStrategy"];
class Octokit {
constructor(options = {}) {
const hook = new beforeAfterHook.Collection();
const requestDefaults = {
baseUrl: request.request.endpoint.DEFAULTS.baseUrl,
headers: {},
request: Object.assign({}, options.request, {
// @ts-ignore internal usage only, no need to type
hook: hook.bind(null, "request")
}),
mediaType: {
previews: [],
format: ""
}
}; // prepend default user agent with `options.userAgent` if set
requestDefaults.headers["user-agent"] = [options.userAgent, `octokit-core.js/${VERSION} ${universalUserAgent.getUserAgent()}`].filter(Boolean).join(" ");
if (options.baseUrl) {
requestDefaults.baseUrl = options.baseUrl;
}
if (options.previews) {
requestDefaults.mediaType.previews = options.previews;
}
if (options.timeZone) {
requestDefaults.headers["time-zone"] = options.timeZone;
}
this.request = request.request.defaults(requestDefaults);
this.graphql = graphql.withCustomRequest(this.request).defaults(requestDefaults);
this.log = Object.assign({
debug: () => {},
info: () => {},
warn: console.warn.bind(console),
error: console.error.bind(console)
}, options.log);
this.hook = hook; // (1) If neither `options.authStrategy` nor `options.auth` are set, the `octokit` instance
// is unauthenticated. The `this.auth()` method is a no-op and no request hook is registered.
// (2) If only `options.auth` is set, use the default token authentication strategy.
// (3) If `options.authStrategy` is set then use it and pass in `options.auth`. Always pass own request as many strategies accept a custom request instance.
// TODO: type `options.auth` based on `options.authStrategy`.
if (!options.authStrategy) {
if (!options.auth) {
// (1)
this.auth = async () => ({
type: "unauthenticated"
});
} else {
// (2)
const auth = authToken.createTokenAuth(options.auth); // @ts-ignore ¯\_(ツ)_/¯
hook.wrap("request", auth.hook);
this.auth = auth;
}
} else {
const {
authStrategy
} = options,
otherOptions = _objectWithoutProperties(options, _excluded);
const auth = authStrategy(Object.assign({
request: this.request,
log: this.log,
// we pass the current octokit instance as well as its constructor options
// to allow for authentication strategies that return a new octokit instance
// that shares the same internal state as the current one. The original
// requirement for this was the "event-octokit" authentication strategy
// of https://github.com/probot/octokit-auth-probot.
octokit: this,
octokitOptions: otherOptions
}, options.auth)); // @ts-ignore ¯\_(ツ)_/¯
hook.wrap("request", auth.hook);
this.auth = auth;
} // apply plugins
// https://stackoverflow.com/a/16345172
const classConstructor = this.constructor;
classConstructor.plugins.forEach(plugin => {
Object.assign(this, plugin(this, options));
});
}
static defaults(defaults) {
const OctokitWithDefaults = class extends this {
constructor(...args) {
const options = args[0] || {};
if (typeof defaults === "function") {
super(defaults(options));
return;
}
super(Object.assign({}, defaults, options, options.userAgent && defaults.userAgent ? {
userAgent: `${options.userAgent} ${defaults.userAgent}`
} : null));
}
};
return OctokitWithDefaults;
}
/**
* Attach a plugin (or many) to your Octokit instance.
*
* @example
* const API = Octokit.plugin(plugin1, plugin2, plugin3, ...)
*/
static plugin(...newPlugins) {
var _a;
const currentPlugins = this.plugins;
const NewOctokit = (_a = class extends this {}, _a.plugins = currentPlugins.concat(newPlugins.filter(plugin => !currentPlugins.includes(plugin))), _a);
return NewOctokit;
}
}
Octokit.VERSION = VERSION;
Octokit.plugins = [];
exports.Octokit = Octokit;
//# sourceMappingURL=index.js.map
/***/ }),
/***/ 9440:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
var isPlainObject = __nccwpck_require__(3287);
var universalUserAgent = __nccwpck_require__(5030);
function lowercaseKeys(object) {
if (!object) {
return {};
}
return Object.keys(object).reduce((newObj, key) => {
newObj[key.toLowerCase()] = object[key];
return newObj;
}, {});
}
function mergeDeep(defaults, options) {
const result = Object.assign({}, defaults);
Object.keys(options).forEach(key => {
if (isPlainObject.isPlainObject(options[key])) {
if (!(key in defaults)) Object.assign(result, {
[key]: options[key]
});else result[key] = mergeDeep(defaults[key], options[key]);
} else {
Object.assign(result, {
[key]: options[key]
});
}
});
return result;
}
function removeUndefinedProperties(obj) {
for (const key in obj) {
if (obj[key] === undefined) {
delete obj[key];
}
}
return obj;
}
function merge(defaults, route, options) {
if (typeof route === "string") {
let [method, url] = route.split(" ");
options = Object.assign(url ? {
method,
url
} : {
url: method
}, options);
} else {
options = Object.assign({}, route);
} // lowercase header names before merging with defaults to avoid duplicates
options.headers = lowercaseKeys(options.headers); // remove properties with undefined values before merging
removeUndefinedProperties(options);
removeUndefinedProperties(options.headers);
const mergedOptions = mergeDeep(defaults || {}, options); // mediaType.previews arrays are merged, instead of overwritten
if (defaults && defaults.mediaType.previews.length) {
mergedOptions.mediaType.previews = defaults.mediaType.previews.filter(preview => !mergedOptions.mediaType.previews.includes(preview)).concat(mergedOptions.mediaType.previews);
}
mergedOptions.mediaType.previews = mergedOptions.mediaType.previews.map(preview => preview.replace(/-preview/, ""));
return mergedOptions;
}
function addQueryParameters(url, parameters) {
const separator = /\?/.test(url) ? "&" : "?";
const names = Object.keys(parameters);
if (names.length === 0) {
return url;
}
return url + separator + names.map(name => {
if (name === "q") {
return "q=" + parameters.q.split("+").map(encodeURIComponent).join("+");
}
return `${name}=${encodeURIComponent(parameters[name])}`;
}).join("&");
}
const urlVariableRegex = /\{[^}]+\}/g;
function removeNonChars(variableName) {
return variableName.replace(/^\W+|\W+$/g, "").split(/,/);
}
function extractUrlVariableNames(url) {
const matches = url.match(urlVariableRegex);
if (!matches) {
return [];
}
return matches.map(removeNonChars).reduce((a, b) => a.concat(b), []);
}
function omit(object, keysToOmit) {
return Object.keys(object).filter(option => !keysToOmit.includes(option)).reduce((obj, key) => {
obj[key] = object[key];
return obj;
}, {});
}
// Based on https://github.com/bramstein/url-template, licensed under BSD
// TODO: create separate package.
//
// Copyright (c) 2012-2014, Bram Stein
// All rights reserved.
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions
// are met:
// 1. Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// 2. Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
// 3. The name of the author may not be used to endorse or promote products
// derived from this software without specific prior written permission.
// THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED
// WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
// EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
// INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
// BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
/* istanbul ignore file */
function encodeReserved(str) {
return str.split(/(%[0-9A-Fa-f]{2})/g).map(function (part) {
if (!/%[0-9A-Fa-f]/.test(part)) {
part = encodeURI(part).replace(/%5B/g, "[").replace(/%5D/g, "]");
}
return part;
}).join("");
}
function encodeUnreserved(str) {
return encodeURIComponent(str).replace(/[!'()*]/g, function (c) {
return "%" + c.charCodeAt(0).toString(16).toUpperCase();
});
}
function encodeValue(operator, value, key) {
value = operator === "+" || operator === "#" ? encodeReserved(value) : encodeUnreserved(value);
if (key) {
return encodeUnreserved(key) + "=" + value;
} else {
return value;
}
}
function isDefined(value) {
return value !== undefined && value !== null;
}
function isKeyOperator(operator) {
return operator === ";" || operator === "&" || operator === "?";
}
function getValues(context, operator, key, modifier) {
var value = context[key],
result = [];
if (isDefined(value) && value !== "") {
if (typeof value === "string" || typeof value === "number" || typeof value === "boolean") {
value = value.toString();
if (modifier && modifier !== "*") {
value = value.substring(0, parseInt(modifier, 10));
}
result.push(encodeValue(operator, value, isKeyOperator(operator) ? key : ""));
} else {
if (modifier === "*") {
if (Array.isArray(value)) {
value.filter(isDefined).forEach(function (value) {
result.push(encodeValue(operator, value, isKeyOperator(operator) ? key : ""));
});
} else {
Object.keys(value).forEach(function (k) {
if (isDefined(value[k])) {
result.push(encodeValue(operator, value[k], k));
}
});
}
} else {
const tmp = [];
if (Array.isArray(value)) {
value.filter(isDefined).forEach(function (value) {
tmp.push(encodeValue(operator, value));
});
} else {
Object.keys(value).forEach(function (k) {
if (isDefined(value[k])) {
tmp.push(encodeUnreserved(k));
tmp.push(encodeValue(operator, value[k].toString()));
}
});
}
if (isKeyOperator(operator)) {
result.push(encodeUnreserved(key) + "=" + tmp.join(","));
} else if (tmp.length !== 0) {
result.push(tmp.join(","));
}
}
}
} else {
if (operator === ";") {
if (isDefined(value)) {
result.push(encodeUnreserved(key));
}
} else if (value === "" && (operator === "&" || operator === "?")) {
result.push(encodeUnreserved(key) + "=");
} else if (value === "") {
result.push("");
}
}
return result;
}
function parseUrl(template) {
return {
expand: expand.bind(null, template)
};
}
function expand(template, context) {
var operators = ["+", "#", ".", "/", ";", "?", "&"];
return template.replace(/\{([^\{\}]+)\}|([^\{\}]+)/g, function (_, expression, literal) {
if (expression) {
let operator = "";
const values = [];
if (operators.indexOf(expression.charAt(0)) !== -1) {
operator = expression.charAt(0);
expression = expression.substr(1);
}
expression.split(/,/g).forEach(function (variable) {
var tmp = /([^:\*]*)(?::(\d+)|(\*))?/.exec(variable);
values.push(getValues(context, operator, tmp[1], tmp[2] || tmp[3]));
});
if (operator && operator !== "+") {
var separator = ",";
if (operator === "?") {
separator = "&";
} else if (operator !== "#") {
separator = operator;
}
return (values.length !== 0 ? operator : "") + values.join(separator);
} else {
return values.join(",");
}
} else {
return encodeReserved(literal);
}
});
}
function parse(options) {
// https://fetch.spec.whatwg.org/#methods
let method = options.method.toUpperCase(); // replace :varname with {varname} to make it RFC 6570 compatible
let url = (options.url || "/").replace(/:([a-z]\w+)/g, "{$1}");
let headers = Object.assign({}, options.headers);
let body;
let parameters = omit(options, ["method", "baseUrl", "url", "headers", "request", "mediaType"]); // extract variable names from URL to calculate remaining variables later
const urlVariableNames = extractUrlVariableNames(url);
url = parseUrl(url).expand(parameters);
if (!/^http/.test(url)) {
url = options.baseUrl + url;
}
const omittedParameters = Object.keys(options).filter(option => urlVariableNames.includes(option)).concat("baseUrl");
const remainingParameters = omit(parameters, omittedParameters);
const isBinaryRequest = /application\/octet-stream/i.test(headers.accept);
if (!isBinaryRequest) {
if (options.mediaType.format) {
// e.g. application/vnd.github.v3+json => application/vnd.github.v3.raw
headers.accept = headers.accept.split(/,/).map(preview => preview.replace(/application\/vnd(\.\w+)(\.v3)?(\.\w+)?(\+json)?$/, `application/vnd$1$2.${options.mediaType.format}`)).join(",");
}
if (options.mediaType.previews.length) {
const previewsFromAcceptHeader = headers.accept.match(/[\w-]+(?=-preview)/g) || [];
headers.accept = previewsFromAcceptHeader.concat(options.mediaType.previews).map(preview => {
const format = options.mediaType.format ? `.${options.mediaType.format}` : "+json";
return `application/vnd.github.${preview}-preview${format}`;
}).join(",");
}
} // for GET/HEAD requests, set URL query parameters from remaining parameters
// for PATCH/POST/PUT/DELETE requests, set request body from remaining parameters
if (["GET", "HEAD"].includes(method)) {
url = addQueryParameters(url, remainingParameters);
} else {
if ("data" in remainingParameters) {
body = remainingParameters.data;
} else {
if (Object.keys(remainingParameters).length) {
body = remainingParameters;
} else {
headers["content-length"] = 0;
}
}
} // default content-type for JSON if body is set
if (!headers["content-type"] && typeof body !== "undefined") {
headers["content-type"] = "application/json; charset=utf-8";
} // GitHub expects 'content-length: 0' header for PUT/PATCH requests without body.
// fetch does not allow to set `content-length` header, but we can set body to an empty string
if (["PATCH", "PUT"].includes(method) && typeof body === "undefined") {
body = "";
} // Only return body/request keys if present
return Object.assign({
method,
url,
headers
}, typeof body !== "undefined" ? {
body
} : null, options.request ? {
request: options.request
} : null);
}
function endpointWithDefaults(defaults, route, options) {
return parse(merge(defaults, route, options));
}
function withDefaults(oldDefaults, newDefaults) {
const DEFAULTS = merge(oldDefaults, newDefaults);
const endpoint = endpointWithDefaults.bind(null, DEFAULTS);
return Object.assign(endpoint, {
DEFAULTS,
defaults: withDefaults.bind(null, DEFAULTS),
merge: merge.bind(null, DEFAULTS),
parse
});
}
const VERSION = "6.0.12";
const userAgent = `octokit-endpoint.js/${VERSION} ${universalUserAgent.getUserAgent()}`; // DEFAULTS has all properties set that EndpointOptions has, except url.
// So we use RequestParameters and add method as additional required property.
const DEFAULTS = {
method: "GET",
baseUrl: "https://api.github.com",
headers: {
accept: "application/vnd.github.v3+json",
"user-agent": userAgent
},
mediaType: {
format: "",
previews: []
}
};
const endpoint = withDefaults(null, DEFAULTS);
exports.endpoint = endpoint;
//# sourceMappingURL=index.js.map
/***/ }),
/***/ 8467:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
2021-10-01 09:38:36 -04:00
var request = __nccwpck_require__(5712);
2021-09-26 15:31:45 -04:00
var universalUserAgent = __nccwpck_require__(5030);
const VERSION = "4.8.0";
function _buildMessageForResponseErrors(data) {
return `Request failed due to following response errors:\n` + data.errors.map(e => ` - ${e.message}`).join("\n");
}
class GraphqlResponseError extends Error {
constructor(request, headers, response) {
super(_buildMessageForResponseErrors(response));
this.request = request;
this.headers = headers;
this.response = response;
this.name = "GraphqlResponseError"; // Expose the errors and response data in their shorthand properties.
this.errors = response.errors;
this.data = response.data; // Maintains proper stack trace (only available on V8)
/* istanbul ignore next */
if (Error.captureStackTrace) {
Error.captureStackTrace(this, this.constructor);
}
}
}
const NON_VARIABLE_OPTIONS = ["method", "baseUrl", "url", "headers", "request", "query", "mediaType"];
const FORBIDDEN_VARIABLE_OPTIONS = ["query", "method", "url"];
const GHES_V3_SUFFIX_REGEX = /\/api\/v3\/?$/;
function graphql(request, query, options) {
if (options) {
if (typeof query === "string" && "query" in options) {
return Promise.reject(new Error(`[@octokit/graphql] "query" cannot be used as variable name`));
}
for (const key in options) {
if (!FORBIDDEN_VARIABLE_OPTIONS.includes(key)) continue;
return Promise.reject(new Error(`[@octokit/graphql] "${key}" cannot be used as variable name`));
}
}
const parsedOptions = typeof query === "string" ? Object.assign({
query
}, options) : query;
const requestOptions = Object.keys(parsedOptions).reduce((result, key) => {
if (NON_VARIABLE_OPTIONS.includes(key)) {
result[key] = parsedOptions[key];
return result;
}
if (!result.variables) {
result.variables = {};
}
result.variables[key] = parsedOptions[key];
return result;
}, {}); // workaround for GitHub Enterprise baseUrl set with /api/v3 suffix
// https://github.com/octokit/auth-app.js/issues/111#issuecomment-657610451
const baseUrl = parsedOptions.baseUrl || request.endpoint.DEFAULTS.baseUrl;
if (GHES_V3_SUFFIX_REGEX.test(baseUrl)) {
requestOptions.url = baseUrl.replace(GHES_V3_SUFFIX_REGEX, "/api/graphql");
}
return request(requestOptions).then(response => {
if (response.data.errors) {
const headers = {};
for (const key of Object.keys(response.headers)) {
headers[key] = response.headers[key];
}
throw new GraphqlResponseError(requestOptions, headers, response.data);
}
return response.data.data;
});
}
function withDefaults(request$1, newDefaults) {
const newRequest = request$1.defaults(newDefaults);
const newApi = (query, options) => {
return graphql(newRequest, query, options);
};
return Object.assign(newApi, {
defaults: withDefaults.bind(null, newRequest),
endpoint: request.request.endpoint
});
}
const graphql$1 = withDefaults(request.request, {
headers: {
"user-agent": `octokit-graphql.js/${VERSION} ${universalUserAgent.getUserAgent()}`
},
method: "POST",
url: "/graphql"
});
function withCustomRequest(customRequest) {
return withDefaults(customRequest, {
method: "POST",
url: "/graphql"
});
}
exports.GraphqlResponseError = GraphqlResponseError;
exports.graphql = graphql$1;
exports.withCustomRequest = withCustomRequest;
//# sourceMappingURL=index.js.map
/***/ }),
/***/ 4193:
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
2022-05-31 14:18:28 -04:00
const VERSION = "2.17.0";
2021-09-26 15:31:45 -04:00
function ownKeys(object, enumerableOnly) {
var keys = Object.keys(object);
if (Object.getOwnPropertySymbols) {
var symbols = Object.getOwnPropertySymbols(object);
if (enumerableOnly) {
symbols = symbols.filter(function (sym) {
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
});
}
keys.push.apply(keys, symbols);
}
return keys;
}
function _objectSpread2(target) {
for (var i = 1; i < arguments.length; i++) {
var source = arguments[i] != null ? arguments[i] : {};
if (i % 2) {
ownKeys(Object(source), true).forEach(function (key) {
_defineProperty(target, key, source[key]);
});
} else if (Object.getOwnPropertyDescriptors) {
Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
} else {
ownKeys(Object(source)).forEach(function (key) {
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
});
}
}
return target;
}
function _defineProperty(obj, key, value) {
if (key in obj) {
Object.defineProperty(obj, key, {
value: value,
enumerable: true,
configurable: true,
writable: true
});
} else {
obj[key] = value;
}
return obj;
}
/**
* Some list response that can be paginated have a different response structure
*
* They have a `total_count` key in the response (search also has `incomplete_results`,
* /installation/repositories also has `repository_selection`), as well as a key with
* the list of the items which name varies from endpoint to endpoint.
*
* Octokit normalizes these responses so that paginated results are always returned following
* the same structure. One challenge is that if the list response has only one page, no Link
* header is provided, so this header alone is not sufficient to check wether a response is
* paginated or not.
*
* We check if a "total_count" key is present in the response data, but also make sure that
* a "url" property is not, as the "Get the combined status for a specific ref" endpoint would
* otherwise match: https://developer.github.com/v3/repos/statuses/#get-the-combined-status-for-a-specific-ref
*/
function normalizePaginatedListResponse(response) {
// endpoints can respond with 204 if repository is empty
if (!response.data) {
return _objectSpread2(_objectSpread2({}, response), {}, {
data: []
});
}
const responseNeedsNormalization = "total_count" in response.data && !("url" in response.data);
if (!responseNeedsNormalization) return response; // keep the additional properties intact as there is currently no other way
// to retrieve the same information.
const incompleteResults = response.data.incomplete_results;
const repositorySelection = response.data.repository_selection;
const totalCount = response.data.total_count;
delete response.data.incomplete_results;
delete response.data.repository_selection;
delete response.data.total_count;
const namespaceKey = Object.keys(response.data)[0];
const data = response.data[namespaceKey];
response.data = data;
if (typeof incompleteResults !== "undefined") {
response.data.incomplete_results = incompleteResults;
}
if (typeof repositorySelection !== "undefined") {
response.data.repository_selection = repositorySelection;
}
response.data.total_count = totalCount;
return response;
}
function iterator(octokit, route, parameters) {
const options = typeof route === "function" ? route.endpoint(parameters) : octokit.request.endpoint(route, parameters);
const requestMethod = typeof route === "function" ? route : octokit.request;
const method = options.method;
const headers = options.headers;
let url = options.url;
return {
[Symbol.asyncIterator]: () => ({
async next() {
if (!url) return {
done: true
};
try {
const response = await requestMethod({
method,
url,
headers
});
const normalizedResponse = normalizePaginatedListResponse(response); // `response.headers.link` format:
// '<https://api.github.com/users/aseemk/followers?page=2>; rel="next", <https://api.github.com/users/aseemk/followers?page=2>; rel="last"'
// sets `url` to undefined if "next" URL is not present or `link` header is not set
url = ((normalizedResponse.headers.link || "").match(/<([^>]+)>;\s*rel="next"/) || [])[1];
return {
value: normalizedResponse
};
} catch (error) {
if (error.status !== 409) throw error;
url = "";
return {
value: {
status: 200,
headers: {},
data: []
}
};
}
}
})
};
}
function paginate(octokit, route, parameters, mapFn) {
if (typeof parameters === "function") {
mapFn = parameters;
parameters = undefined;
}
return gather(octokit, [], iterator(octokit, route, parameters)[Symbol.asyncIterator](), mapFn);
}
function gather(octokit, results, iterator, mapFn) {
return iterator.next().then(result => {
if (result.done) {
return results;
}
let earlyExit = false;
function done() {
earlyExit = true;
}
results = results.concat(mapFn ? mapFn(result.value, done) : result.value.data);
if (earlyExit) {
return results;
}
return gather(octokit, results, iterator, mapFn);
});
}
const composePaginateRest = Object.assign(paginate, {
iterator
});
2022-05-31 14:18:28 -04:00
const paginatingEndpoints = ["GET /app/hook/deliveries", "GET /app/installations", "GET /applications/grants", "GET /authorizations", "GET /enterprises/{enterprise}/actions/permissions/organizations", "GET /enterprises/{enterprise}/actions/runner-groups", "GET /enterprises/{enterprise}/actions/runner-groups/{runner_group_id}/organizations", "GET /enterprises/{enterprise}/actions/runner-groups/{runner_group_id}/runners", "GET /enterprises/{enterprise}/actions/runners", "GET /enterprises/{enterprise}/actions/runners/downloads", "GET /events", "GET /gists", "GET /gists/public", "GET /gists/starred", "GET /gists/{gist_id}/comments", "GET /gists/{gist_id}/commits", "GET /gists/{gist_id}/forks", "GET /installation/repositories", "GET /issues", "GET /marketplace_listing/plans", "GET /marketplace_listing/plans/{plan_id}/accounts", "GET /marketplace_listing/stubbed/plans", "GET /marketplace_listing/stubbed/plans/{plan_id}/accounts", "GET /networks/{owner}/{repo}/events", "GET /notifications", "GET /organizations", "GET /orgs/{org}/actions/permissions/repositories", "GET /orgs/{org}/actions/runner-groups", "GET /orgs/{org}/actions/runner-groups/{runner_group_id}/repositories", "GET /orgs/{org}/actions/runner-groups/{runner_group_id}/runners", "GET /orgs/{org}/actions/runners", "GET /orgs/{org}/actions/runners/downloads", "GET /orgs/{org}/actions/secrets", "GET /orgs/{org}/actions/secrets/{secret_name}/repositories", "GET /orgs/{org}/blocks", "GET /orgs/{org}/credential-authorizations", "GET /orgs/{org}/events", "GET /orgs/{org}/failed_invitations", "GET /orgs/{org}/hooks", "GET /orgs/{org}/hooks/{hook_id}/deliveries", "GET /orgs/{org}/installations", "GET /orgs/{org}/invitations", "GET /orgs/{org}/invitations/{invitation_id}/teams", "GET /orgs/{org}/issues", "GET /orgs/{org}/members", "GET /orgs/{org}/migrations", "GET /orgs/{org}/migrations/{migration_id}/repositories", "GET /orgs/{org}/outside_collaborators", "GET /orgs/{org}/packages", "GET /orgs/{org}/projects", "GET /orgs/{org}/public_members", "GET /orgs/{org}/repos", "GET /orgs/{org}/secret-scanning/alerts", "GET /orgs/{org}/team-sync/groups", "GET /orgs/{org}/teams", "GET /orgs/{org}/teams/{team_slug}/discussions", "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments", "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions", "GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions", "GET /orgs/{org}/teams/{team_slug}/invitations", "GET /orgs/{org}/teams/{team_slug}/members", "GET /orgs/{org}/teams/{team_slug}/projects", "GET /orgs/{org}/teams/{team_slug}/repos", "GET /orgs/{org}/teams/{team_slug}/team-sync/group-mappings", "GET /orgs/{org}/teams/{team_slug}/teams", "GET /projects/columns/{column_id}/cards", "GET /projects/{project_id}/collaborators", "GET /projects/{project_id}/columns", "GET /repos/{owner}/{repo}/actions/artifacts", "GET /repos/{owner}/{repo}/actions/runners", "GET /repos/{owner}/{repo}/actions/runners/downloads", "GET /repos/{owner}/{repo}/actions/runs", "GET /repos/{owner}/{repo}/actions/runs/{run_id}/artifacts", "GET /repos/{owner}/{repo}/actions/runs/{run_id}/attempts/{attempt_number}/jobs", "GET /repos/{owner}/{repo}/actions/runs/{run_id}/jobs", "GET /repos/{owner}/{repo}/actions/secrets", "GET /repos/{owner}/{repo}/actions/workflows", "GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/runs", "GET /repos/{owner}/{repo}/assignees", "GET /repos/{owner}/{repo}/autolinks", "GET /repos/{owner}/{repo}/branches", "GET /repos/{owner}/{repo}/check-runs/{check_run_id}/annotations", "GET /repos/{owner}/{repo}/check-suites/{check_suite_id}/check-runs", "GET /repos/{owner}/{repo}/code-scanning/alerts", "GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}/instances", "GET /repos/{owner}/{repo}/code-scanning/analyses", "GET /repos/{owner}/{repo}/collaborators", "GET /repos/{owner}/{repo}/comments", "GET /repos/{owner}/{repo}/comments/{comment_id}/reactions", "GET /repos/{owner}/{repo}/commits", "GET /repos/{owner}/{repo}/commits/{commit_sha}/branches-where-
2021-09-26 15:31:45 -04:00
function isPaginatingEndpoint(arg) {
if (typeof arg === "string") {
return paginatingEndpoints.includes(arg);
} else {
return false;
}
}
/**
* @param octokit Octokit instance
* @param options Options passed to Octokit constructor
*/
function paginateRest(octokit) {
return {
paginate: Object.assign(paginate.bind(null, octokit), {
iterator: iterator.bind(null, octokit)
})
};
}
paginateRest.VERSION = VERSION;
exports.composePaginateRest = composePaginateRest;
exports.isPaginatingEndpoint = isPaginatingEndpoint;
exports.paginateRest = paginateRest;
exports.paginatingEndpoints = paginatingEndpoints;
//# sourceMappingURL=index.js.map
/***/ }),
/***/ 3044:
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
function ownKeys(object, enumerableOnly) {
var keys = Object.keys(object);
if (Object.getOwnPropertySymbols) {
var symbols = Object.getOwnPropertySymbols(object);
if (enumerableOnly) {
symbols = symbols.filter(function (sym) {
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
});
}
keys.push.apply(keys, symbols);
}
return keys;
}
function _objectSpread2(target) {
for (var i = 1; i < arguments.length; i++) {
var source = arguments[i] != null ? arguments[i] : {};
if (i % 2) {
ownKeys(Object(source), true).forEach(function (key) {
_defineProperty(target, key, source[key]);
});
} else if (Object.getOwnPropertyDescriptors) {
Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
} else {
ownKeys(Object(source)).forEach(function (key) {
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
});
}
}
return target;
}
function _defineProperty(obj, key, value) {
if (key in obj) {
Object.defineProperty(obj, key, {
value: value,
enumerable: true,
configurable: true,
writable: true
});
} else {
obj[key] = value;
}
return obj;
}
const Endpoints = {
actions: {
addSelectedRepoToOrgSecret: ["PUT /orgs/{org}/actions/secrets/{secret_name}/repositories/{repository_id}"],
approveWorkflowRun: ["POST /repos/{owner}/{repo}/actions/runs/{run_id}/approve"],
cancelWorkflowRun: ["POST /repos/{owner}/{repo}/actions/runs/{run_id}/cancel"],
createOrUpdateEnvironmentSecret: ["PUT /repositories/{repository_id}/environments/{environment_name}/secrets/{secret_name}"],
createOrUpdateOrgSecret: ["PUT /orgs/{org}/actions/secrets/{secret_name}"],
createOrUpdateRepoSecret: ["PUT /repos/{owner}/{repo}/actions/secrets/{secret_name}"],
createRegistrationTokenForOrg: ["POST /orgs/{org}/actions/runners/registration-token"],
createRegistrationTokenForRepo: ["POST /repos/{owner}/{repo}/actions/runners/registration-token"],
createRemoveTokenForOrg: ["POST /orgs/{org}/actions/runners/remove-token"],
createRemoveTokenForRepo: ["POST /repos/{owner}/{repo}/actions/runners/remove-token"],
createWorkflowDispatch: ["POST /repos/{owner}/{repo}/actions/workflows/{workflow_id}/dispatches"],
deleteArtifact: ["DELETE /repos/{owner}/{repo}/actions/artifacts/{artifact_id}"],
deleteEnvironmentSecret: ["DELETE /repositories/{repository_id}/environments/{environment_name}/secrets/{secret_name}"],
deleteOrgSecret: ["DELETE /orgs/{org}/actions/secrets/{secret_name}"],
deleteRepoSecret: ["DELETE /repos/{owner}/{repo}/actions/secrets/{secret_name}"],
deleteSelfHostedRunnerFromOrg: ["DELETE /orgs/{org}/actions/runners/{runner_id}"],
deleteSelfHostedRunnerFromRepo: ["DELETE /repos/{owner}/{repo}/actions/runners/{runner_id}"],
deleteWorkflowRun: ["DELETE /repos/{owner}/{repo}/actions/runs/{run_id}"],
deleteWorkflowRunLogs: ["DELETE /repos/{owner}/{repo}/actions/runs/{run_id}/logs"],
disableSelectedRepositoryGithubActionsOrganization: ["DELETE /orgs/{org}/actions/permissions/repositories/{repository_id}"],
disableWorkflow: ["PUT /repos/{owner}/{repo}/actions/workflows/{workflow_id}/disable"],
downloadArtifact: ["GET /repos/{owner}/{repo}/actions/artifacts/{artifact_id}/{archive_format}"],
downloadJobLogsForWorkflowRun: ["GET /repos/{owner}/{repo}/actions/jobs/{job_id}/logs"],
2022-05-31 14:18:28 -04:00
downloadWorkflowRunAttemptLogs: ["GET /repos/{owner}/{repo}/actions/runs/{run_id}/attempts/{attempt_number}/logs"],
2021-09-26 15:31:45 -04:00
downloadWorkflowRunLogs: ["GET /repos/{owner}/{repo}/actions/runs/{run_id}/logs"],
enableSelectedRepositoryGithubActionsOrganization: ["PUT /orgs/{org}/actions/permissions/repositories/{repository_id}"],
enableWorkflow: ["PUT /repos/{owner}/{repo}/actions/workflows/{workflow_id}/enable"],
getAllowedActionsOrganization: ["GET /orgs/{org}/actions/permissions/selected-actions"],
getAllowedActionsRepository: ["GET /repos/{owner}/{repo}/actions/permissions/selected-actions"],
getArtifact: ["GET /repos/{owner}/{repo}/actions/artifacts/{artifact_id}"],
getEnvironmentPublicKey: ["GET /repositories/{repository_id}/environments/{environment_name}/secrets/public-key"],
getEnvironmentSecret: ["GET /repositories/{repository_id}/environments/{environment_name}/secrets/{secret_name}"],
getGithubActionsPermissionsOrganization: ["GET /orgs/{org}/actions/permissions"],
getGithubActionsPermissionsRepository: ["GET /repos/{owner}/{repo}/actions/permissions"],
getJobForWorkflowRun: ["GET /repos/{owner}/{repo}/actions/jobs/{job_id}"],
getOrgPublicKey: ["GET /orgs/{org}/actions/secrets/public-key"],
getOrgSecret: ["GET /orgs/{org}/actions/secrets/{secret_name}"],
getPendingDeploymentsForRun: ["GET /repos/{owner}/{repo}/actions/runs/{run_id}/pending_deployments"],
getRepoPermissions: ["GET /repos/{owner}/{repo}/actions/permissions", {}, {
renamed: ["actions", "getGithubActionsPermissionsRepository"]
}],
getRepoPublicKey: ["GET /repos/{owner}/{repo}/actions/secrets/public-key"],
getRepoSecret: ["GET /repos/{owner}/{repo}/actions/secrets/{secret_name}"],
getReviewsForRun: ["GET /repos/{owner}/{repo}/actions/runs/{run_id}/approvals"],
getSelfHostedRunnerForOrg: ["GET /orgs/{org}/actions/runners/{runner_id}"],
getSelfHostedRunnerForRepo: ["GET /repos/{owner}/{repo}/actions/runners/{runner_id}"],
getWorkflow: ["GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}"],
getWorkflowRun: ["GET /repos/{owner}/{repo}/actions/runs/{run_id}"],
2022-05-31 14:18:28 -04:00
getWorkflowRunAttempt: ["GET /repos/{owner}/{repo}/actions/runs/{run_id}/attempts/{attempt_number}"],
2021-09-26 15:31:45 -04:00
getWorkflowRunUsage: ["GET /repos/{owner}/{repo}/actions/runs/{run_id}/timing"],
getWorkflowUsage: ["GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/timing"],
listArtifactsForRepo: ["GET /repos/{owner}/{repo}/actions/artifacts"],
listEnvironmentSecrets: ["GET /repositories/{repository_id}/environments/{environment_name}/secrets"],
listJobsForWorkflowRun: ["GET /repos/{owner}/{repo}/actions/runs/{run_id}/jobs"],
2022-05-31 14:18:28 -04:00
listJobsForWorkflowRunAttempt: ["GET /repos/{owner}/{repo}/actions/runs/{run_id}/attempts/{attempt_number}/jobs"],
2021-09-26 15:31:45 -04:00
listOrgSecrets: ["GET /orgs/{org}/actions/secrets"],
listRepoSecrets: ["GET /repos/{owner}/{repo}/actions/secrets"],
listRepoWorkflows: ["GET /repos/{owner}/{repo}/actions/workflows"],
listRunnerApplicationsForOrg: ["GET /orgs/{org}/actions/runners/downloads"],
listRunnerApplicationsForRepo: ["GET /repos/{owner}/{repo}/actions/runners/downloads"],
listSelectedReposForOrgSecret: ["GET /orgs/{org}/actions/secrets/{secret_name}/repositories"],
listSelectedRepositoriesEnabledGithubActionsOrganization: ["GET /orgs/{org}/actions/permissions/repositories"],
listSelfHostedRunnersForOrg: ["GET /orgs/{org}/actions/runners"],
listSelfHostedRunnersForRepo: ["GET /repos/{owner}/{repo}/actions/runners"],
listWorkflowRunArtifacts: ["GET /repos/{owner}/{repo}/actions/runs/{run_id}/artifacts"],
listWorkflowRuns: ["GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/runs"],
listWorkflowRunsForRepo: ["GET /repos/{owner}/{repo}/actions/runs"],
removeSelectedRepoFromOrgSecret: ["DELETE /orgs/{org}/actions/secrets/{secret_name}/repositories/{repository_id}"],
reviewPendingDeploymentsForRun: ["POST /repos/{owner}/{repo}/actions/runs/{run_id}/pending_deployments"],
setAllowedActionsOrganization: ["PUT /orgs/{org}/actions/permissions/selected-actions"],
setAllowedActionsRepository: ["PUT /repos/{owner}/{repo}/actions/permissions/selected-actions"],
setGithubActionsPermissionsOrganization: ["PUT /orgs/{org}/actions/permissions"],
setGithubActionsPermissionsRepository: ["PUT /repos/{owner}/{repo}/actions/permissions"],
setSelectedReposForOrgSecret: ["PUT /orgs/{org}/actions/secrets/{secret_name}/repositories"],
setSelectedRepositoriesEnabledGithubActionsOrganization: ["PUT /orgs/{org}/actions/permissions/repositories"]
},
activity: {
checkRepoIsStarredByAuthenticatedUser: ["GET /user/starred/{owner}/{repo}"],
deleteRepoSubscription: ["DELETE /repos/{owner}/{repo}/subscription"],
deleteThreadSubscription: ["DELETE /notifications/threads/{thread_id}/subscription"],
getFeeds: ["GET /feeds"],
getRepoSubscription: ["GET /repos/{owner}/{repo}/subscription"],
getThread: ["GET /notifications/threads/{thread_id}"],
getThreadSubscriptionForAuthenticatedUser: ["GET /notifications/threads/{thread_id}/subscription"],
listEventsForAuthenticatedUser: ["GET /users/{username}/events"],
listNotificationsForAuthenticatedUser: ["GET /notifications"],
listOrgEventsForAuthenticatedUser: ["GET /users/{username}/events/orgs/{org}"],
listPublicEvents: ["GET /events"],
listPublicEventsForRepoNetwork: ["GET /networks/{owner}/{repo}/events"],
listPublicEventsForUser: ["GET /users/{username}/events/public"],
listPublicOrgEvents: ["GET /orgs/{org}/events"],
listReceivedEventsForUser: ["GET /users/{username}/received_events"],
listReceivedPublicEventsForUser: ["GET /users/{username}/received_events/public"],
listRepoEvents: ["GET /repos/{owner}/{repo}/events"],
listRepoNotificationsForAuthenticatedUser: ["GET /repos/{owner}/{repo}/notifications"],
listReposStarredByAuthenticatedUser: ["GET /user/starred"],
listReposStarredByUser: ["GET /users/{username}/starred"],
listReposWatchedByUser: ["GET /users/{username}/subscriptions"],
listStargazersForRepo: ["GET /repos/{owner}/{repo}/stargazers"],
listWatchedReposForAuthenticatedUser: ["GET /user/subscriptions"],
listWatchersForRepo: ["GET /repos/{owner}/{repo}/subscribers"],
markNotificationsAsRead: ["PUT /notifications"],
markRepoNotificationsAsRead: ["PUT /repos/{owner}/{repo}/notifications"],
markThreadAsRead: ["PATCH /notifications/threads/{thread_id}"],
setRepoSubscription: ["PUT /repos/{owner}/{repo}/subscription"],
setThreadSubscription: ["PUT /notifications/threads/{thread_id}/subscription"],
starRepoForAuthenticatedUser: ["PUT /user/starred/{owner}/{repo}"],
unstarRepoForAuthenticatedUser: ["DELETE /user/starred/{owner}/{repo}"]
},
apps: {
2022-05-31 14:18:28 -04:00
addRepoToInstallation: ["PUT /user/installations/{installation_id}/repositories/{repository_id}", {}, {
renamed: ["apps", "addRepoToInstallationForAuthenticatedUser"]
}],
addRepoToInstallationForAuthenticatedUser: ["PUT /user/installations/{installation_id}/repositories/{repository_id}"],
2021-09-26 15:31:45 -04:00
checkToken: ["POST /applications/{client_id}/token"],
createContentAttachment: ["POST /content_references/{content_reference_id}/attachments", {
mediaType: {
previews: ["corsair"]
}
}],
createContentAttachmentForRepo: ["POST /repos/{owner}/{repo}/content_references/{content_reference_id}/attachments", {
mediaType: {
previews: ["corsair"]
}
}],
createFromManifest: ["POST /app-manifests/{code}/conversions"],
createInstallationAccessToken: ["POST /app/installations/{installation_id}/access_tokens"],
deleteAuthorization: ["DELETE /applications/{client_id}/grant"],
deleteInstallation: ["DELETE /app/installations/{installation_id}"],
deleteToken: ["DELETE /applications/{client_id}/token"],
getAuthenticated: ["GET /app"],
getBySlug: ["GET /apps/{app_slug}"],
getInstallation: ["GET /app/installations/{installation_id}"],
getOrgInstallation: ["GET /orgs/{org}/installation"],
getRepoInstallation: ["GET /repos/{owner}/{repo}/installation"],
getSubscriptionPlanForAccount: ["GET /marketplace_listing/accounts/{account_id}"],
getSubscriptionPlanForAccountStubbed: ["GET /marketplace_listing/stubbed/accounts/{account_id}"],
getUserInstallation: ["GET /users/{username}/installation"],
getWebhookConfigForApp: ["GET /app/hook/config"],
getWebhookDelivery: ["GET /app/hook/deliveries/{delivery_id}"],
listAccountsForPlan: ["GET /marketplace_listing/plans/{plan_id}/accounts"],
listAccountsForPlanStubbed: ["GET /marketplace_listing/stubbed/plans/{plan_id}/accounts"],
listInstallationReposForAuthenticatedUser: ["GET /user/installations/{installation_id}/repositories"],
listInstallations: ["GET /app/installations"],
listInstallationsForAuthenticatedUser: ["GET /user/installations"],
listPlans: ["GET /marketplace_listing/plans"],
listPlansStubbed: ["GET /marketplace_listing/stubbed/plans"],
listReposAccessibleToInstallation: ["GET /installation/repositories"],
listSubscriptionsForAuthenticatedUser: ["GET /user/marketplace_purchases"],
listSubscriptionsForAuthenticatedUserStubbed: ["GET /user/marketplace_purchases/stubbed"],
listWebhookDeliveries: ["GET /app/hook/deliveries"],
redeliverWebhookDelivery: ["POST /app/hook/deliveries/{delivery_id}/attempts"],
2022-05-31 14:18:28 -04:00
removeRepoFromInstallation: ["DELETE /user/installations/{installation_id}/repositories/{repository_id}", {}, {
renamed: ["apps", "removeRepoFromInstallationForAuthenticatedUser"]
}],
removeRepoFromInstallationForAuthenticatedUser: ["DELETE /user/installations/{installation_id}/repositories/{repository_id}"],
2021-09-26 15:31:45 -04:00
resetToken: ["PATCH /applications/{client_id}/token"],
revokeInstallationAccessToken: ["DELETE /installation/token"],
scopeToken: ["POST /applications/{client_id}/token/scoped"],
suspendInstallation: ["PUT /app/installations/{installation_id}/suspended"],
unsuspendInstallation: ["DELETE /app/installations/{installation_id}/suspended"],
updateWebhookConfigForApp: ["PATCH /app/hook/config"]
},
billing: {
getGithubActionsBillingOrg: ["GET /orgs/{org}/settings/billing/actions"],
getGithubActionsBillingUser: ["GET /users/{username}/settings/billing/actions"],
getGithubPackagesBillingOrg: ["GET /orgs/{org}/settings/billing/packages"],
getGithubPackagesBillingUser: ["GET /users/{username}/settings/billing/packages"],
getSharedStorageBillingOrg: ["GET /orgs/{org}/settings/billing/shared-storage"],
getSharedStorageBillingUser: ["GET /users/{username}/settings/billing/shared-storage"]
},
checks: {
create: ["POST /repos/{owner}/{repo}/check-runs"],
createSuite: ["POST /repos/{owner}/{repo}/check-suites"],
get: ["GET /repos/{owner}/{repo}/check-runs/{check_run_id}"],
getSuite: ["GET /repos/{owner}/{repo}/check-suites/{check_suite_id}"],
listAnnotations: ["GET /repos/{owner}/{repo}/check-runs/{check_run_id}/annotations"],
listForRef: ["GET /repos/{owner}/{repo}/commits/{ref}/check-runs"],
listForSuite: ["GET /repos/{owner}/{repo}/check-suites/{check_suite_id}/check-runs"],
listSuitesForRef: ["GET /repos/{owner}/{repo}/commits/{ref}/check-suites"],
2022-05-31 14:18:28 -04:00
rerequestRun: ["POST /repos/{owner}/{repo}/check-runs/{check_run_id}/rerequest"],
2021-09-26 15:31:45 -04:00
rerequestSuite: ["POST /repos/{owner}/{repo}/check-suites/{check_suite_id}/rerequest"],
setSuitesPreferences: ["PATCH /repos/{owner}/{repo}/check-suites/preferences"],
update: ["PATCH /repos/{owner}/{repo}/check-runs/{check_run_id}"]
},
codeScanning: {
deleteAnalysis: ["DELETE /repos/{owner}/{repo}/code-scanning/analyses/{analysis_id}{?confirm_delete}"],
getAlert: ["GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}", {}, {
renamedParameters: {
alert_id: "alert_number"
}
}],
getAnalysis: ["GET /repos/{owner}/{repo}/code-scanning/analyses/{analysis_id}"],
getSarif: ["GET /repos/{owner}/{repo}/code-scanning/sarifs/{sarif_id}"],
listAlertInstances: ["GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}/instances"],
listAlertsForRepo: ["GET /repos/{owner}/{repo}/code-scanning/alerts"],
listAlertsInstances: ["GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}/instances", {}, {
renamed: ["codeScanning", "listAlertInstances"]
}],
listRecentAnalyses: ["GET /repos/{owner}/{repo}/code-scanning/analyses"],
updateAlert: ["PATCH /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}"],
uploadSarif: ["POST /repos/{owner}/{repo}/code-scanning/sarifs"]
},
codesOfConduct: {
getAllCodesOfConduct: ["GET /codes_of_conduct"],
2022-05-31 14:18:28 -04:00
getConductCode: ["GET /codes_of_conduct/{key}"]
2021-09-26 15:31:45 -04:00
},
emojis: {
get: ["GET /emojis"]
},
enterpriseAdmin: {
disableSelectedOrganizationGithubActionsEnterprise: ["DELETE /enterprises/{enterprise}/actions/permissions/organizations/{org_id}"],
enableSelectedOrganizationGithubActionsEnterprise: ["PUT /enterprises/{enterprise}/actions/permissions/organizations/{org_id}"],
getAllowedActionsEnterprise: ["GET /enterprises/{enterprise}/actions/permissions/selected-actions"],
getGithubActionsPermissionsEnterprise: ["GET /enterprises/{enterprise}/actions/permissions"],
listSelectedOrganizationsEnabledGithubActionsEnterprise: ["GET /enterprises/{enterprise}/actions/permissions/organizations"],
setAllowedActionsEnterprise: ["PUT /enterprises/{enterprise}/actions/permissions/selected-actions"],
setGithubActionsPermissionsEnterprise: ["PUT /enterprises/{enterprise}/actions/permissions"],
setSelectedOrganizationsEnabledGithubActionsEnterprise: ["PUT /enterprises/{enterprise}/actions/permissions/organizations"]
},
gists: {
checkIsStarred: ["GET /gists/{gist_id}/star"],
create: ["POST /gists"],
createComment: ["POST /gists/{gist_id}/comments"],
delete: ["DELETE /gists/{gist_id}"],
deleteComment: ["DELETE /gists/{gist_id}/comments/{comment_id}"],
fork: ["POST /gists/{gist_id}/forks"],
get: ["GET /gists/{gist_id}"],
getComment: ["GET /gists/{gist_id}/comments/{comment_id}"],
getRevision: ["GET /gists/{gist_id}/{sha}"],
list: ["GET /gists"],
listComments: ["GET /gists/{gist_id}/comments"],
listCommits: ["GET /gists/{gist_id}/commits"],
listForUser: ["GET /users/{username}/gists"],
listForks: ["GET /gists/{gist_id}/forks"],
listPublic: ["GET /gists/public"],
listStarred: ["GET /gists/starred"],
star: ["PUT /gists/{gist_id}/star"],
unstar: ["DELETE /gists/{gist_id}/star"],
update: ["PATCH /gists/{gist_id}"],
updateComment: ["PATCH /gists/{gist_id}/comments/{comment_id}"]
},
git: {
createBlob: ["POST /repos/{owner}/{repo}/git/blobs"],
createCommit: ["POST /repos/{owner}/{repo}/git/commits"],
createRef: ["POST /repos/{owner}/{repo}/git/refs"],
createTag: ["POST /repos/{owner}/{repo}/git/tags"],
createTree: ["POST /repos/{owner}/{repo}/git/trees"],
deleteRef: ["DELETE /repos/{owner}/{repo}/git/refs/{ref}"],
getBlob: ["GET /repos/{owner}/{repo}/git/blobs/{file_sha}"],
getCommit: ["GET /repos/{owner}/{repo}/git/commits/{commit_sha}"],
getRef: ["GET /repos/{owner}/{repo}/git/ref/{ref}"],
getTag: ["GET /repos/{owner}/{repo}/git/tags/{tag_sha}"],
getTree: ["GET /repos/{owner}/{repo}/git/trees/{tree_sha}"],
listMatchingRefs: ["GET /repos/{owner}/{repo}/git/matching-refs/{ref}"],
updateRef: ["PATCH /repos/{owner}/{repo}/git/refs/{ref}"]
},
gitignore: {
getAllTemplates: ["GET /gitignore/templates"],
getTemplate: ["GET /gitignore/templates/{name}"]
},
interactions: {
getRestrictionsForAuthenticatedUser: ["GET /user/interaction-limits"],
getRestrictionsForOrg: ["GET /orgs/{org}/interaction-limits"],
getRestrictionsForRepo: ["GET /repos/{owner}/{repo}/interaction-limits"],
getRestrictionsForYourPublicRepos: ["GET /user/interaction-limits", {}, {
renamed: ["interactions", "getRestrictionsForAuthenticatedUser"]
}],
removeRestrictionsForAuthenticatedUser: ["DELETE /user/interaction-limits"],
removeRestrictionsForOrg: ["DELETE /orgs/{org}/interaction-limits"],
removeRestrictionsForRepo: ["DELETE /repos/{owner}/{repo}/interaction-limits"],
removeRestrictionsForYourPublicRepos: ["DELETE /user/interaction-limits", {}, {
renamed: ["interactions", "removeRestrictionsForAuthenticatedUser"]
}],
setRestrictionsForAuthenticatedUser: ["PUT /user/interaction-limits"],
setRestrictionsForOrg: ["PUT /orgs/{org}/interaction-limits"],
setRestrictionsForRepo: ["PUT /repos/{owner}/{repo}/interaction-limits"],
setRestrictionsForYourPublicRepos: ["PUT /user/interaction-limits", {}, {
renamed: ["interactions", "setRestrictionsForAuthenticatedUser"]
}]
},
issues: {
addAssignees: ["POST /repos/{owner}/{repo}/issues/{issue_number}/assignees"],
addLabels: ["POST /repos/{owner}/{repo}/issues/{issue_number}/labels"],
checkUserCanBeAssigned: ["GET /repos/{owner}/{repo}/assignees/{assignee}"],
create: ["POST /repos/{owner}/{repo}/issues"],
createComment: ["POST /repos/{owner}/{repo}/issues/{issue_number}/comments"],
createLabel: ["POST /repos/{owner}/{repo}/labels"],
createMilestone: ["POST /repos/{owner}/{repo}/milestones"],
deleteComment: ["DELETE /repos/{owner}/{repo}/issues/comments/{comment_id}"],
deleteLabel: ["DELETE /repos/{owner}/{repo}/labels/{name}"],
deleteMilestone: ["DELETE /repos/{owner}/{repo}/milestones/{milestone_number}"],
get: ["GET /repos/{owner}/{repo}/issues/{issue_number}"],
getComment: ["GET /repos/{owner}/{repo}/issues/comments/{comment_id}"],
getEvent: ["GET /repos/{owner}/{repo}/issues/events/{event_id}"],
getLabel: ["GET /repos/{owner}/{repo}/labels/{name}"],
getMilestone: ["GET /repos/{owner}/{repo}/milestones/{milestone_number}"],
list: ["GET /issues"],
listAssignees: ["GET /repos/{owner}/{repo}/assignees"],
listComments: ["GET /repos/{owner}/{repo}/issues/{issue_number}/comments"],
listCommentsForRepo: ["GET /repos/{owner}/{repo}/issues/comments"],
listEvents: ["GET /repos/{owner}/{repo}/issues/{issue_number}/events"],
listEventsForRepo: ["GET /repos/{owner}/{repo}/issues/events"],
listEventsForTimeline: ["GET /repos/{owner}/{repo}/issues/{issue_number}/timeline"],
listForAuthenticatedUser: ["GET /user/issues"],
listForOrg: ["GET /orgs/{org}/issues"],
listForRepo: ["GET /repos/{owner}/{repo}/issues"],
listLabelsForMilestone: ["GET /repos/{owner}/{repo}/milestones/{milestone_number}/labels"],
listLabelsForRepo: ["GET /repos/{owner}/{repo}/labels"],
listLabelsOnIssue: ["GET /repos/{owner}/{repo}/issues/{issue_number}/labels"],
listMilestones: ["GET /repos/{owner}/{repo}/milestones"],
lock: ["PUT /repos/{owner}/{repo}/issues/{issue_number}/lock"],
removeAllLabels: ["DELETE /repos/{owner}/{repo}/issues/{issue_number}/labels"],
removeAssignees: ["DELETE /repos/{owner}/{repo}/issues/{issue_number}/assignees"],
removeLabel: ["DELETE /repos/{owner}/{repo}/issues/{issue_number}/labels/{name}"],
setLabels: ["PUT /repos/{owner}/{repo}/issues/{issue_number}/labels"],
unlock: ["DELETE /repos/{owner}/{repo}/issues/{issue_number}/lock"],
update: ["PATCH /repos/{owner}/{repo}/issues/{issue_number}"],
updateComment: ["PATCH /repos/{owner}/{repo}/issues/comments/{comment_id}"],
updateLabel: ["PATCH /repos/{owner}/{repo}/labels/{name}"],
updateMilestone: ["PATCH /repos/{owner}/{repo}/milestones/{milestone_number}"]
},
licenses: {
get: ["GET /licenses/{license}"],
getAllCommonlyUsed: ["GET /licenses"],
getForRepo: ["GET /repos/{owner}/{repo}/license"]
},
markdown: {
render: ["POST /markdown"],
renderRaw: ["POST /markdown/raw", {
headers: {
"content-type": "text/plain; charset=utf-8"
}
}]
},
meta: {
get: ["GET /meta"],
getOctocat: ["GET /octocat"],
getZen: ["GET /zen"],
root: ["GET /"]
},
migrations: {
cancelImport: ["DELETE /repos/{owner}/{repo}/import"],
deleteArchiveForAuthenticatedUser: ["DELETE /user/migrations/{migration_id}/archive"],
deleteArchiveForOrg: ["DELETE /orgs/{org}/migrations/{migration_id}/archive"],
downloadArchiveForOrg: ["GET /orgs/{org}/migrations/{migration_id}/archive"],
getArchiveForAuthenticatedUser: ["GET /user/migrations/{migration_id}/archive"],
getCommitAuthors: ["GET /repos/{owner}/{repo}/import/authors"],
getImportStatus: ["GET /repos/{owner}/{repo}/import"],
getLargeFiles: ["GET /repos/{owner}/{repo}/import/large_files"],
getStatusForAuthenticatedUser: ["GET /user/migrations/{migration_id}"],
getStatusForOrg: ["GET /orgs/{org}/migrations/{migration_id}"],
listForAuthenticatedUser: ["GET /user/migrations"],
listForOrg: ["GET /orgs/{org}/migrations"],
2022-05-31 14:18:28 -04:00
listReposForAuthenticatedUser: ["GET /user/migrations/{migration_id}/repositories"],
2021-09-26 15:31:45 -04:00
listReposForOrg: ["GET /orgs/{org}/migrations/{migration_id}/repositories"],
2022-05-31 14:18:28 -04:00
listReposForUser: ["GET /user/migrations/{migration_id}/repositories", {}, {
renamed: ["migrations", "listReposForAuthenticatedUser"]
}],
2021-09-26 15:31:45 -04:00
mapCommitAuthor: ["PATCH /repos/{owner}/{repo}/import/authors/{author_id}"],
setLfsPreference: ["PATCH /repos/{owner}/{repo}/import/lfs"],
startForAuthenticatedUser: ["POST /user/migrations"],
startForOrg: ["POST /orgs/{org}/migrations"],
startImport: ["PUT /repos/{owner}/{repo}/import"],
unlockRepoForAuthenticatedUser: ["DELETE /user/migrations/{migration_id}/repos/{repo_name}/lock"],
unlockRepoForOrg: ["DELETE /orgs/{org}/migrations/{migration_id}/repos/{repo_name}/lock"],
updateImport: ["PATCH /repos/{owner}/{repo}/import"]
},
orgs: {
blockUser: ["PUT /orgs/{org}/blocks/{username}"],
cancelInvitation: ["DELETE /orgs/{org}/invitations/{invitation_id}"],
checkBlockedUser: ["GET /orgs/{org}/blocks/{username}"],
checkMembershipForUser: ["GET /orgs/{org}/members/{username}"],
checkPublicMembershipForUser: ["GET /orgs/{org}/public_members/{username}"],
convertMemberToOutsideCollaborator: ["PUT /orgs/{org}/outside_collaborators/{username}"],
createInvitation: ["POST /orgs/{org}/invitations"],
createWebhook: ["POST /orgs/{org}/hooks"],
deleteWebhook: ["DELETE /orgs/{org}/hooks/{hook_id}"],
get: ["GET /orgs/{org}"],
getMembershipForAuthenticatedUser: ["GET /user/memberships/orgs/{org}"],
getMembershipForUser: ["GET /orgs/{org}/memberships/{username}"],
getWebhook: ["GET /orgs/{org}/hooks/{hook_id}"],
getWebhookConfigForOrg: ["GET /orgs/{org}/hooks/{hook_id}/config"],
getWebhookDelivery: ["GET /orgs/{org}/hooks/{hook_id}/deliveries/{delivery_id}"],
list: ["GET /organizations"],
listAppInstallations: ["GET /orgs/{org}/installations"],
listBlockedUsers: ["GET /orgs/{org}/blocks"],
listFailedInvitations: ["GET /orgs/{org}/failed_invitations"],
listForAuthenticatedUser: ["GET /user/orgs"],
listForUser: ["GET /users/{username}/orgs"],
listInvitationTeams: ["GET /orgs/{org}/invitations/{invitation_id}/teams"],
listMembers: ["GET /orgs/{org}/members"],
listMembershipsForAuthenticatedUser: ["GET /user/memberships/orgs"],
listOutsideCollaborators: ["GET /orgs/{org}/outside_collaborators"],
listPendingInvitations: ["GET /orgs/{org}/invitations"],
listPublicMembers: ["GET /orgs/{org}/public_members"],
listWebhookDeliveries: ["GET /orgs/{org}/hooks/{hook_id}/deliveries"],
listWebhooks: ["GET /orgs/{org}/hooks"],
pingWebhook: ["POST /orgs/{org}/hooks/{hook_id}/pings"],
redeliverWebhookDelivery: ["POST /orgs/{org}/hooks/{hook_id}/deliveries/{delivery_id}/attempts"],
removeMember: ["DELETE /orgs/{org}/members/{username}"],
removeMembershipForUser: ["DELETE /orgs/{org}/memberships/{username}"],
removeOutsideCollaborator: ["DELETE /orgs/{org}/outside_collaborators/{username}"],
removePublicMembershipForAuthenticatedUser: ["DELETE /orgs/{org}/public_members/{username}"],
setMembershipForUser: ["PUT /orgs/{org}/memberships/{username}"],
setPublicMembershipForAuthenticatedUser: ["PUT /orgs/{org}/public_members/{username}"],
unblockUser: ["DELETE /orgs/{org}/blocks/{username}"],
update: ["PATCH /orgs/{org}"],
updateMembershipForAuthenticatedUser: ["PATCH /user/memberships/orgs/{org}"],
updateWebhook: ["PATCH /orgs/{org}/hooks/{hook_id}"],
updateWebhookConfigForOrg: ["PATCH /orgs/{org}/hooks/{hook_id}/config"]
},
packages: {
deletePackageForAuthenticatedUser: ["DELETE /user/packages/{package_type}/{package_name}"],
deletePackageForOrg: ["DELETE /orgs/{org}/packages/{package_type}/{package_name}"],
deletePackageForUser: ["DELETE /users/{username}/packages/{package_type}/{package_name}"],
deletePackageVersionForAuthenticatedUser: ["DELETE /user/packages/{package_type}/{package_name}/versions/{package_version_id}"],
deletePackageVersionForOrg: ["DELETE /orgs/{org}/packages/{package_type}/{package_name}/versions/{package_version_id}"],
deletePackageVersionForUser: ["DELETE /users/{username}/packages/{package_type}/{package_name}/versions/{package_version_id}"],
getAllPackageVersionsForAPackageOwnedByAnOrg: ["GET /orgs/{org}/packages/{package_type}/{package_name}/versions", {}, {
renamed: ["packages", "getAllPackageVersionsForPackageOwnedByOrg"]
}],
getAllPackageVersionsForAPackageOwnedByTheAuthenticatedUser: ["GET /user/packages/{package_type}/{package_name}/versions", {}, {
renamed: ["packages", "getAllPackageVersionsForPackageOwnedByAuthenticatedUser"]
}],
getAllPackageVersionsForPackageOwnedByAuthenticatedUser: ["GET /user/packages/{package_type}/{package_name}/versions"],
getAllPackageVersionsForPackageOwnedByOrg: ["GET /orgs/{org}/packages/{package_type}/{package_name}/versions"],
getAllPackageVersionsForPackageOwnedByUser: ["GET /users/{username}/packages/{package_type}/{package_name}/versions"],
getPackageForAuthenticatedUser: ["GET /user/packages/{package_type}/{package_name}"],
getPackageForOrganization: ["GET /orgs/{org}/packages/{package_type}/{package_name}"],
getPackageForUser: ["GET /users/{username}/packages/{package_type}/{package_name}"],
getPackageVersionForAuthenticatedUser: ["GET /user/packages/{package_type}/{package_name}/versions/{package_version_id}"],
getPackageVersionForOrganization: ["GET /orgs/{org}/packages/{package_type}/{package_name}/versions/{package_version_id}"],
getPackageVersionForUser: ["GET /users/{username}/packages/{package_type}/{package_name}/versions/{package_version_id}"],
listPackagesForAuthenticatedUser: ["GET /user/packages"],
listPackagesForOrganization: ["GET /orgs/{org}/packages"],
listPackagesForUser: ["GET /users/{username}/packages"],
restorePackageForAuthenticatedUser: ["POST /user/packages/{package_type}/{package_name}/restore{?token}"],
restorePackageForOrg: ["POST /orgs/{org}/packages/{package_type}/{package_name}/restore{?token}"],
restorePackageForUser: ["POST /users/{username}/packages/{package_type}/{package_name}/restore{?token}"],
restorePackageVersionForAuthenticatedUser: ["POST /user/packages/{package_type}/{package_name}/versions/{package_version_id}/restore"],
restorePackageVersionForOrg: ["POST /orgs/{org}/packages/{package_type}/{package_name}/versions/{package_version_id}/restore"],
restorePackageVersionForUser: ["POST /users/{username}/packages/{package_type}/{package_name}/versions/{package_version_id}/restore"]
},
projects: {
addCollaborator: ["PUT /projects/{project_id}/collaborators/{username}"],
createCard: ["POST /projects/columns/{column_id}/cards"],
createColumn: ["POST /projects/{project_id}/columns"],
createForAuthenticatedUser: ["POST /user/projects"],
createForOrg: ["POST /orgs/{org}/projects"],
createForRepo: ["POST /repos/{owner}/{repo}/projects"],
delete: ["DELETE /projects/{project_id}"],
deleteCard: ["DELETE /projects/columns/cards/{card_id}"],
deleteColumn: ["DELETE /projects/columns/{column_id}"],
get: ["GET /projects/{project_id}"],
getCard: ["GET /projects/columns/cards/{card_id}"],
getColumn: ["GET /projects/columns/{column_id}"],
getPermissionForUser: ["GET /projects/{project_id}/collaborators/{username}/permission"],
listCards: ["GET /projects/columns/{column_id}/cards"],
listCollaborators: ["GET /projects/{project_id}/collaborators"],
listColumns: ["GET /projects/{project_id}/columns"],
listForOrg: ["GET /orgs/{org}/projects"],
listForRepo: ["GET /repos/{owner}/{repo}/projects"],
listForUser: ["GET /users/{username}/projects"],
moveCard: ["POST /projects/columns/cards/{card_id}/moves"],
moveColumn: ["POST /projects/columns/{column_id}/moves"],
removeCollaborator: ["DELETE /projects/{project_id}/collaborators/{username}"],
update: ["PATCH /projects/{project_id}"],
updateCard: ["PATCH /projects/columns/cards/{card_id}"],
updateColumn: ["PATCH /projects/columns/{column_id}"]
},
pulls: {
checkIfMerged: ["GET /repos/{owner}/{repo}/pulls/{pull_number}/merge"],
create: ["POST /repos/{owner}/{repo}/pulls"],
createReplyForReviewComment: ["POST /repos/{owner}/{repo}/pulls/{pull_number}/comments/{comment_id}/replies"],
createReview: ["POST /repos/{owner}/{repo}/pulls/{pull_number}/reviews"],
createReviewComment: ["POST /repos/{owner}/{repo}/pulls/{pull_number}/comments"],
deletePendingReview: ["DELETE /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}"],
deleteReviewComment: ["DELETE /repos/{owner}/{repo}/pulls/comments/{comment_id}"],
dismissReview: ["PUT /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/dismissals"],
get: ["GET /repos/{owner}/{repo}/pulls/{pull_number}"],
getReview: ["GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}"],
getReviewComment: ["GET /repos/{owner}/{repo}/pulls/comments/{comment_id}"],
list: ["GET /repos/{owner}/{repo}/pulls"],
listCommentsForReview: ["GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/comments"],
listCommits: ["GET /repos/{owner}/{repo}/pulls/{pull_number}/commits"],
listFiles: ["GET /repos/{owner}/{repo}/pulls/{pull_number}/files"],
listRequestedReviewers: ["GET /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers"],
listReviewComments: ["GET /repos/{owner}/{repo}/pulls/{pull_number}/comments"],
listReviewCommentsForRepo: ["GET /repos/{owner}/{repo}/pulls/comments"],
listReviews: ["GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews"],
merge: ["PUT /repos/{owner}/{repo}/pulls/{pull_number}/merge"],
removeRequestedReviewers: ["DELETE /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers"],
requestReviewers: ["POST /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers"],
submitReview: ["POST /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/events"],
update: ["PATCH /repos/{owner}/{repo}/pulls/{pull_number}"],
updateBranch: ["PUT /repos/{owner}/{repo}/pulls/{pull_number}/update-branch"],
updateReview: ["PUT /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}"],
updateReviewComment: ["PATCH /repos/{owner}/{repo}/pulls/comments/{comment_id}"]
},
rateLimit: {
get: ["GET /rate_limit"]
},
reactions: {
2022-05-31 14:18:28 -04:00
createForCommitComment: ["POST /repos/{owner}/{repo}/comments/{comment_id}/reactions"],
createForIssue: ["POST /repos/{owner}/{repo}/issues/{issue_number}/reactions"],
createForIssueComment: ["POST /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions"],
createForPullRequestReviewComment: ["POST /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions"],
createForRelease: ["POST /repos/{owner}/{repo}/releases/{release_id}/reactions"],
createForTeamDiscussionCommentInOrg: ["POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions"],
createForTeamDiscussionInOrg: ["POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions"],
deleteForCommitComment: ["DELETE /repos/{owner}/{repo}/comments/{comment_id}/reactions/{reaction_id}"],
deleteForIssue: ["DELETE /repos/{owner}/{repo}/issues/{issue_number}/reactions/{reaction_id}"],
deleteForIssueComment: ["DELETE /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions/{reaction_id}"],
deleteForPullRequestComment: ["DELETE /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions/{reaction_id}"],
deleteForTeamDiscussion: ["DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions/{reaction_id}"],
deleteForTeamDiscussionComment: ["DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions/{reaction_id}"],
listForCommitComment: ["GET /repos/{owner}/{repo}/comments/{comment_id}/reactions"],
listForIssue: ["GET /repos/{owner}/{repo}/issues/{issue_number}/reactions"],
listForIssueComment: ["GET /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions"],
listForPullRequestReviewComment: ["GET /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions"],
listForTeamDiscussionCommentInOrg: ["GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions"],
listForTeamDiscussionInOrg: ["GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions"]
2021-09-26 15:31:45 -04:00
},
repos: {
2022-05-31 14:18:28 -04:00
acceptInvitation: ["PATCH /user/repository_invitations/{invitation_id}", {}, {
renamed: ["repos", "acceptInvitationForAuthenticatedUser"]
}],
acceptInvitationForAuthenticatedUser: ["PATCH /user/repository_invitations/{invitation_id}"],
2021-09-26 15:31:45 -04:00
addAppAccessRestrictions: ["POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps", {}, {
mapToData: "apps"
}],
addCollaborator: ["PUT /repos/{owner}/{repo}/collaborators/{username}"],
addStatusCheckContexts: ["POST /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts", {}, {
mapToData: "contexts"
}],
addTeamAccessRestrictions: ["POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams", {}, {
mapToData: "teams"
}],
addUserAccessRestrictions: ["POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users", {}, {
mapToData: "users"
}],
checkCollaborator: ["GET /repos/{owner}/{repo}/collaborators/{username}"],
checkVulnerabilityAlerts: ["GET /repos/{owner}/{repo}/vulnerability-alerts"],
compareCommits: ["GET /repos/{owner}/{repo}/compare/{base}...{head}"],
compareCommitsWithBasehead: ["GET /repos/{owner}/{repo}/compare/{basehead}"],
createAutolink: ["POST /repos/{owner}/{repo}/autolinks"],
createCommitComment: ["POST /repos/{owner}/{repo}/commits/{commit_sha}/comments"],
2022-05-31 14:18:28 -04:00
createCommitSignatureProtection: ["POST /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures"],
2021-09-26 15:31:45 -04:00
createCommitStatus: ["POST /repos/{owner}/{repo}/statuses/{sha}"],
createDeployKey: ["POST /repos/{owner}/{repo}/keys"],
createDeployment: ["POST /repos/{owner}/{repo}/deployments"],
createDeploymentStatus: ["POST /repos/{owner}/{repo}/deployments/{deployment_id}/statuses"],
createDispatchEvent: ["POST /repos/{owner}/{repo}/dispatches"],
createForAuthenticatedUser: ["POST /user/repos"],
createFork: ["POST /repos/{owner}/{repo}/forks"],
createInOrg: ["POST /orgs/{org}/repos"],
createOrUpdateEnvironment: ["PUT /repos/{owner}/{repo}/environments/{environment_name}"],
createOrUpdateFileContents: ["PUT /repos/{owner}/{repo}/contents/{path}"],
2022-05-31 14:18:28 -04:00
createPagesSite: ["POST /repos/{owner}/{repo}/pages"],
2021-09-26 15:31:45 -04:00
createRelease: ["POST /repos/{owner}/{repo}/releases"],
2022-05-31 14:18:28 -04:00
createUsingTemplate: ["POST /repos/{template_owner}/{template_repo}/generate"],
2021-09-26 15:31:45 -04:00
createWebhook: ["POST /repos/{owner}/{repo}/hooks"],
2022-05-31 14:18:28 -04:00
declineInvitation: ["DELETE /user/repository_invitations/{invitation_id}", {}, {
renamed: ["repos", "declineInvitationForAuthenticatedUser"]
}],
declineInvitationForAuthenticatedUser: ["DELETE /user/repository_invitations/{invitation_id}"],
2021-09-26 15:31:45 -04:00
delete: ["DELETE /repos/{owner}/{repo}"],
deleteAccessRestrictions: ["DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions"],
deleteAdminBranchProtection: ["DELETE /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins"],
deleteAnEnvironment: ["DELETE /repos/{owner}/{repo}/environments/{environment_name}"],
deleteAutolink: ["DELETE /repos/{owner}/{repo}/autolinks/{autolink_id}"],
deleteBranchProtection: ["DELETE /repos/{owner}/{repo}/branches/{branch}/protection"],
deleteCommitComment: ["DELETE /repos/{owner}/{repo}/comments/{comment_id}"],
2022-05-31 14:18:28 -04:00
deleteCommitSignatureProtection: ["DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures"],
2021-09-26 15:31:45 -04:00
deleteDeployKey: ["DELETE /repos/{owner}/{repo}/keys/{key_id}"],
deleteDeployment: ["DELETE /repos/{owner}/{repo}/deployments/{deployment_id}"],
deleteFile: ["DELETE /repos/{owner}/{repo}/contents/{path}"],
deleteInvitation: ["DELETE /repos/{owner}/{repo}/invitations/{invitation_id}"],
2022-05-31 14:18:28 -04:00
deletePagesSite: ["DELETE /repos/{owner}/{repo}/pages"],
2021-09-26 15:31:45 -04:00
deletePullRequestReviewProtection: ["DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews"],
deleteRelease: ["DELETE /repos/{owner}/{repo}/releases/{release_id}"],
deleteReleaseAsset: ["DELETE /repos/{owner}/{repo}/releases/assets/{asset_id}"],
deleteWebhook: ["DELETE /repos/{owner}/{repo}/hooks/{hook_id}"],
disableAutomatedSecurityFixes: ["DELETE /repos/{owner}/{repo}/automated-security-fixes"],
disableLfsForRepo: ["DELETE /repos/{owner}/{repo}/lfs"],
disableVulnerabilityAlerts: ["DELETE /repos/{owner}/{repo}/vulnerability-alerts"],
downloadArchive: ["GET /repos/{owner}/{repo}/zipball/{ref}", {}, {
renamed: ["repos", "downloadZipballArchive"]
}],
downloadTarballArchive: ["GET /repos/{owner}/{repo}/tarball/{ref}"],
downloadZipballArchive: ["GET /repos/{owner}/{repo}/zipball/{ref}"],
enableAutomatedSecurityFixes: ["PUT /repos/{owner}/{repo}/automated-security-fixes"],
enableLfsForRepo: ["PUT /repos/{owner}/{repo}/lfs"],
enableVulnerabilityAlerts: ["PUT /repos/{owner}/{repo}/vulnerability-alerts"],
2022-05-31 14:18:28 -04:00
generateReleaseNotes: ["POST /repos/{owner}/{repo}/releases/generate-notes"],
2021-09-26 15:31:45 -04:00
get: ["GET /repos/{owner}/{repo}"],
getAccessRestrictions: ["GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions"],
getAdminBranchProtection: ["GET /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins"],
getAllEnvironments: ["GET /repos/{owner}/{repo}/environments"],
getAllStatusCheckContexts: ["GET /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts"],
getAllTopics: ["GET /repos/{owner}/{repo}/topics", {
mediaType: {
previews: ["mercy"]
}
}],
getAppsWithAccessToProtectedBranch: ["GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps"],
getAutolink: ["GET /repos/{owner}/{repo}/autolinks/{autolink_id}"],
getBranch: ["GET /repos/{owner}/{repo}/branches/{branch}"],
getBranchProtection: ["GET /repos/{owner}/{repo}/branches/{branch}/protection"],
getClones: ["GET /repos/{owner}/{repo}/traffic/clones"],
getCodeFrequencyStats: ["GET /repos/{owner}/{repo}/stats/code_frequency"],
getCollaboratorPermissionLevel: ["GET /repos/{owner}/{repo}/collaborators/{username}/permission"],
getCombinedStatusForRef: ["GET /repos/{owner}/{repo}/commits/{ref}/status"],
getCommit: ["GET /repos/{owner}/{repo}/commits/{ref}"],
getCommitActivityStats: ["GET /repos/{owner}/{repo}/stats/commit_activity"],
getCommitComment: ["GET /repos/{owner}/{repo}/comments/{comment_id}"],
2022-05-31 14:18:28 -04:00
getCommitSignatureProtection: ["GET /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures"],
2021-09-26 15:31:45 -04:00
getCommunityProfileMetrics: ["GET /repos/{owner}/{repo}/community/profile"],
getContent: ["GET /repos/{owner}/{repo}/contents/{path}"],
getContributorsStats: ["GET /repos/{owner}/{repo}/stats/contributors"],
getDeployKey: ["GET /repos/{owner}/{repo}/keys/{key_id}"],
getDeployment: ["GET /repos/{owner}/{repo}/deployments/{deployment_id}"],
getDeploymentStatus: ["GET /repos/{owner}/{repo}/deployments/{deployment_id}/statuses/{status_id}"],
getEnvironment: ["GET /repos/{owner}/{repo}/environments/{environment_name}"],
getLatestPagesBuild: ["GET /repos/{owner}/{repo}/pages/builds/latest"],
getLatestRelease: ["GET /repos/{owner}/{repo}/releases/latest"],
getPages: ["GET /repos/{owner}/{repo}/pages"],
getPagesBuild: ["GET /repos/{owner}/{repo}/pages/builds/{build_id}"],
getPagesHealthCheck: ["GET /repos/{owner}/{repo}/pages/health"],
getParticipationStats: ["GET /repos/{owner}/{repo}/stats/participation"],
getPullRequestReviewProtection: ["GET /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews"],
getPunchCardStats: ["GET /repos/{owner}/{repo}/stats/punch_card"],
getReadme: ["GET /repos/{owner}/{repo}/readme"],
getReadmeInDirectory: ["GET /repos/{owner}/{repo}/readme/{dir}"],
getRelease: ["GET /repos/{owner}/{repo}/releases/{release_id}"],
getReleaseAsset: ["GET /repos/{owner}/{repo}/releases/assets/{asset_id}"],
getReleaseByTag: ["GET /repos/{owner}/{repo}/releases/tags/{tag}"],
getStatusChecksProtection: ["GET /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks"],
getTeamsWithAccessToProtectedBranch: ["GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams"],
getTopPaths: ["GET /repos/{owner}/{repo}/traffic/popular/paths"],
getTopReferrers: ["GET /repos/{owner}/{repo}/traffic/popular/referrers"],
getUsersWithAccessToProtectedBranch: ["GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users"],
getViews: ["GET /repos/{owner}/{repo}/traffic/views"],
getWebhook: ["GET /repos/{owner}/{repo}/hooks/{hook_id}"],
getWebhookConfigForRepo: ["GET /repos/{owner}/{repo}/hooks/{hook_id}/config"],
getWebhookDelivery: ["GET /repos/{owner}/{repo}/hooks/{hook_id}/deliveries/{delivery_id}"],
listAutolinks: ["GET /repos/{owner}/{repo}/autolinks"],
listBranches: ["GET /repos/{owner}/{repo}/branches"],
listBranchesForHeadCommit: ["GET /repos/{owner}/{repo}/commits/{commit_sha}/branches-where-head"],
listCollaborators: ["GET /repos/{owner}/{repo}/collaborators"],
listCommentsForCommit: ["GET /repos/{owner}/{repo}/commits/{commit_sha}/comments"],
listCommitCommentsForRepo: ["GET /repos/{owner}/{repo}/comments"],
listCommitStatusesForRef: ["GET /repos/{owner}/{repo}/commits/{ref}/statuses"],
listCommits: ["GET /repos/{owner}/{repo}/commits"],
listContributors: ["GET /repos/{owner}/{repo}/contributors"],
listDeployKeys: ["GET /repos/{owner}/{repo}/keys"],
listDeploymentStatuses: ["GET /repos/{owner}/{repo}/deployments/{deployment_id}/statuses"],
listDeployments: ["GET /repos/{owner}/{repo}/deployments"],
listForAuthenticatedUser: ["GET /user/repos"],
listForOrg: ["GET /orgs/{org}/repos"],
listForUser: ["GET /users/{username}/repos"],
listForks: ["GET /repos/{owner}/{repo}/forks"],
listInvitations: ["GET /repos/{owner}/{repo}/invitations"],
listInvitationsForAuthenticatedUser: ["GET /user/repository_invitations"],
listLanguages: ["GET /repos/{owner}/{repo}/languages"],
listPagesBuilds: ["GET /repos/{owner}/{repo}/pages/builds"],
listPublic: ["GET /repositories"],
listPullRequestsAssociatedWithCommit: ["GET /repos/{owner}/{repo}/commits/{commit_sha}/pulls"],
listReleaseAssets: ["GET /repos/{owner}/{repo}/releases/{release_id}/assets"],
listReleases: ["GET /repos/{owner}/{repo}/releases"],
listTags: ["GET /repos/{owner}/{repo}/tags"],
listTeams: ["GET /repos/{owner}/{repo}/teams"],
listWebhookDeliveries: ["GET /repos/{owner}/{repo}/hooks/{hook_id}/deliveries"],
listWebhooks: ["GET /repos/{owner}/{repo}/hooks"],
merge: ["POST /repos/{owner}/{repo}/merges"],
mergeUpstream: ["POST /repos/{owner}/{repo}/merge-upstream"],
pingWebhook: ["POST /repos/{owner}/{repo}/hooks/{hook_id}/pings"],
redeliverWebhookDelivery: ["POST /repos/{owner}/{repo}/hooks/{hook_id}/deliveries/{delivery_id}/attempts"],
removeAppAccessRestrictions: ["DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps", {}, {
mapToData: "apps"
}],
removeCollaborator: ["DELETE /repos/{owner}/{repo}/collaborators/{username}"],
removeStatusCheckContexts: ["DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts", {}, {
mapToData: "contexts"
}],
removeStatusCheckProtection: ["DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks"],
removeTeamAccessRestrictions: ["DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams", {}, {
mapToData: "teams"
}],
removeUserAccessRestrictions: ["DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users", {}, {
mapToData: "users"
}],
renameBranch: ["POST /repos/{owner}/{repo}/branches/{branch}/rename"],
replaceAllTopics: ["PUT /repos/{owner}/{repo}/topics", {
mediaType: {
previews: ["mercy"]
}
}],
requestPagesBuild: ["POST /repos/{owner}/{repo}/pages/builds"],
setAdminBranchProtection: ["POST /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins"],
setAppAccessRestrictions: ["PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps", {}, {
mapToData: "apps"
}],
setStatusCheckContexts: ["PUT /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts", {}, {
mapToData: "contexts"
}],
setTeamAccessRestrictions: ["PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams", {}, {
mapToData: "teams"
}],
setUserAccessRestrictions: ["PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users", {}, {
mapToData: "users"
}],
testPushWebhook: ["POST /repos/{owner}/{repo}/hooks/{hook_id}/tests"],
transfer: ["POST /repos/{owner}/{repo}/transfer"],
update: ["PATCH /repos/{owner}/{repo}"],
updateBranchProtection: ["PUT /repos/{owner}/{repo}/branches/{branch}/protection"],
updateCommitComment: ["PATCH /repos/{owner}/{repo}/comments/{comment_id}"],
updateInformationAboutPagesSite: ["PUT /repos/{owner}/{repo}/pages"],
updateInvitation: ["PATCH /repos/{owner}/{repo}/invitations/{invitation_id}"],
updatePullRequestReviewProtection: ["PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews"],
updateRelease: ["PATCH /repos/{owner}/{repo}/releases/{release_id}"],
updateReleaseAsset: ["PATCH /repos/{owner}/{repo}/releases/assets/{asset_id}"],
updateStatusCheckPotection: ["PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks", {}, {
renamed: ["repos", "updateStatusCheckProtection"]
}],
updateStatusCheckProtection: ["PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks"],
updateWebhook: ["PATCH /repos/{owner}/{repo}/hooks/{hook_id}"],
updateWebhookConfigForRepo: ["PATCH /repos/{owner}/{repo}/hooks/{hook_id}/config"],
uploadReleaseAsset: ["POST /repos/{owner}/{repo}/releases/{release_id}/assets{?name,label}", {
baseUrl: "https://uploads.github.com"
}]
},
search: {
code: ["GET /search/code"],
2022-05-31 14:18:28 -04:00
commits: ["GET /search/commits"],
2021-09-26 15:31:45 -04:00
issuesAndPullRequests: ["GET /search/issues"],
labels: ["GET /search/labels"],
repos: ["GET /search/repositories"],
topics: ["GET /search/topics", {
mediaType: {
previews: ["mercy"]
}
}],
users: ["GET /search/users"]
},
secretScanning: {
getAlert: ["GET /repos/{owner}/{repo}/secret-scanning/alerts/{alert_number}"],
listAlertsForOrg: ["GET /orgs/{org}/secret-scanning/alerts"],
listAlertsForRepo: ["GET /repos/{owner}/{repo}/secret-scanning/alerts"],
updateAlert: ["PATCH /repos/{owner}/{repo}/secret-scanning/alerts/{alert_number}"]
},
teams: {
addOrUpdateMembershipForUserInOrg: ["PUT /orgs/{org}/teams/{team_slug}/memberships/{username}"],
addOrUpdateProjectPermissionsInOrg: ["PUT /orgs/{org}/teams/{team_slug}/projects/{project_id}"],
addOrUpdateRepoPermissionsInOrg: ["PUT /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}"],
checkPermissionsForProjectInOrg: ["GET /orgs/{org}/teams/{team_slug}/projects/{project_id}"],
checkPermissionsForRepoInOrg: ["GET /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}"],
create: ["POST /orgs/{org}/teams"],
createDiscussionCommentInOrg: ["POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments"],
createDiscussionInOrg: ["POST /orgs/{org}/teams/{team_slug}/discussions"],
deleteDiscussionCommentInOrg: ["DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}"],
deleteDiscussionInOrg: ["DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}"],
deleteInOrg: ["DELETE /orgs/{org}/teams/{team_slug}"],
getByName: ["GET /orgs/{org}/teams/{team_slug}"],
getDiscussionCommentInOrg: ["GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}"],
getDiscussionInOrg: ["GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}"],
getMembershipForUserInOrg: ["GET /orgs/{org}/teams/{team_slug}/memberships/{username}"],
list: ["GET /orgs/{org}/teams"],
listChildInOrg: ["GET /orgs/{org}/teams/{team_slug}/teams"],
listDiscussionCommentsInOrg: ["GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments"],
listDiscussionsInOrg: ["GET /orgs/{org}/teams/{team_slug}/discussions"],
listForAuthenticatedUser: ["GET /user/teams"],
listMembersInOrg: ["GET /orgs/{org}/teams/{team_slug}/members"],
listPendingInvitationsInOrg: ["GET /orgs/{org}/teams/{team_slug}/invitations"],
listProjectsInOrg: ["GET /orgs/{org}/teams/{team_slug}/projects"],
listReposInOrg: ["GET /orgs/{org}/teams/{team_slug}/repos"],
removeMembershipForUserInOrg: ["DELETE /orgs/{org}/teams/{team_slug}/memberships/{username}"],
removeProjectInOrg: ["DELETE /orgs/{org}/teams/{team_slug}/projects/{project_id}"],
removeRepoInOrg: ["DELETE /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}"],
updateDiscussionCommentInOrg: ["PATCH /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}"],
updateDiscussionInOrg: ["PATCH /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}"],
updateInOrg: ["PATCH /orgs/{org}/teams/{team_slug}"]
},
users: {
2022-05-31 14:18:28 -04:00
addEmailForAuthenticated: ["POST /user/emails", {}, {
renamed: ["users", "addEmailForAuthenticatedUser"]
}],
addEmailForAuthenticatedUser: ["POST /user/emails"],
2021-09-26 15:31:45 -04:00
block: ["PUT /user/blocks/{username}"],
checkBlocked: ["GET /user/blocks/{username}"],
checkFollowingForUser: ["GET /users/{username}/following/{target_user}"],
checkPersonIsFollowedByAuthenticated: ["GET /user/following/{username}"],
2022-05-31 14:18:28 -04:00
createGpgKeyForAuthenticated: ["POST /user/gpg_keys", {}, {
renamed: ["users", "createGpgKeyForAuthenticatedUser"]
}],
createGpgKeyForAuthenticatedUser: ["POST /user/gpg_keys"],
createPublicSshKeyForAuthenticated: ["POST /user/keys", {}, {
renamed: ["users", "createPublicSshKeyForAuthenticatedUser"]
}],
createPublicSshKeyForAuthenticatedUser: ["POST /user/keys"],
deleteEmailForAuthenticated: ["DELETE /user/emails", {}, {
renamed: ["users", "deleteEmailForAuthenticatedUser"]
}],
deleteEmailForAuthenticatedUser: ["DELETE /user/emails"],
deleteGpgKeyForAuthenticated: ["DELETE /user/gpg_keys/{gpg_key_id}", {}, {
renamed: ["users", "deleteGpgKeyForAuthenticatedUser"]
}],
deleteGpgKeyForAuthenticatedUser: ["DELETE /user/gpg_keys/{gpg_key_id}"],
deletePublicSshKeyForAuthenticated: ["DELETE /user/keys/{key_id}", {}, {
renamed: ["users", "deletePublicSshKeyForAuthenticatedUser"]
}],
deletePublicSshKeyForAuthenticatedUser: ["DELETE /user/keys/{key_id}"],
2021-09-26 15:31:45 -04:00
follow: ["PUT /user/following/{username}"],
getAuthenticated: ["GET /user"],
getByUsername: ["GET /users/{username}"],
getContextForUser: ["GET /users/{username}/hovercard"],
2022-05-31 14:18:28 -04:00
getGpgKeyForAuthenticated: ["GET /user/gpg_keys/{gpg_key_id}", {}, {
renamed: ["users", "getGpgKeyForAuthenticatedUser"]
}],
getGpgKeyForAuthenticatedUser: ["GET /user/gpg_keys/{gpg_key_id}"],
getPublicSshKeyForAuthenticated: ["GET /user/keys/{key_id}", {}, {
renamed: ["users", "getPublicSshKeyForAuthenticatedUser"]
}],
getPublicSshKeyForAuthenticatedUser: ["GET /user/keys/{key_id}"],
2021-09-26 15:31:45 -04:00
list: ["GET /users"],
2022-05-31 14:18:28 -04:00
listBlockedByAuthenticated: ["GET /user/blocks", {}, {
renamed: ["users", "listBlockedByAuthenticatedUser"]
}],
listBlockedByAuthenticatedUser: ["GET /user/blocks"],
listEmailsForAuthenticated: ["GET /user/emails", {}, {
renamed: ["users", "listEmailsForAuthenticatedUser"]
}],
listEmailsForAuthenticatedUser: ["GET /user/emails"],
listFollowedByAuthenticated: ["GET /user/following", {}, {
renamed: ["users", "listFollowedByAuthenticatedUser"]
}],
listFollowedByAuthenticatedUser: ["GET /user/following"],
2021-09-26 15:31:45 -04:00
listFollowersForAuthenticatedUser: ["GET /user/followers"],
listFollowersForUser: ["GET /users/{username}/followers"],
listFollowingForUser: ["GET /users/{username}/following"],
2022-05-31 14:18:28 -04:00
listGpgKeysForAuthenticated: ["GET /user/gpg_keys", {}, {
renamed: ["users", "listGpgKeysForAuthenticatedUser"]
}],
listGpgKeysForAuthenticatedUser: ["GET /user/gpg_keys"],
2021-09-26 15:31:45 -04:00
listGpgKeysForUser: ["GET /users/{username}/gpg_keys"],
2022-05-31 14:18:28 -04:00
listPublicEmailsForAuthenticated: ["GET /user/public_emails", {}, {
renamed: ["users", "listPublicEmailsForAuthenticatedUser"]
}],
listPublicEmailsForAuthenticatedUser: ["GET /user/public_emails"],
2021-09-26 15:31:45 -04:00
listPublicKeysForUser: ["GET /users/{username}/keys"],
2022-05-31 14:18:28 -04:00
listPublicSshKeysForAuthenticated: ["GET /user/keys", {}, {
renamed: ["users", "listPublicSshKeysForAuthenticatedUser"]
}],
listPublicSshKeysForAuthenticatedUser: ["GET /user/keys"],
setPrimaryEmailVisibilityForAuthenticated: ["PATCH /user/email/visibility", {}, {
renamed: ["users", "setPrimaryEmailVisibilityForAuthenticatedUser"]
}],
setPrimaryEmailVisibilityForAuthenticatedUser: ["PATCH /user/email/visibility"],
2021-09-26 15:31:45 -04:00
unblock: ["DELETE /user/blocks/{username}"],
unfollow: ["DELETE /user/following/{username}"],
updateAuthenticated: ["PATCH /user"]
}
};
2022-05-31 14:18:28 -04:00
const VERSION = "5.13.0";
2021-09-26 15:31:45 -04:00
function endpointsToMethods(octokit, endpointsMap) {
const newMethods = {};
for (const [scope, endpoints] of Object.entries(endpointsMap)) {
for (const [methodName, endpoint] of Object.entries(endpoints)) {
const [route, defaults, decorations] = endpoint;
const [method, url] = route.split(/ /);
const endpointDefaults = Object.assign({
method,
url
}, defaults);
if (!newMethods[scope]) {
newMethods[scope] = {};
}
const scopeMethods = newMethods[scope];
if (decorations) {
scopeMethods[methodName] = decorate(octokit, scope, methodName, endpointDefaults, decorations);
continue;
}
scopeMethods[methodName] = octokit.request.defaults(endpointDefaults);
}
}
return newMethods;
}
function decorate(octokit, scope, methodName, defaults, decorations) {
const requestWithDefaults = octokit.request.defaults(defaults);
/* istanbul ignore next */
function withDecorations(...args) {
// @ts-ignore https://github.com/microsoft/TypeScript/issues/25488
let options = requestWithDefaults.endpoint.merge(...args); // There are currently no other decorations than `.mapToData`
if (decorations.mapToData) {
options = Object.assign({}, options, {
data: options[decorations.mapToData],
[decorations.mapToData]: undefined
});
return requestWithDefaults(options);
}
if (decorations.renamed) {
const [newScope, newMethodName] = decorations.renamed;
octokit.log.warn(`octokit.${scope}.${methodName}() has been renamed to octokit.${newScope}.${newMethodName}()`);
}
if (decorations.deprecated) {
octokit.log.warn(decorations.deprecated);
}
if (decorations.renamedParameters) {
// @ts-ignore https://github.com/microsoft/TypeScript/issues/25488
const options = requestWithDefaults.endpoint.merge(...args);
for (const [name, alias] of Object.entries(decorations.renamedParameters)) {
if (name in options) {
octokit.log.warn(`"${name}" parameter is deprecated for "octokit.${scope}.${methodName}()". Use "${alias}" instead`);
if (!(alias in options)) {
options[alias] = options[name];
}
delete options[name];
}
}
return requestWithDefaults(options);
} // @ts-ignore https://github.com/microsoft/TypeScript/issues/25488
return requestWithDefaults(...args);
}
return Object.assign(withDecorations, requestWithDefaults);
}
function restEndpointMethods(octokit) {
const api = endpointsToMethods(octokit, Endpoints);
return {
rest: api
};
}
restEndpointMethods.VERSION = VERSION;
function legacyRestEndpointMethods(octokit) {
const api = endpointsToMethods(octokit, Endpoints);
return _objectSpread2(_objectSpread2({}, api), {}, {
rest: api
});
}
legacyRestEndpointMethods.VERSION = VERSION;
exports.legacyRestEndpointMethods = legacyRestEndpointMethods;
exports.restEndpointMethods = restEndpointMethods;
//# sourceMappingURL=index.js.map
/***/ }),
/***/ 537:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
var deprecation = __nccwpck_require__(8932);
var once = _interopDefault(__nccwpck_require__(1223));
const logOnceCode = once(deprecation => console.warn(deprecation));
const logOnceHeaders = once(deprecation => console.warn(deprecation));
/**
* Error with extra properties to help with debugging
*/
class RequestError extends Error {
constructor(message, statusCode, options) {
super(message); // Maintains proper stack trace (only available on V8)
/* istanbul ignore next */
if (Error.captureStackTrace) {
Error.captureStackTrace(this, this.constructor);
}
this.name = "HttpError";
this.status = statusCode;
let headers;
if ("headers" in options && typeof options.headers !== "undefined") {
headers = options.headers;
}
if ("response" in options) {
this.response = options.response;
headers = options.response.headers;
} // redact request credentials without mutating original request options
const requestCopy = Object.assign({}, options.request);
if (options.request.headers.authorization) {
requestCopy.headers = Object.assign({}, options.request.headers, {
authorization: options.request.headers.authorization.replace(/ .*$/, " [REDACTED]")
});
}
requestCopy.url = requestCopy.url // client_id & client_secret can be passed as URL query parameters to increase rate limit
// see https://developer.github.com/v3/#increasing-the-unauthenticated-rate-limit-for-oauth-applications
.replace(/\bclient_secret=\w+/g, "client_secret=[REDACTED]") // OAuth tokens can be passed as URL query parameters, although it is not recommended
// see https://developer.github.com/v3/#oauth2-token-sent-in-a-header
.replace(/\baccess_token=\w+/g, "access_token=[REDACTED]");
this.request = requestCopy; // deprecations
Object.defineProperty(this, "code", {
get() {
logOnceCode(new deprecation.Deprecation("[@octokit/request-error] `error.code` is deprecated, use `error.status`."));
return statusCode;
}
});
Object.defineProperty(this, "headers", {
get() {
logOnceHeaders(new deprecation.Deprecation("[@octokit/request-error] `error.headers` is deprecated, use `error.response.headers`."));
return headers || {};
}
});
}
}
exports.RequestError = RequestError;
//# sourceMappingURL=index.js.map
/***/ }),
2021-10-01 09:38:36 -04:00
/***/ 5712:
2021-09-26 15:31:45 -04:00
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
var endpoint = __nccwpck_require__(9440);
var universalUserAgent = __nccwpck_require__(5030);
var isPlainObject = __nccwpck_require__(3287);
2022-05-31 14:18:28 -04:00
var nodeFetch = _interopDefault(__nccwpck_require__(467));
2021-09-26 15:31:45 -04:00
var requestError = __nccwpck_require__(537);
2022-05-31 14:18:28 -04:00
const VERSION = "5.6.3";
2021-09-26 15:31:45 -04:00
function getBufferResponse(response) {
return response.arrayBuffer();
}
function fetchWrapper(requestOptions) {
const log = requestOptions.request && requestOptions.request.log ? requestOptions.request.log : console;
if (isPlainObject.isPlainObject(requestOptions.body) || Array.isArray(requestOptions.body)) {
requestOptions.body = JSON.stringify(requestOptions.body);
}
let headers = {};
let status;
let url;
const fetch = requestOptions.request && requestOptions.request.fetch || nodeFetch;
return fetch(requestOptions.url, Object.assign({
method: requestOptions.method,
body: requestOptions.body,
headers: requestOptions.headers,
redirect: requestOptions.redirect
}, // `requestOptions.request.agent` type is incompatible
// see https://github.com/octokit/types.ts/pull/264
requestOptions.request)).then(async response => {
url = response.url;
status = response.status;
for (const keyAndValue of response.headers) {
headers[keyAndValue[0]] = keyAndValue[1];
}
if ("deprecation" in headers) {
const matches = headers.link && headers.link.match(/<([^>]+)>; rel="deprecation"/);
const deprecationLink = matches && matches.pop();
log.warn(`[@octokit/request] "${requestOptions.method} ${requestOptions.url}" is deprecated. It is scheduled to be removed on ${headers.sunset}${deprecationLink ? `. See ${deprecationLink}` : ""}`);
}
if (status === 204 || status === 205) {
return;
} // GitHub API returns 200 for HEAD requests
if (requestOptions.method === "HEAD") {
if (status < 400) {
return;
}
throw new requestError.RequestError(response.statusText, status, {
response: {
url,
status,
headers,
data: undefined
},
request: requestOptions
});
}
if (status === 304) {
throw new requestError.RequestError("Not modified", status, {
response: {
url,
status,
headers,
data: await getResponseData(response)
},
request: requestOptions
});
}
if (status >= 400) {
const data = await getResponseData(response);
const error = new requestError.RequestError(toErrorMessage(data), status, {
response: {
url,
status,
headers,
data
},
request: requestOptions
});
throw error;
}
return getResponseData(response);
}).then(data => {
return {
status,
url,
headers,
data
};
}).catch(error => {
if (error instanceof requestError.RequestError) throw error;
throw new requestError.RequestError(error.message, 500, {
request: requestOptions
});
});
}
async function getResponseData(response) {
const contentType = response.headers.get("content-type");
if (/application\/json/.test(contentType)) {
return response.json();
}
if (!contentType || /^text\/|charset=utf-8$/.test(contentType)) {
return response.text();
}
return getBufferResponse(response);
}
function toErrorMessage(data) {
if (typeof data === "string") return data; // istanbul ignore else - just in case
if ("message" in data) {
if (Array.isArray(data.errors)) {
return `${data.message}: ${data.errors.map(JSON.stringify).join(", ")}`;
}
return data.message;
} // istanbul ignore next - just in case
return `Unknown error: ${JSON.stringify(data)}`;
}
function withDefaults(oldEndpoint, newDefaults) {
const endpoint = oldEndpoint.defaults(newDefaults);
const newApi = function (route, parameters) {
const endpointOptions = endpoint.merge(route, parameters);
if (!endpointOptions.request || !endpointOptions.request.hook) {
return fetchWrapper(endpoint.parse(endpointOptions));
}
const request = (route, parameters) => {
return fetchWrapper(endpoint.parse(endpoint.merge(route, parameters)));
};
Object.assign(request, {
endpoint,
defaults: withDefaults.bind(null, endpoint)
});
return endpointOptions.request.hook(request, endpointOptions);
};
return Object.assign(newApi, {
endpoint,
defaults: withDefaults.bind(null, endpoint)
});
}
const request = withDefaults(endpoint.endpoint, {
headers: {
"user-agent": `octokit-request.js/${VERSION} ${universalUserAgent.getUserAgent()}`
}
});
exports.request = request;
//# sourceMappingURL=index.js.map
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 3682:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var register = __nccwpck_require__(4670)
var addHook = __nccwpck_require__(5549)
var removeHook = __nccwpck_require__(6819)
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// bind with array of arguments: https://stackoverflow.com/a/21792913
var bind = Function.bind
var bindable = bind.bind(bind)
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function bindApi (hook, state, name) {
var removeHookRef = bindable(removeHook, null).apply(null, name ? [state, name] : [state])
hook.api = { remove: removeHookRef }
hook.remove = removeHookRef
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
;['before', 'error', 'after', 'wrap'].forEach(function (kind) {
var args = name ? [state, kind, name] : [state, kind]
hook[kind] = hook.api[kind] = bindable(addHook, null).apply(null, args)
})
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function HookSingular () {
var singularHookName = 'h'
var singularHookState = {
registry: {}
}
var singularHook = register.bind(null, singularHookState, singularHookName)
bindApi(singularHook, singularHookState, singularHookName)
return singularHook
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function HookCollection () {
var state = {
registry: {}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var hook = register.bind(null, state)
bindApi(hook, state)
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return hook
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var collectionHookDeprecationMessageDisplayed = false
function Hook () {
if (!collectionHookDeprecationMessageDisplayed) {
console.warn('[before-after-hook]: "Hook()" repurposing warning, use "Hook.Collection()". Read more: https://git.io/upgrade-before-after-hook-to-1.4')
collectionHookDeprecationMessageDisplayed = true
}
return HookCollection()
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Hook.Singular = HookSingular.bind()
Hook.Collection = HookCollection.bind()
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = Hook
// expose constructors as a named property for TypeScript
module.exports.Hook = Hook
module.exports.Singular = Hook.Singular
module.exports.Collection = Hook.Collection
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 5549:
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = addHook;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function addHook(state, kind, name, hook) {
var orig = hook;
if (!state.registry[name]) {
state.registry[name] = [];
}
if (kind === "before") {
hook = function (method, options) {
return Promise.resolve()
.then(orig.bind(null, options))
.then(method.bind(null, options));
};
}
if (kind === "after") {
hook = function (method, options) {
var result;
return Promise.resolve()
.then(method.bind(null, options))
.then(function (result_) {
result = result_;
return orig(result, options);
})
.then(function () {
return result;
});
};
}
if (kind === "error") {
hook = function (method, options) {
return Promise.resolve()
.then(method.bind(null, options))
.catch(function (error) {
return orig(error, options);
});
};
}
state.registry[name].push({
hook: hook,
orig: orig,
});
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 4670:
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = register;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function register(state, name, method, options) {
if (typeof method !== "function") {
throw new Error("method for before hook must be a function");
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!options) {
options = {};
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (Array.isArray(name)) {
return name.reverse().reduce(function (callback, name) {
return register.bind(null, state, name, callback, options);
}, method)();
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return Promise.resolve().then(function () {
if (!state.registry[name]) {
return method(options);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return state.registry[name].reduce(function (method, registered) {
return registered.hook.bind(null, method, options);
}, method)();
});
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 6819:
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = removeHook;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function removeHook(state, name, method) {
if (!state.registry[name]) {
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var index = state.registry[name]
.map(function (registered) {
return registered.orig;
})
.indexOf(method);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (index === -1) {
return;
}
state.registry[name].splice(index, 1);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 610:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const stringify = __nccwpck_require__(8750);
const compile = __nccwpck_require__(9434);
const expand = __nccwpck_require__(5873);
const parse = __nccwpck_require__(6477);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Expand the given pattern or create a regex-compatible string.
*
* ```js
* const braces = require('braces');
* console.log(braces('{a,b,c}', { compile: true })); //=> ['(a|b|c)']
* console.log(braces('{a,b,c}')); //=> ['a', 'b', 'c']
* ```
* @param {String} `str`
* @param {Object} `options`
* @return {String}
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const braces = (input, options = {}) => {
let output = [];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (Array.isArray(input)) {
for (let pattern of input) {
let result = braces.create(pattern, options);
if (Array.isArray(result)) {
output.push(...result);
} else {
output.push(result);
}
}
} else {
output = [].concat(braces.create(input, options));
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (options && options.expand === true && options.nodupes === true) {
output = [...new Set(output)];
}
return output;
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
/**
* Parse the given `str` with the given `options`.
*
* ```js
* // braces.parse(pattern, [, options]);
* const ast = braces.parse('a/{b,c}/d');
* console.log(ast);
* ```
* @param {String} pattern Brace pattern to parse
* @param {Object} options
* @return {Object} Returns an AST
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
braces.parse = (input, options = {}) => parse(input, options);
/**
* Creates a braces string from an AST, or an AST node.
*
* ```js
* const braces = require('braces');
* let ast = braces.parse('foo/{a,b}/bar');
* console.log(stringify(ast.nodes[2])); //=> '{a,b}'
* ```
* @param {String} `input` Brace pattern or AST.
* @param {Object} `options`
* @return {Array} Returns an array of expanded values.
* @api public
*/
braces.stringify = (input, options = {}) => {
if (typeof input === 'string') {
return stringify(braces.parse(input, options), options);
}
return stringify(input, options);
2021-09-26 15:31:45 -04:00
};
/**
2022-05-31 14:18:28 -04:00
* Compiles a brace pattern into a regex-compatible, optimized string.
* This method is called by the main [braces](#braces) function by default.
2021-09-26 15:31:45 -04:00
*
2022-05-31 14:18:28 -04:00
* ```js
* const braces = require('braces');
* console.log(braces.compile('a/{b,c}/d'));
* //=> ['a/(b|c)/d']
* ```
* @param {String} `input` Brace pattern or AST.
* @param {Object} `options`
* @return {Array} Returns an array of expanded values.
* @api public
*/
braces.compile = (input, options = {}) => {
if (typeof input === 'string') {
input = braces.parse(input, options);
}
return compile(input, options);
};
/**
* Expands a brace pattern into an array. This method is called by the
* main [braces](#braces) function when `options.expand` is true. Before
* using this method it's recommended that you read the [performance notes](#performance))
* and advantages of using [.compile](#compile) instead.
2021-09-26 15:31:45 -04:00
*
2022-05-31 14:18:28 -04:00
* ```js
* const braces = require('braces');
* console.log(braces.expand('a/{b,c}/d'));
* //=> ['a/b/d', 'a/c/d'];
* ```
* @param {String} `pattern` Brace pattern
* @param {Object} `options`
* @return {Array} Returns an array of expanded values.
* @api public
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
braces.expand = (input, options = {}) => {
if (typeof input === 'string') {
input = braces.parse(input, options);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let result = expand(input, options);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// filter out empty strings if specified
if (options.noempty === true) {
result = result.filter(Boolean);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// filter out duplicates if specified
if (options.nodupes === true) {
result = [...new Set(result)];
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return result;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Processes a brace pattern and returns either an expanded array
* (if `options.expand` is true), a highly optimized regex-compatible string.
* This method is called by the main [braces](#braces) function.
*
* ```js
* const braces = require('braces');
* console.log(braces.create('user-{200..300}/project-{a,b,c}-{1..10}'))
* //=> 'user-(20[0-9]|2[1-9][0-9]|300)/project-(a|b|c)-([1-9]|10)'
* ```
* @param {String} `pattern` Brace pattern
* @param {Object} `options`
* @return {Array} Returns an array of expanded values.
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
braces.create = (input, options = {}) => {
if (input === '' || input.length < 3) {
return [input];
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return options.expand !== true
? braces.compile(input, options)
: braces.expand(input, options);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Expose "braces"
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = braces;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 9434:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const fill = __nccwpck_require__(6330);
const utils = __nccwpck_require__(5207);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const compile = (ast, options = {}) => {
let walk = (node, parent = {}) => {
let invalidBlock = utils.isInvalidBrace(parent);
let invalidNode = node.invalid === true && options.escapeInvalid === true;
let invalid = invalidBlock === true || invalidNode === true;
let prefix = options.escapeInvalid === true ? '\\' : '';
let output = '';
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.isOpen === true) {
return prefix + node.value;
}
if (node.isClose === true) {
return prefix + node.value;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.type === 'open') {
return invalid ? (prefix + node.value) : '(';
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.type === 'close') {
return invalid ? (prefix + node.value) : ')';
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.type === 'comma') {
return node.prev.type === 'comma' ? '' : (invalid ? node.value : '|');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.value) {
return node.value;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.nodes && node.ranges > 0) {
let args = utils.reduce(node.nodes);
let range = fill(...args, { ...options, wrap: false, toRegex: true });
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (range.length !== 0) {
return args.length > 1 && range.length > 1 ? `(${range})` : range;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.nodes) {
for (let child of node.nodes) {
output += walk(child, node);
}
}
return output;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return walk(ast);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = compile;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 8774:
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = {
MAX_LENGTH: 1024 * 64,
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Digits
CHAR_0: '0', /* 0 */
CHAR_9: '9', /* 9 */
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Alphabet chars.
CHAR_UPPERCASE_A: 'A', /* A */
CHAR_LOWERCASE_A: 'a', /* a */
CHAR_UPPERCASE_Z: 'Z', /* Z */
CHAR_LOWERCASE_Z: 'z', /* z */
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
CHAR_LEFT_PARENTHESES: '(', /* ( */
CHAR_RIGHT_PARENTHESES: ')', /* ) */
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
CHAR_ASTERISK: '*', /* * */
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Non-alphabetic chars.
CHAR_AMPERSAND: '&', /* & */
CHAR_AT: '@', /* @ */
CHAR_BACKSLASH: '\\', /* \ */
CHAR_BACKTICK: '`', /* ` */
CHAR_CARRIAGE_RETURN: '\r', /* \r */
CHAR_CIRCUMFLEX_ACCENT: '^', /* ^ */
CHAR_COLON: ':', /* : */
CHAR_COMMA: ',', /* , */
CHAR_DOLLAR: '$', /* . */
CHAR_DOT: '.', /* . */
CHAR_DOUBLE_QUOTE: '"', /* " */
CHAR_EQUAL: '=', /* = */
CHAR_EXCLAMATION_MARK: '!', /* ! */
CHAR_FORM_FEED: '\f', /* \f */
CHAR_FORWARD_SLASH: '/', /* / */
CHAR_HASH: '#', /* # */
CHAR_HYPHEN_MINUS: '-', /* - */
CHAR_LEFT_ANGLE_BRACKET: '<', /* < */
CHAR_LEFT_CURLY_BRACE: '{', /* { */
CHAR_LEFT_SQUARE_BRACKET: '[', /* [ */
CHAR_LINE_FEED: '\n', /* \n */
CHAR_NO_BREAK_SPACE: '\u00A0', /* \u00A0 */
CHAR_PERCENT: '%', /* % */
CHAR_PLUS: '+', /* + */
CHAR_QUESTION_MARK: '?', /* ? */
CHAR_RIGHT_ANGLE_BRACKET: '>', /* > */
CHAR_RIGHT_CURLY_BRACE: '}', /* } */
CHAR_RIGHT_SQUARE_BRACKET: ']', /* ] */
CHAR_SEMICOLON: ';', /* ; */
CHAR_SINGLE_QUOTE: '\'', /* ' */
CHAR_SPACE: ' ', /* */
CHAR_TAB: '\t', /* \t */
CHAR_UNDERSCORE: '_', /* _ */
CHAR_VERTICAL_LINE: '|', /* | */
CHAR_ZERO_WIDTH_NOBREAK_SPACE: '\uFEFF' /* \uFEFF */
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 5873:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const fill = __nccwpck_require__(6330);
const stringify = __nccwpck_require__(8750);
const utils = __nccwpck_require__(5207);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const append = (queue = '', stash = '', enclose = false) => {
let result = [];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
queue = [].concat(queue);
stash = [].concat(stash);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!stash.length) return queue;
if (!queue.length) {
return enclose ? utils.flatten(stash).map(ele => `{${ele}}`) : stash;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (let item of queue) {
if (Array.isArray(item)) {
for (let value of item) {
result.push(append(value, stash, enclose));
}
} else {
for (let ele of stash) {
if (enclose === true && typeof ele === 'string') ele = `{${ele}}`;
result.push(Array.isArray(ele) ? append(item, ele, enclose) : (item + ele));
}
}
}
return utils.flatten(result);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const expand = (ast, options = {}) => {
let rangeLimit = options.rangeLimit === void 0 ? 1000 : options.rangeLimit;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let walk = (node, parent = {}) => {
node.queue = [];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let p = parent;
let q = parent.queue;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (p.type !== 'brace' && p.type !== 'root' && p.parent) {
p = p.parent;
q = p.queue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.invalid || node.dollar) {
q.push(append(q.pop(), stringify(node, options)));
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.type === 'brace' && node.invalid !== true && node.nodes.length === 2) {
q.push(append(q.pop(), ['{}']));
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.nodes && node.ranges > 0) {
let args = utils.reduce(node.nodes);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (utils.exceedsLimit(...args, options.step, rangeLimit)) {
throw new RangeError('expanded array length exceeds range limit. Use options.rangeLimit to increase or disable the limit.');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let range = fill(...args, options);
if (range.length === 0) {
range = stringify(node, options);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
q.push(append(q.pop(), range));
node.nodes = [];
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let enclose = utils.encloseBrace(node);
let queue = node.queue;
let block = node;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (block.type !== 'brace' && block.type !== 'root' && block.parent) {
block = block.parent;
queue = block.queue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (let i = 0; i < node.nodes.length; i++) {
let child = node.nodes[i];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (child.type === 'comma' && node.type === 'brace') {
if (i === 1) queue.push('');
queue.push('');
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (child.type === 'close') {
q.push(append(q.pop(), queue, enclose));
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (child.value && child.type !== 'open') {
queue.push(append(queue.pop(), child.value));
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (child.nodes) {
walk(child, node);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return queue;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return utils.flatten(walk(ast));
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = expand;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 6477:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const stringify = __nccwpck_require__(8750);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Constants
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const {
MAX_LENGTH,
CHAR_BACKSLASH, /* \ */
CHAR_BACKTICK, /* ` */
CHAR_COMMA, /* , */
CHAR_DOT, /* . */
CHAR_LEFT_PARENTHESES, /* ( */
CHAR_RIGHT_PARENTHESES, /* ) */
CHAR_LEFT_CURLY_BRACE, /* { */
CHAR_RIGHT_CURLY_BRACE, /* } */
CHAR_LEFT_SQUARE_BRACKET, /* [ */
CHAR_RIGHT_SQUARE_BRACKET, /* ] */
CHAR_DOUBLE_QUOTE, /* " */
CHAR_SINGLE_QUOTE, /* ' */
CHAR_NO_BREAK_SPACE,
CHAR_ZERO_WIDTH_NOBREAK_SPACE
} = __nccwpck_require__(8774);
2021-09-26 15:31:45 -04:00
/**
2022-05-31 14:18:28 -04:00
* parse
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
const parse = (input, options = {}) => {
if (typeof input !== 'string') {
throw new TypeError('Expected a string');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let opts = options || {};
let max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH;
if (input.length > max) {
throw new SyntaxError(`Input length (${input.length}), exceeds max characters (${max})`);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let ast = { type: 'root', input, nodes: [] };
let stack = [ast];
let block = ast;
let prev = ast;
let brackets = 0;
let length = input.length;
let index = 0;
let depth = 0;
let value;
let memo = {};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Helpers
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const advance = () => input[index++];
const push = node => {
if (node.type === 'text' && prev.type === 'dot') {
prev.type = 'text';
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (prev && prev.type === 'text' && node.type === 'text') {
prev.value += node.value;
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
block.nodes.push(node);
node.parent = block;
node.prev = prev;
prev = node;
return node;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
push({ type: 'bos' });
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (index < length) {
block = stack[stack.length - 1];
value = advance();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Invalid chars
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === CHAR_ZERO_WIDTH_NOBREAK_SPACE || value === CHAR_NO_BREAK_SPACE) {
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Escaped chars
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === CHAR_BACKSLASH) {
push({ type: 'text', value: (options.keepEscaping ? value : '') + advance() });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Right square bracket (literal): ']'
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === CHAR_RIGHT_SQUARE_BRACKET) {
push({ type: 'text', value: '\\' + value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Left square bracket: '['
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === CHAR_LEFT_SQUARE_BRACKET) {
brackets++;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let closed = true;
let next;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (index < length && (next = advance())) {
value += next;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (next === CHAR_LEFT_SQUARE_BRACKET) {
brackets++;
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (next === CHAR_BACKSLASH) {
value += advance();
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (next === CHAR_RIGHT_SQUARE_BRACKET) {
brackets--;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (brackets === 0) {
break;
}
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
push({ type: 'text', value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Parentheses
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === CHAR_LEFT_PARENTHESES) {
block = push({ type: 'paren', nodes: [] });
stack.push(block);
push({ type: 'text', value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === CHAR_RIGHT_PARENTHESES) {
if (block.type !== 'paren') {
push({ type: 'text', value });
continue;
}
block = stack.pop();
push({ type: 'text', value });
block = stack[stack.length - 1];
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Quotes: '|"|`
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === CHAR_DOUBLE_QUOTE || value === CHAR_SINGLE_QUOTE || value === CHAR_BACKTICK) {
let open = value;
let next;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (options.keepQuotes !== true) {
value = '';
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (index < length && (next = advance())) {
if (next === CHAR_BACKSLASH) {
value += next + advance();
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (next === open) {
if (options.keepQuotes === true) value += next;
break;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
value += next;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
push({ type: 'text', value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Left curly brace: '{'
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === CHAR_LEFT_CURLY_BRACE) {
depth++;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let dollar = prev.value && prev.value.slice(-1) === '$' || block.dollar === true;
let brace = {
type: 'brace',
open: true,
close: false,
dollar,
depth,
commas: 0,
ranges: 0,
nodes: []
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
block = push(brace);
stack.push(block);
push({ type: 'open', value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Right curly brace: '}'
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === CHAR_RIGHT_CURLY_BRACE) {
if (block.type !== 'brace') {
push({ type: 'text', value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let type = 'close';
block = stack.pop();
block.close = true;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
push({ type, value });
depth--;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
block = stack[stack.length - 1];
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Comma: ','
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === CHAR_COMMA && depth > 0) {
if (block.ranges > 0) {
block.ranges = 0;
let open = block.nodes.shift();
block.nodes = [open, { type: 'text', value: stringify(block) }];
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
push({ type: 'comma', value });
block.commas++;
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Dot: '.'
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === CHAR_DOT && depth > 0 && block.commas === 0) {
let siblings = block.nodes;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (depth === 0 || siblings.length === 0) {
push({ type: 'text', value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (prev.type === 'dot') {
block.range = [];
prev.value += value;
prev.type = 'range';
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (block.nodes.length !== 3 && block.nodes.length !== 5) {
block.invalid = true;
block.ranges = 0;
prev.type = 'text';
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
block.ranges++;
block.args = [];
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (prev.type === 'range') {
siblings.pop();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let before = siblings[siblings.length - 1];
before.value += prev.value + value;
prev = before;
block.ranges--;
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
push({ type: 'dot', value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Text
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
push({ type: 'text', value });
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Mark imbalanced braces and brackets as invalid
do {
block = stack.pop();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (block.type !== 'root') {
block.nodes.forEach(node => {
if (!node.nodes) {
if (node.type === 'open') node.isOpen = true;
if (node.type === 'close') node.isClose = true;
if (!node.nodes) node.type = 'text';
node.invalid = true;
}
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// get the location of the block on parent.nodes (block's siblings)
let parent = stack[stack.length - 1];
let index = parent.nodes.indexOf(block);
// replace the (invalid) block with it's nodes
parent.nodes.splice(index, 1, ...block.nodes);
}
} while (stack.length > 0);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
push({ type: 'eos' });
return ast;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = parse;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 8750:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const utils = __nccwpck_require__(5207);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = (ast, options = {}) => {
let stringify = (node, parent = {}) => {
let invalidBlock = options.escapeInvalid && utils.isInvalidBrace(parent);
let invalidNode = node.invalid === true && options.escapeInvalid === true;
let output = '';
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.value) {
if ((invalidBlock || invalidNode) && utils.isOpenOrClose(node)) {
return '\\' + node.value;
}
return node.value;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.value) {
return node.value;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (node.nodes) {
for (let child of node.nodes) {
output += stringify(child);
}
}
return output;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return stringify(ast);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 5207:
/***/ ((__unused_webpack_module, exports) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
exports.isInteger = num => {
if (typeof num === 'number') {
return Number.isInteger(num);
}
if (typeof num === 'string' && num.trim() !== '') {
return Number.isInteger(Number(num));
}
return false;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Find a node of the given type
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
exports.find = (node, type) => node.nodes.find(node => node.type === type);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Find a node of the given type
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
exports.exceedsLimit = (min, max, step = 1, limit) => {
if (limit === false) return false;
if (!exports.isInteger(min) || !exports.isInteger(max)) return false;
return ((Number(max) - Number(min)) / Number(step)) >= limit;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Escape the given node with '\\' before node.value
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
exports.escapeNode = (block, n = 0, type) => {
let node = block.nodes[n];
if (!node) return;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if ((type && node.type === type) || node.type === 'open' || node.type === 'close') {
if (node.escaped !== true) {
node.value = '\\' + node.value;
node.escaped = true;
}
}
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Returns true if the given brace node should be enclosed in literal braces
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
exports.encloseBrace = node => {
if (node.type !== 'brace') return false;
if ((node.commas >> 0 + node.ranges >> 0) === 0) {
node.invalid = true;
return true;
}
return false;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Returns true if a brace node is invalid.
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
exports.isInvalidBrace = block => {
if (block.type !== 'brace') return false;
if (block.invalid === true || block.dollar) return true;
if ((block.commas >> 0 + block.ranges >> 0) === 0) {
block.invalid = true;
return true;
}
if (block.open !== true || block.close !== true) {
block.invalid = true;
return true;
}
return false;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Returns true if a node is an open or close node
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
exports.isOpenOrClose = node => {
if (node.type === 'open' || node.type === 'close') {
return true;
}
return node.open === true || node.close === true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Reduce an array of text nodes.
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
exports.reduce = nodes => nodes.reduce((acc, node) => {
if (node.type === 'text') acc.push(node.value);
if (node.type === 'range') node.type = 'text';
return acc;
}, []);
2021-09-26 15:31:45 -04:00
/**
2022-05-31 14:18:28 -04:00
* Flatten an array
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
exports.flatten = (...args) => {
const result = [];
const flat = arr => {
for (let i = 0; i < arr.length; i++) {
let ele = arr[i];
Array.isArray(ele) ? flat(ele, result) : ele !== void 0 && result.push(ele);
}
return result;
};
flat(args);
return result;
};
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 8932:
/***/ ((__unused_webpack_module, exports) => {
2021-09-26 15:31:45 -04:00
"use strict";
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class Deprecation extends Error {
constructor(message) {
super(message); // Maintains proper stack trace (only available on V8)
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/* istanbul ignore next */
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (Error.captureStackTrace) {
Error.captureStackTrace(this, this.constructor);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
this.name = 'Deprecation';
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.Deprecation = Deprecation;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 3664:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const taskManager = __nccwpck_require__(2708);
const patternManager = __nccwpck_require__(8306);
const async_1 = __nccwpck_require__(5679);
const stream_1 = __nccwpck_require__(4630);
const sync_1 = __nccwpck_require__(2405);
const settings_1 = __nccwpck_require__(952);
const utils = __nccwpck_require__(5444);
async function FastGlob(source, options) {
assertPatternsInput(source);
const works = getWorks(source, async_1.default, options);
const result = await Promise.all(works);
return utils.array.flatten(result);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
// https://github.com/typescript-eslint/typescript-eslint/issues/60
// eslint-disable-next-line no-redeclare
(function (FastGlob) {
function sync(source, options) {
assertPatternsInput(source);
const works = getWorks(source, sync_1.default, options);
return utils.array.flatten(works);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
FastGlob.sync = sync;
function stream(source, options) {
assertPatternsInput(source);
const works = getWorks(source, stream_1.default, options);
/**
* The stream returned by the provider cannot work with an asynchronous iterator.
* To support asynchronous iterators, regardless of the number of tasks, we always multiplex streams.
* This affects performance (+25%). I don't see best solution right now.
*/
return utils.stream.merge(works);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
FastGlob.stream = stream;
function generateTasks(source, options) {
assertPatternsInput(source);
const patterns = patternManager.transform([].concat(source));
const settings = new settings_1.default(options);
return taskManager.generate(patterns, settings);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
FastGlob.generateTasks = generateTasks;
function isDynamicPattern(source, options) {
assertPatternsInput(source);
const settings = new settings_1.default(options);
return utils.pattern.isDynamicPattern(source, settings);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
FastGlob.isDynamicPattern = isDynamicPattern;
function escapePath(source) {
assertPatternsInput(source);
return utils.path.escape(source);
}
FastGlob.escapePath = escapePath;
})(FastGlob || (FastGlob = {}));
function getWorks(source, _Provider, options) {
const patterns = patternManager.transform([].concat(source));
const settings = new settings_1.default(options);
const tasks = taskManager.generate(patterns, settings);
const provider = new _Provider(settings);
return tasks.map(provider.read, provider);
}
function assertPatternsInput(input) {
const source = [].concat(input);
const isValidSource = source.every((item) => utils.string.isString(item) && !utils.string.isEmpty(item));
if (!isValidSource) {
throw new TypeError('Patterns must be a string (non empty) or an array of strings');
}
}
module.exports = FastGlob;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 8306:
/***/ ((__unused_webpack_module, exports) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.removeDuplicateSlashes = exports.transform = void 0;
/**
* Matches a sequence of two or more consecutive slashes, excluding the first two slashes at the beginning of the string.
* The latter is due to the presence of the device path at the beginning of the UNC path.
* @todo rewrite to negative lookbehind with the next major release.
*/
const DOUBLE_SLASH_RE = /(?!^)\/{2,}/g;
function transform(patterns) {
return patterns.map((pattern) => removeDuplicateSlashes(pattern));
}
exports.transform = transform;
/**
* This package only works with forward slashes as a path separator.
* Because of this, we cannot use the standard `path.normalize` method, because on Windows platform it will use of backslashes.
*/
function removeDuplicateSlashes(pattern) {
return pattern.replace(DOUBLE_SLASH_RE, '/');
}
exports.removeDuplicateSlashes = removeDuplicateSlashes;
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 2708:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
"use strict";
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.convertPatternGroupToTask = exports.convertPatternGroupsToTasks = exports.groupPatternsByBaseDirectory = exports.getNegativePatternsAsPositive = exports.getPositivePatterns = exports.convertPatternsToTasks = exports.generate = void 0;
const utils = __nccwpck_require__(5444);
function generate(patterns, settings) {
const positivePatterns = getPositivePatterns(patterns);
const negativePatterns = getNegativePatternsAsPositive(patterns, settings.ignore);
const staticPatterns = positivePatterns.filter((pattern) => utils.pattern.isStaticPattern(pattern, settings));
const dynamicPatterns = positivePatterns.filter((pattern) => utils.pattern.isDynamicPattern(pattern, settings));
const staticTasks = convertPatternsToTasks(staticPatterns, negativePatterns, /* dynamic */ false);
const dynamicTasks = convertPatternsToTasks(dynamicPatterns, negativePatterns, /* dynamic */ true);
return staticTasks.concat(dynamicTasks);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.generate = generate;
/**
* Returns tasks grouped by basic pattern directories.
*
* Patterns that can be found inside (`./`) and outside (`../`) the current directory are handled separately.
* This is necessary because directory traversal starts at the base directory and goes deeper.
*/
function convertPatternsToTasks(positive, negative, dynamic) {
const tasks = [];
const patternsOutsideCurrentDirectory = utils.pattern.getPatternsOutsideCurrentDirectory(positive);
const patternsInsideCurrentDirectory = utils.pattern.getPatternsInsideCurrentDirectory(positive);
const outsideCurrentDirectoryGroup = groupPatternsByBaseDirectory(patternsOutsideCurrentDirectory);
const insideCurrentDirectoryGroup = groupPatternsByBaseDirectory(patternsInsideCurrentDirectory);
tasks.push(...convertPatternGroupsToTasks(outsideCurrentDirectoryGroup, negative, dynamic));
/*
* For the sake of reducing future accesses to the file system, we merge all tasks within the current directory
* into a global task, if at least one pattern refers to the root (`.`). In this case, the global task covers the rest.
*/
if ('.' in insideCurrentDirectoryGroup) {
tasks.push(convertPatternGroupToTask('.', patternsInsideCurrentDirectory, negative, dynamic));
}
else {
tasks.push(...convertPatternGroupsToTasks(insideCurrentDirectoryGroup, negative, dynamic));
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return tasks;
}
exports.convertPatternsToTasks = convertPatternsToTasks;
function getPositivePatterns(patterns) {
return utils.pattern.getPositivePatterns(patterns);
}
exports.getPositivePatterns = getPositivePatterns;
function getNegativePatternsAsPositive(patterns, ignore) {
const negative = utils.pattern.getNegativePatterns(patterns).concat(ignore);
const positive = negative.map(utils.pattern.convertToPositivePattern);
return positive;
}
exports.getNegativePatternsAsPositive = getNegativePatternsAsPositive;
function groupPatternsByBaseDirectory(patterns) {
const group = {};
return patterns.reduce((collection, pattern) => {
const base = utils.pattern.getBaseDirectory(pattern);
if (base in collection) {
collection[base].push(pattern);
}
else {
collection[base] = [pattern];
}
return collection;
}, group);
}
exports.groupPatternsByBaseDirectory = groupPatternsByBaseDirectory;
function convertPatternGroupsToTasks(positive, negative, dynamic) {
return Object.keys(positive).map((base) => {
return convertPatternGroupToTask(base, positive[base], negative, dynamic);
});
}
exports.convertPatternGroupsToTasks = convertPatternGroupsToTasks;
function convertPatternGroupToTask(base, positive, negative, dynamic) {
return {
dynamic,
positive,
negative,
base,
patterns: [].concat(positive, negative.map(utils.pattern.convertToNegativePattern))
};
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.convertPatternGroupToTask = convertPatternGroupToTask;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 5679:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const stream_1 = __nccwpck_require__(2083);
const provider_1 = __nccwpck_require__(257);
class ProviderAsync extends provider_1.default {
constructor() {
super(...arguments);
this._reader = new stream_1.default(this._settings);
}
read(task) {
const root = this._getRootDirectory(task);
const options = this._getReaderOptions(task);
const entries = [];
return new Promise((resolve, reject) => {
const stream = this.api(root, task, options);
stream.once('error', reject);
stream.on('data', (entry) => entries.push(options.transform(entry)));
stream.once('end', () => resolve(entries));
});
}
api(root, task, options) {
if (task.dynamic) {
return this._reader.dynamic(root, options);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return this._reader.static(task.patterns, options);
2021-09-26 15:31:45 -04:00
}
}
2022-05-31 14:18:28 -04:00
exports["default"] = ProviderAsync;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 6983:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const utils = __nccwpck_require__(5444);
const partial_1 = __nccwpck_require__(5295);
class DeepFilter {
constructor(_settings, _micromatchOptions) {
this._settings = _settings;
this._micromatchOptions = _micromatchOptions;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
getFilter(basePath, positive, negative) {
const matcher = this._getMatcher(positive);
const negativeRe = this._getNegativePatternsRe(negative);
return (entry) => this._filter(basePath, entry, matcher, negativeRe);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_getMatcher(patterns) {
return new partial_1.default(patterns, this._settings, this._micromatchOptions);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_getNegativePatternsRe(patterns) {
const affectDepthOfReadingPatterns = patterns.filter(utils.pattern.isAffectDepthOfReadingPattern);
return utils.pattern.convertPatternsToRe(affectDepthOfReadingPatterns, this._micromatchOptions);
}
_filter(basePath, entry, matcher, negativeRe) {
if (this._isSkippedByDeep(basePath, entry.path)) {
return false;
}
if (this._isSkippedSymbolicLink(entry)) {
return false;
}
const filepath = utils.path.removeLeadingDotSegment(entry.path);
if (this._isSkippedByPositivePatterns(filepath, matcher)) {
return false;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return this._isSkippedByNegativePatterns(filepath, negativeRe);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_isSkippedByDeep(basePath, entryPath) {
/**
* Avoid unnecessary depth calculations when it doesn't matter.
*/
if (this._settings.deep === Infinity) {
return false;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return this._getEntryLevel(basePath, entryPath) >= this._settings.deep;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_getEntryLevel(basePath, entryPath) {
const entryPathDepth = entryPath.split('/').length;
if (basePath === '') {
return entryPathDepth;
}
const basePathDepth = basePath.split('/').length;
return entryPathDepth - basePathDepth;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_isSkippedSymbolicLink(entry) {
return !this._settings.followSymbolicLinks && entry.dirent.isSymbolicLink();
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_isSkippedByPositivePatterns(entryPath, matcher) {
return !this._settings.baseNameMatch && !matcher.match(entryPath);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_isSkippedByNegativePatterns(entryPath, patternsRe) {
return !utils.pattern.matchAny(entryPath, patternsRe);
}
}
exports["default"] = DeepFilter;
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 1343:
2021-09-26 15:31:45 -04:00
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const utils = __nccwpck_require__(5444);
class EntryFilter {
constructor(_settings, _micromatchOptions) {
this._settings = _settings;
this._micromatchOptions = _micromatchOptions;
this.index = new Map();
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
getFilter(positive, negative) {
const positiveRe = utils.pattern.convertPatternsToRe(positive, this._micromatchOptions);
const negativeRe = utils.pattern.convertPatternsToRe(negative, this._micromatchOptions);
return (entry) => this._filter(entry, positiveRe, negativeRe);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_filter(entry, positiveRe, negativeRe) {
if (this._settings.unique && this._isDuplicateEntry(entry)) {
return false;
}
if (this._onlyFileFilter(entry) || this._onlyDirectoryFilter(entry)) {
return false;
}
if (this._isSkippedByAbsoluteNegativePatterns(entry.path, negativeRe)) {
return false;
}
const filepath = this._settings.baseNameMatch ? entry.name : entry.path;
const isMatched = this._isMatchToPatterns(filepath, positiveRe) && !this._isMatchToPatterns(entry.path, negativeRe);
if (this._settings.unique && isMatched) {
this._createIndexRecord(entry);
}
return isMatched;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_isDuplicateEntry(entry) {
return this.index.has(entry.path);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_createIndexRecord(entry) {
this.index.set(entry.path, undefined);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_onlyFileFilter(entry) {
return this._settings.onlyFiles && !entry.dirent.isFile();
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_onlyDirectoryFilter(entry) {
return this._settings.onlyDirectories && !entry.dirent.isDirectory();
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_isSkippedByAbsoluteNegativePatterns(entryPath, patternsRe) {
if (!this._settings.absolute) {
return false;
}
const fullpath = utils.path.makeAbsolute(this._settings.cwd, entryPath);
return utils.pattern.matchAny(fullpath, patternsRe);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
/**
* First, just trying to apply patterns to the path.
* Second, trying to apply patterns to the path with final slash.
*/
_isMatchToPatterns(entryPath, patternsRe) {
const filepath = utils.path.removeLeadingDotSegment(entryPath);
return utils.pattern.matchAny(filepath, patternsRe) || utils.pattern.matchAny(filepath + '/', patternsRe);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
exports["default"] = EntryFilter;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 6654:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const utils = __nccwpck_require__(5444);
class ErrorFilter {
constructor(_settings) {
this._settings = _settings;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
getFilter() {
return (error) => this._isNonFatalError(error);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_isNonFatalError(error) {
return utils.errno.isEnoentCodeError(error) || this._settings.suppressErrors;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
exports["default"] = ErrorFilter;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 2576:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const utils = __nccwpck_require__(5444);
class Matcher {
constructor(_patterns, _settings, _micromatchOptions) {
this._patterns = _patterns;
this._settings = _settings;
this._micromatchOptions = _micromatchOptions;
this._storage = [];
this._fillStorage();
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_fillStorage() {
/**
* The original pattern may include `{,*,**,a/*}`, which will lead to problems with matching (unresolved level).
* So, before expand patterns with brace expansion into separated patterns.
*/
const patterns = utils.pattern.expandPatternsWithBraceExpansion(this._patterns);
for (const pattern of patterns) {
const segments = this._getPatternSegments(pattern);
const sections = this._splitSegmentsIntoSections(segments);
this._storage.push({
complete: sections.length <= 1,
pattern,
segments,
sections
});
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_getPatternSegments(pattern) {
const parts = utils.pattern.getPatternParts(pattern, this._micromatchOptions);
return parts.map((part) => {
const dynamic = utils.pattern.isDynamicPattern(part, this._settings);
if (!dynamic) {
return {
dynamic: false,
pattern: part
};
}
return {
dynamic: true,
pattern: part,
patternRe: utils.pattern.makeRe(part, this._micromatchOptions)
};
});
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
_splitSegmentsIntoSections(segments) {
return utils.array.splitWhen(segments, (segment) => segment.dynamic && utils.pattern.hasGlobStar(segment.pattern));
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
exports["default"] = Matcher;
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 5295:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
"use strict";
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const matcher_1 = __nccwpck_require__(2576);
class PartialMatcher extends matcher_1.default {
match(filepath) {
const parts = filepath.split('/');
const levels = parts.length;
const patterns = this._storage.filter((info) => !info.complete || info.segments.length > levels);
for (const pattern of patterns) {
const section = pattern.sections[0];
/**
* In this case, the pattern has a globstar and we must read all directories unconditionally,
* but only if the level has reached the end of the first group.
*
* fixtures/{a,b}/**
* ^ true/false ^ always true
*/
if (!pattern.complete && levels > section.length) {
return true;
}
const match = parts.every((part, index) => {
const segment = pattern.segments[index];
if (segment.dynamic && segment.patternRe.test(part)) {
return true;
}
if (!segment.dynamic && segment.pattern === part) {
return true;
}
return false;
});
if (match) {
return true;
}
}
return false;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports["default"] = PartialMatcher;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 257:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const path = __nccwpck_require__(1017);
const deep_1 = __nccwpck_require__(6983);
const entry_1 = __nccwpck_require__(1343);
const error_1 = __nccwpck_require__(6654);
const entry_2 = __nccwpck_require__(4029);
class Provider {
constructor(_settings) {
this._settings = _settings;
this.errorFilter = new error_1.default(this._settings);
this.entryFilter = new entry_1.default(this._settings, this._getMicromatchOptions());
this.deepFilter = new deep_1.default(this._settings, this._getMicromatchOptions());
this.entryTransformer = new entry_2.default(this._settings);
}
_getRootDirectory(task) {
return path.resolve(this._settings.cwd, task.base);
}
_getReaderOptions(task) {
const basePath = task.base === '.' ? '' : task.base;
return {
basePath,
pathSegmentSeparator: '/',
concurrency: this._settings.concurrency,
deepFilter: this.deepFilter.getFilter(basePath, task.positive, task.negative),
entryFilter: this.entryFilter.getFilter(task.positive, task.negative),
errorFilter: this.errorFilter.getFilter(),
followSymbolicLinks: this._settings.followSymbolicLinks,
fs: this._settings.fs,
stats: this._settings.stats,
throwErrorOnBrokenSymbolicLink: this._settings.throwErrorOnBrokenSymbolicLink,
transform: this.entryTransformer.getTransformer()
};
}
_getMicromatchOptions() {
return {
dot: this._settings.dot,
matchBase: this._settings.baseNameMatch,
nobrace: !this._settings.braceExpansion,
nocase: !this._settings.caseSensitiveMatch,
noext: !this._settings.extglob,
noglobstar: !this._settings.globstar,
posix: true,
strictSlashes: false
};
}
}
exports["default"] = Provider;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 4630:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const stream_1 = __nccwpck_require__(2781);
const stream_2 = __nccwpck_require__(2083);
const provider_1 = __nccwpck_require__(257);
class ProviderStream extends provider_1.default {
constructor() {
super(...arguments);
this._reader = new stream_2.default(this._settings);
}
read(task) {
const root = this._getRootDirectory(task);
const options = this._getReaderOptions(task);
const source = this.api(root, task, options);
const destination = new stream_1.Readable({ objectMode: true, read: () => { } });
source
.once('error', (error) => destination.emit('error', error))
.on('data', (entry) => destination.emit('data', options.transform(entry)))
.once('end', () => destination.emit('end'));
destination
.once('close', () => source.destroy());
return destination;
}
api(root, task, options) {
if (task.dynamic) {
return this._reader.dynamic(root, options);
}
return this._reader.static(task.patterns, options);
}
}
exports["default"] = ProviderStream;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 2405:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const sync_1 = __nccwpck_require__(6234);
const provider_1 = __nccwpck_require__(257);
class ProviderSync extends provider_1.default {
constructor() {
super(...arguments);
this._reader = new sync_1.default(this._settings);
}
read(task) {
const root = this._getRootDirectory(task);
const options = this._getReaderOptions(task);
const entries = this.api(root, task, options);
return entries.map(options.transform);
}
api(root, task, options) {
if (task.dynamic) {
return this._reader.dynamic(root, options);
}
return this._reader.static(task.patterns, options);
}
}
exports["default"] = ProviderSync;
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 4029:
2021-09-26 15:31:45 -04:00
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
"use strict";
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const utils = __nccwpck_require__(5444);
class EntryTransformer {
constructor(_settings) {
this._settings = _settings;
}
getTransformer() {
return (entry) => this._transform(entry);
}
_transform(entry) {
let filepath = entry.path;
if (this._settings.absolute) {
filepath = utils.path.makeAbsolute(this._settings.cwd, filepath);
filepath = utils.path.unixify(filepath);
}
if (this._settings.markDirectories && entry.dirent.isDirectory()) {
filepath += '/';
}
if (!this._settings.objectMode) {
return filepath;
}
return Object.assign(Object.assign({}, entry), { path: filepath });
}
}
exports["default"] = EntryTransformer;
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 5582:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
"use strict";
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const path = __nccwpck_require__(1017);
const fsStat = __nccwpck_require__(109);
const utils = __nccwpck_require__(5444);
class Reader {
constructor(_settings) {
this._settings = _settings;
this._fsStatSettings = new fsStat.Settings({
followSymbolicLink: this._settings.followSymbolicLinks,
fs: this._settings.fs,
throwErrorOnBrokenSymbolicLink: this._settings.followSymbolicLinks
});
}
_getFullEntryPath(filepath) {
return path.resolve(this._settings.cwd, filepath);
}
_makeEntry(stats, pattern) {
const entry = {
name: pattern,
path: pattern,
dirent: utils.fs.createDirentFromStats(pattern, stats)
};
if (this._settings.stats) {
entry.stats = stats;
}
return entry;
}
_isFatalError(error) {
return !utils.errno.isEnoentCodeError(error) && !this._settings.suppressErrors;
}
}
exports["default"] = Reader;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 2083:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const stream_1 = __nccwpck_require__(2781);
const fsStat = __nccwpck_require__(109);
const fsWalk = __nccwpck_require__(6026);
const reader_1 = __nccwpck_require__(5582);
class ReaderStream extends reader_1.default {
constructor() {
super(...arguments);
this._walkStream = fsWalk.walkStream;
this._stat = fsStat.stat;
}
dynamic(root, options) {
return this._walkStream(root, options);
}
static(patterns, options) {
const filepaths = patterns.map(this._getFullEntryPath, this);
const stream = new stream_1.PassThrough({ objectMode: true });
stream._write = (index, _enc, done) => {
return this._getEntry(filepaths[index], patterns[index], options)
.then((entry) => {
if (entry !== null && options.entryFilter(entry)) {
stream.push(entry);
}
if (index === filepaths.length - 1) {
stream.end();
}
done();
})
.catch(done);
};
for (let i = 0; i < filepaths.length; i++) {
stream.write(i);
}
return stream;
}
_getEntry(filepath, pattern, options) {
return this._getStat(filepath)
.then((stats) => this._makeEntry(stats, pattern))
.catch((error) => {
if (options.errorFilter(error)) {
return null;
}
throw error;
});
}
_getStat(filepath) {
return new Promise((resolve, reject) => {
this._stat(filepath, this._fsStatSettings, (error, stats) => {
return error === null ? resolve(stats) : reject(error);
});
});
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports["default"] = ReaderStream;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 6234:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
const fsStat = __nccwpck_require__(109);
const fsWalk = __nccwpck_require__(6026);
const reader_1 = __nccwpck_require__(5582);
class ReaderSync extends reader_1.default {
constructor() {
super(...arguments);
this._walkSync = fsWalk.walkSync;
this._statSync = fsStat.statSync;
}
dynamic(root, options) {
return this._walkSync(root, options);
}
static(patterns, options) {
const entries = [];
for (const pattern of patterns) {
const filepath = this._getFullEntryPath(pattern);
const entry = this._getEntry(filepath, pattern, options);
if (entry === null || !options.entryFilter(entry)) {
continue;
}
entries.push(entry);
}
return entries;
}
_getEntry(filepath, pattern, options) {
try {
const stats = this._getStat(filepath);
return this._makeEntry(stats, pattern);
}
catch (error) {
if (options.errorFilter(error)) {
return null;
}
throw error;
}
}
_getStat(filepath) {
return this._statSync(filepath, this._fsStatSettings);
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports["default"] = ReaderSync;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 952:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.DEFAULT_FILE_SYSTEM_ADAPTER = void 0;
const fs = __nccwpck_require__(7147);
const os = __nccwpck_require__(2037);
/**
* The `os.cpus` method can return zero. We expect the number of cores to be greater than zero.
* https://github.com/nodejs/node/blob/7faeddf23a98c53896f8b574a6e66589e8fb1eb8/lib/os.js#L106-L107
*/
const CPU_COUNT = Math.max(os.cpus().length, 1);
exports.DEFAULT_FILE_SYSTEM_ADAPTER = {
lstat: fs.lstat,
lstatSync: fs.lstatSync,
stat: fs.stat,
statSync: fs.statSync,
readdir: fs.readdir,
readdirSync: fs.readdirSync
};
class Settings {
constructor(_options = {}) {
this._options = _options;
this.absolute = this._getValue(this._options.absolute, false);
this.baseNameMatch = this._getValue(this._options.baseNameMatch, false);
this.braceExpansion = this._getValue(this._options.braceExpansion, true);
this.caseSensitiveMatch = this._getValue(this._options.caseSensitiveMatch, true);
this.concurrency = this._getValue(this._options.concurrency, CPU_COUNT);
this.cwd = this._getValue(this._options.cwd, process.cwd());
this.deep = this._getValue(this._options.deep, Infinity);
this.dot = this._getValue(this._options.dot, false);
this.extglob = this._getValue(this._options.extglob, true);
this.followSymbolicLinks = this._getValue(this._options.followSymbolicLinks, true);
this.fs = this._getFileSystemMethods(this._options.fs);
this.globstar = this._getValue(this._options.globstar, true);
this.ignore = this._getValue(this._options.ignore, []);
this.markDirectories = this._getValue(this._options.markDirectories, false);
this.objectMode = this._getValue(this._options.objectMode, false);
this.onlyDirectories = this._getValue(this._options.onlyDirectories, false);
this.onlyFiles = this._getValue(this._options.onlyFiles, true);
this.stats = this._getValue(this._options.stats, false);
this.suppressErrors = this._getValue(this._options.suppressErrors, false);
this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, false);
this.unique = this._getValue(this._options.unique, true);
if (this.onlyDirectories) {
this.onlyFiles = false;
}
if (this.stats) {
this.objectMode = true;
}
}
_getValue(option, value) {
return option === undefined ? value : option;
}
_getFileSystemMethods(methods = {}) {
return Object.assign(Object.assign({}, exports.DEFAULT_FILE_SYSTEM_ADAPTER), methods);
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports["default"] = Settings;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 5325:
/***/ ((__unused_webpack_module, exports) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.splitWhen = exports.flatten = void 0;
function flatten(items) {
return items.reduce((collection, item) => [].concat(collection, item), []);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.flatten = flatten;
function splitWhen(items, predicate) {
const result = [[]];
let groupIndex = 0;
for (const item of items) {
if (predicate(item)) {
groupIndex++;
result[groupIndex] = [];
}
else {
result[groupIndex].push(item);
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return result;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.splitWhen = splitWhen;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 1230:
/***/ ((__unused_webpack_module, exports) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.isEnoentCodeError = void 0;
function isEnoentCodeError(error) {
return error.code === 'ENOENT';
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.isEnoentCodeError = isEnoentCodeError;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 7543:
/***/ ((__unused_webpack_module, exports) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.createDirentFromStats = void 0;
class DirentFromStats {
constructor(name, stats) {
this.name = name;
this.isBlockDevice = stats.isBlockDevice.bind(stats);
this.isCharacterDevice = stats.isCharacterDevice.bind(stats);
this.isDirectory = stats.isDirectory.bind(stats);
this.isFIFO = stats.isFIFO.bind(stats);
this.isFile = stats.isFile.bind(stats);
this.isSocket = stats.isSocket.bind(stats);
this.isSymbolicLink = stats.isSymbolicLink.bind(stats);
}
}
function createDirentFromStats(name, stats) {
return new DirentFromStats(name, stats);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.createDirentFromStats = createDirentFromStats;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 5444:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.string = exports.stream = exports.pattern = exports.path = exports.fs = exports.errno = exports.array = void 0;
const array = __nccwpck_require__(5325);
exports.array = array;
const errno = __nccwpck_require__(1230);
exports.errno = errno;
const fs = __nccwpck_require__(7543);
exports.fs = fs;
const path = __nccwpck_require__(3873);
exports.path = path;
const pattern = __nccwpck_require__(1221);
exports.pattern = pattern;
const stream = __nccwpck_require__(8382);
exports.stream = stream;
const string = __nccwpck_require__(2203);
exports.string = string;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 3873:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.removeLeadingDotSegment = exports.escape = exports.makeAbsolute = exports.unixify = void 0;
const path = __nccwpck_require__(1017);
const LEADING_DOT_SEGMENT_CHARACTERS_COUNT = 2; // ./ or .\\
const UNESCAPED_GLOB_SYMBOLS_RE = /(\\?)([()*?[\]{|}]|^!|[!+@](?=\())/g;
/**
* Designed to work only with simple paths: `dir\\file`.
*/
function unixify(filepath) {
return filepath.replace(/\\/g, '/');
}
exports.unixify = unixify;
function makeAbsolute(cwd, filepath) {
return path.resolve(cwd, filepath);
}
exports.makeAbsolute = makeAbsolute;
function escape(pattern) {
return pattern.replace(UNESCAPED_GLOB_SYMBOLS_RE, '\\$2');
}
exports.escape = escape;
function removeLeadingDotSegment(entry) {
// We do not use `startsWith` because this is 10x slower than current implementation for some cases.
// eslint-disable-next-line @typescript-eslint/prefer-string-starts-ends-with
if (entry.charAt(0) === '.') {
const secondCharactery = entry.charAt(1);
if (secondCharactery === '/' || secondCharactery === '\\') {
return entry.slice(LEADING_DOT_SEGMENT_CHARACTERS_COUNT);
}
}
return entry;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.removeLeadingDotSegment = removeLeadingDotSegment;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 1221:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.matchAny = exports.convertPatternsToRe = exports.makeRe = exports.getPatternParts = exports.expandBraceExpansion = exports.expandPatternsWithBraceExpansion = exports.isAffectDepthOfReadingPattern = exports.endsWithSlashGlobStar = exports.hasGlobStar = exports.getBaseDirectory = exports.isPatternRelatedToParentDirectory = exports.getPatternsOutsideCurrentDirectory = exports.getPatternsInsideCurrentDirectory = exports.getPositivePatterns = exports.getNegativePatterns = exports.isPositivePattern = exports.isNegativePattern = exports.convertToNegativePattern = exports.convertToPositivePattern = exports.isDynamicPattern = exports.isStaticPattern = void 0;
const path = __nccwpck_require__(1017);
const globParent = __nccwpck_require__(4655);
const micromatch = __nccwpck_require__(6228);
const GLOBSTAR = '**';
const ESCAPE_SYMBOL = '\\';
const COMMON_GLOB_SYMBOLS_RE = /[*?]|^!/;
const REGEX_CHARACTER_CLASS_SYMBOLS_RE = /\[[^[]*]/;
const REGEX_GROUP_SYMBOLS_RE = /(?:^|[^!*+?@])\([^(]*\|[^|]*\)/;
const GLOB_EXTENSION_SYMBOLS_RE = /[!*+?@]\([^(]*\)/;
const BRACE_EXPANSION_SEPARATORS_RE = /,|\.\./;
function isStaticPattern(pattern, options = {}) {
return !isDynamicPattern(pattern, options);
}
exports.isStaticPattern = isStaticPattern;
function isDynamicPattern(pattern, options = {}) {
/**
* A special case with an empty string is necessary for matching patterns that start with a forward slash.
* An empty string cannot be a dynamic pattern.
* For example, the pattern `/lib/*` will be spread into parts: '', 'lib', '*'.
*/
if (pattern === '') {
return false;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
/**
* When the `caseSensitiveMatch` option is disabled, all patterns must be marked as dynamic, because we cannot check
* filepath directly (without read directory).
*/
if (options.caseSensitiveMatch === false || pattern.includes(ESCAPE_SYMBOL)) {
return true;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (COMMON_GLOB_SYMBOLS_RE.test(pattern) || REGEX_CHARACTER_CLASS_SYMBOLS_RE.test(pattern) || REGEX_GROUP_SYMBOLS_RE.test(pattern)) {
return true;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (options.extglob !== false && GLOB_EXTENSION_SYMBOLS_RE.test(pattern)) {
return true;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (options.braceExpansion !== false && hasBraceExpansion(pattern)) {
return true;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return false;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.isDynamicPattern = isDynamicPattern;
function hasBraceExpansion(pattern) {
const openingBraceIndex = pattern.indexOf('{');
if (openingBraceIndex === -1) {
return false;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
const closingBraceIndex = pattern.indexOf('}', openingBraceIndex + 1);
if (closingBraceIndex === -1) {
return false;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
const braceContent = pattern.slice(openingBraceIndex, closingBraceIndex);
return BRACE_EXPANSION_SEPARATORS_RE.test(braceContent);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function convertToPositivePattern(pattern) {
return isNegativePattern(pattern) ? pattern.slice(1) : pattern;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.convertToPositivePattern = convertToPositivePattern;
function convertToNegativePattern(pattern) {
return '!' + pattern;
}
exports.convertToNegativePattern = convertToNegativePattern;
function isNegativePattern(pattern) {
return pattern.startsWith('!') && pattern[1] !== '(';
}
exports.isNegativePattern = isNegativePattern;
function isPositivePattern(pattern) {
return !isNegativePattern(pattern);
}
exports.isPositivePattern = isPositivePattern;
function getNegativePatterns(patterns) {
return patterns.filter(isNegativePattern);
}
exports.getNegativePatterns = getNegativePatterns;
function getPositivePatterns(patterns) {
return patterns.filter(isPositivePattern);
}
exports.getPositivePatterns = getPositivePatterns;
/**
* Returns patterns that can be applied inside the current directory.
*
* @example
* // ['./*', '*', 'a/*']
* getPatternsInsideCurrentDirectory(['./*', '*', 'a/*', '../*', './../*'])
*/
function getPatternsInsideCurrentDirectory(patterns) {
return patterns.filter((pattern) => !isPatternRelatedToParentDirectory(pattern));
}
exports.getPatternsInsideCurrentDirectory = getPatternsInsideCurrentDirectory;
/**
* Returns patterns to be expanded relative to (outside) the current directory.
*
* @example
* // ['../*', './../*']
* getPatternsInsideCurrentDirectory(['./*', '*', 'a/*', '../*', './../*'])
*/
function getPatternsOutsideCurrentDirectory(patterns) {
return patterns.filter(isPatternRelatedToParentDirectory);
}
exports.getPatternsOutsideCurrentDirectory = getPatternsOutsideCurrentDirectory;
function isPatternRelatedToParentDirectory(pattern) {
return pattern.startsWith('..') || pattern.startsWith('./..');
}
exports.isPatternRelatedToParentDirectory = isPatternRelatedToParentDirectory;
function getBaseDirectory(pattern) {
return globParent(pattern, { flipBackslashes: false });
}
exports.getBaseDirectory = getBaseDirectory;
function hasGlobStar(pattern) {
return pattern.includes(GLOBSTAR);
}
exports.hasGlobStar = hasGlobStar;
function endsWithSlashGlobStar(pattern) {
return pattern.endsWith('/' + GLOBSTAR);
}
exports.endsWithSlashGlobStar = endsWithSlashGlobStar;
function isAffectDepthOfReadingPattern(pattern) {
const basename = path.basename(pattern);
return endsWithSlashGlobStar(pattern) || isStaticPattern(basename);
}
exports.isAffectDepthOfReadingPattern = isAffectDepthOfReadingPattern;
function expandPatternsWithBraceExpansion(patterns) {
return patterns.reduce((collection, pattern) => {
return collection.concat(expandBraceExpansion(pattern));
}, []);
}
exports.expandPatternsWithBraceExpansion = expandPatternsWithBraceExpansion;
function expandBraceExpansion(pattern) {
return micromatch.braces(pattern, {
expand: true,
nodupes: true
});
}
exports.expandBraceExpansion = expandBraceExpansion;
function getPatternParts(pattern, options) {
let { parts } = micromatch.scan(pattern, Object.assign(Object.assign({}, options), { parts: true }));
/**
* The scan method returns an empty array in some cases.
* See micromatch/picomatch#58 for more details.
*/
if (parts.length === 0) {
parts = [pattern];
}
/**
* The scan method does not return an empty part for the pattern with a forward slash.
* This is another part of micromatch/picomatch#58.
*/
if (parts[0].startsWith('/')) {
parts[0] = parts[0].slice(1);
parts.unshift('');
}
return parts;
}
exports.getPatternParts = getPatternParts;
function makeRe(pattern, options) {
return micromatch.makeRe(pattern, options);
}
exports.makeRe = makeRe;
function convertPatternsToRe(patterns, options) {
return patterns.map((pattern) => makeRe(pattern, options));
}
exports.convertPatternsToRe = convertPatternsToRe;
function matchAny(entry, patternsRe) {
return patternsRe.some((patternRe) => patternRe.test(entry));
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.matchAny = matchAny;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 8382:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.merge = void 0;
const merge2 = __nccwpck_require__(2578);
function merge(streams) {
const mergedStream = merge2(streams);
streams.forEach((stream) => {
stream.once('error', (error) => mergedStream.emit('error', error));
});
mergedStream.once('close', () => propagateCloseEventToSources(streams));
mergedStream.once('end', () => propagateCloseEventToSources(streams));
return mergedStream;
}
exports.merge = merge;
function propagateCloseEventToSources(streams) {
streams.forEach((stream) => stream.emit('close'));
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 2203:
/***/ ((__unused_webpack_module, exports) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.isEmpty = exports.isString = void 0;
function isString(input) {
return typeof input === 'string';
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.isString = isString;
function isEmpty(input) {
return input === '';
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.isEmpty = isEmpty;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 7340:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/* eslint-disable no-var */
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var reusify = __nccwpck_require__(2113)
function fastqueue (context, worker, concurrency) {
if (typeof context === 'function') {
concurrency = worker
worker = context
context = null
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (concurrency < 1) {
throw new Error('fastqueue concurrency must be greater than 1')
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
var cache = reusify(Task)
var queueHead = null
var queueTail = null
var _running = 0
var errorHandler = null
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var self = {
push: push,
drain: noop,
saturated: noop,
pause: pause,
paused: false,
concurrency: concurrency,
running: running,
resume: resume,
idle: idle,
length: length,
getQueue: getQueue,
unshift: unshift,
empty: noop,
kill: kill,
killAndDrain: killAndDrain,
error: error
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return self
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function running () {
return _running
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function pause () {
self.paused = true
}
function length () {
var current = queueHead
var counter = 0
while (current) {
current = current.next
counter++
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return counter
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function getQueue () {
var current = queueHead
var tasks = []
while (current) {
tasks.push(current.value)
current = current.next
}
return tasks
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function resume () {
if (!self.paused) return
self.paused = false
for (var i = 0; i < self.concurrency; i++) {
_running++
release()
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function idle () {
return _running === 0 && self.length() === 0
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function push (value, done) {
var current = cache.get()
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
current.context = context
current.release = release
current.value = value
current.callback = done || noop
current.errorHandler = errorHandler
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (_running === self.concurrency || self.paused) {
if (queueTail) {
queueTail.next = current
queueTail = current
} else {
queueHead = current
queueTail = current
self.saturated()
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
} else {
_running++
worker.call(context, current.value, current.worked)
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
function unshift (value, done) {
var current = cache.get()
current.context = context
current.release = release
current.value = value
current.callback = done || noop
if (_running === self.concurrency || self.paused) {
if (queueHead) {
current.next = queueHead
queueHead = current
} else {
queueHead = current
queueTail = current
self.saturated()
2021-09-26 15:31:45 -04:00
}
} else {
2022-05-31 14:18:28 -04:00
_running++
worker.call(context, current.value, current.worked)
2021-09-26 15:31:45 -04:00
}
}
2022-05-31 14:18:28 -04:00
function release (holder) {
if (holder) {
cache.release(holder)
}
var next = queueHead
if (next) {
if (!self.paused) {
if (queueTail === queueHead) {
queueTail = null
}
queueHead = next.next
next.next = null
worker.call(context, next.value, next.worked)
if (queueTail === null) {
self.empty()
}
} else {
_running--
}
} else if (--_running === 0) {
self.drain()
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function kill () {
queueHead = null
queueTail = null
self.drain = noop
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function killAndDrain () {
queueHead = null
queueTail = null
self.drain()
self.drain = noop
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function error (handler) {
errorHandler = handler
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function noop () {}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function Task () {
this.value = null
this.callback = noop
this.next = null
this.release = noop
this.context = null
this.errorHandler = null
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var self = this
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.worked = function worked (err, result) {
var callback = self.callback
var errorHandler = self.errorHandler
var val = self.value
self.value = null
self.callback = noop
if (self.errorHandler) {
errorHandler(err, val)
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
callback.call(self.context, err, result)
self.release(self)
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function queueAsPromised (context, worker, concurrency) {
if (typeof context === 'function') {
concurrency = worker
worker = context
context = null
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function asyncWrapper (arg, cb) {
worker.call(this, arg)
.then(function (res) {
cb(null, res)
}, cb)
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
var queue = fastqueue(context, asyncWrapper, concurrency)
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var pushCb = queue.push
var unshiftCb = queue.unshift
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
queue.push = push
queue.unshift = unshift
queue.drained = drained
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return queue
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function push (value) {
var p = new Promise(function (resolve, reject) {
pushCb(value, function (err, result) {
if (err) {
reject(err)
return
}
resolve(result)
})
})
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Let's fork the promise chain to
// make the error bubble up to the user but
// not lead to a unhandledRejection
p.catch(noop)
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return p
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function unshift (value) {
var p = new Promise(function (resolve, reject) {
unshiftCb(value, function (err, result) {
if (err) {
reject(err)
return
}
resolve(result)
})
})
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Let's fork the promise chain to
// make the error bubble up to the user but
// not lead to a unhandledRejection
p.catch(noop)
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return p
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function drained () {
var previousDrain = queue.drain
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var p = new Promise(function (resolve) {
queue.drain = function () {
previousDrain()
resolve()
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
})
return p
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = fastqueue
module.exports.promise = queueAsPromised
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 6330:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
/*!
* fill-range <https://github.com/jonschlinkert/fill-range>
*
* Copyright (c) 2014-present, Jon Schlinkert.
* Licensed under the MIT License.
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const util = __nccwpck_require__(3837);
const toRegexRange = __nccwpck_require__(1861);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const isObject = val => val !== null && typeof val === 'object' && !Array.isArray(val);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const transform = toNumber => {
return value => toNumber === true ? Number(value) : String(value);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const isValidValue = value => {
return typeof value === 'number' || (typeof value === 'string' && value !== '');
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
const isNumber = num => Number.isInteger(+num);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const zeros = input => {
let value = `${input}`;
let index = -1;
if (value[0] === '-') value = value.slice(1);
if (value === '0') return false;
while (value[++index] === '0');
return index > 0;
};
const stringify = (start, end, options) => {
if (typeof start === 'string' || typeof end === 'string') {
return true;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return options.stringify === true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const pad = (input, maxLength, toNumber) => {
if (maxLength > 0) {
let dash = input[0] === '-' ? '-' : '';
if (dash) input = input.slice(1);
input = (dash + input.padStart(dash ? maxLength - 1 : maxLength, '0'));
}
if (toNumber === false) {
return String(input);
}
return input;
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
const toMaxLen = (input, maxLength) => {
let negative = input[0] === '-' ? '-' : '';
if (negative) {
input = input.slice(1);
maxLength--;
}
while (input.length < maxLength) input = '0' + input;
return negative ? ('-' + input) : input;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const toSequence = (parts, options) => {
parts.negatives.sort((a, b) => a < b ? -1 : a > b ? 1 : 0);
parts.positives.sort((a, b) => a < b ? -1 : a > b ? 1 : 0);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let prefix = options.capture ? '' : '?:';
let positives = '';
let negatives = '';
let result;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (parts.positives.length) {
positives = parts.positives.join('|');
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (parts.negatives.length) {
negatives = `-(${prefix}${parts.negatives.join('|')})`;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (positives && negatives) {
result = `${positives}|${negatives}`;
2021-09-26 15:31:45 -04:00
} else {
2022-05-31 14:18:28 -04:00
result = positives || negatives;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (options.wrap) {
return `(${prefix}${result})`;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return result;
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
const toRange = (a, b, isNumbers, options) => {
if (isNumbers) {
return toRegexRange(a, b, { wrap: false, ...options });
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let start = String.fromCharCode(a);
if (a === b) return start;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let stop = String.fromCharCode(b);
return `[${start}-${stop}]`;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const toRegex = (start, end, options) => {
if (Array.isArray(start)) {
let wrap = options.wrap === true;
let prefix = options.capture ? '' : '?:';
return wrap ? `(${prefix}${start.join('|')})` : start.join('|');
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return toRegexRange(start, end, options);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const rangeError = (...args) => {
return new RangeError('Invalid range arguments: ' + util.inspect(...args));
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
const invalidRange = (start, end, options) => {
if (options.strictRanges === true) throw rangeError([start, end]);
return [];
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const invalidStep = (step, options) => {
if (options.strictRanges === true) {
throw new TypeError(`Expected step "${step}" to be a number`);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return [];
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
const fillNumbers = (start, end, step = 1, options = {}) => {
let a = Number(start);
let b = Number(end);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!Number.isInteger(a) || !Number.isInteger(b)) {
if (options.strictRanges === true) throw rangeError([start, end]);
return [];
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// fix negative zero
if (a === 0) a = 0;
if (b === 0) b = 0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let descending = a > b;
let startString = String(start);
let endString = String(end);
let stepString = String(step);
step = Math.max(Math.abs(step), 1);
let padded = zeros(startString) || zeros(endString) || zeros(stepString);
let maxLen = padded ? Math.max(startString.length, endString.length, stepString.length) : 0;
let toNumber = padded === false && stringify(start, end, options) === false;
let format = options.transform || transform(toNumber);
if (options.toRegex && step === 1) {
return toRange(toMaxLen(start, maxLen), toMaxLen(end, maxLen), true, options);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
let parts = { negatives: [], positives: [] };
let push = num => parts[num < 0 ? 'negatives' : 'positives'].push(Math.abs(num));
let range = [];
let index = 0;
while (descending ? a >= b : a <= b) {
if (options.toRegex === true && step > 1) {
push(a);
} else {
range.push(pad(format(a, index), maxLen, toNumber));
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
a = descending ? a - step : a + step;
index++;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (options.toRegex === true) {
return step > 1
? toSequence(parts, options)
: toRegex(range, null, { wrap: false, ...options });
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return range;
};
const fillLetters = (start, end, step = 1, options = {}) => {
if ((!isNumber(start) && start.length > 1) || (!isNumber(end) && end.length > 1)) {
return invalidRange(start, end, options);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
let format = options.transform || (val => String.fromCharCode(val));
let a = `${start}`.charCodeAt(0);
let b = `${end}`.charCodeAt(0);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let descending = a > b;
let min = Math.min(a, b);
let max = Math.max(a, b);
if (options.toRegex && step === 1) {
return toRange(min, max, false, options);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
let range = [];
let index = 0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (descending ? a >= b : a <= b) {
range.push(format(a, index));
a = descending ? a - step : a + step;
index++;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (options.toRegex === true) {
return toRegex(range, null, { wrap: false, options });
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return range;
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
const fill = (start, end, step, options = {}) => {
if (end == null && isValidValue(start)) {
return [start];
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (!isValidValue(start) || !isValidValue(end)) {
return invalidRange(start, end, options);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (typeof step === 'function') {
return fill(start, end, 1, { transform: step });
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (isObject(step)) {
return fill(start, end, 0, step);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
let opts = { ...options };
if (opts.capture === true) opts.wrap = true;
step = step || opts.step || 1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!isNumber(step)) {
if (step != null && !isObject(step)) return invalidStep(step, opts);
return fill(start, end, 1, step);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (isNumber(start) && isNumber(end)) {
return fillNumbers(start, end, step, opts);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return fillLetters(start, end, Math.max(Math.abs(step), 1), opts);
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
module.exports = fill;
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 4655:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
"use strict";
2022-05-31 14:18:28 -04:00
var isGlob = __nccwpck_require__(4466);
var pathPosixDirname = (__nccwpck_require__(1017).posix.dirname);
var isWin32 = (__nccwpck_require__(2037).platform)() === 'win32';
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var slash = '/';
var backslash = /\\/g;
var enclosure = /[\{\[].*[\}\]]$/;
var globby = /(^|[^\\])([\{\[]|\([^\)]+$)/;
var escaped = /\\([\!\*\?\|\[\]\(\)\{\}])/g;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* @param {string} str
* @param {Object} opts
* @param {boolean} [opts.flipBackslashes=true]
* @returns {string}
*/
module.exports = function globParent(str, opts) {
var options = Object.assign({ flipBackslashes: true }, opts);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// flip windows path separators
if (options.flipBackslashes && isWin32 && str.indexOf(slash) < 0) {
str = str.replace(backslash, slash);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
// special case for strings ending in enclosure containing path separator
if (enclosure.test(str)) {
str += slash;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
// preserves full path in case of trailing path separator
str += 'a';
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// remove path parts that are globby
do {
str = pathPosixDirname(str);
} while (isGlob(str) || globby.test(str));
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// remove escape chars and return result
return str.replace(escaped, '$1');
};
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 6435:
2021-09-26 15:31:45 -04:00
/***/ ((module) => {
2022-05-31 14:18:28 -04:00
/*!
* is-extglob <https://github.com/jonschlinkert/is-extglob>
*
* Copyright (c) 2014-2016, Jon Schlinkert.
* Licensed under the MIT License.
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = function isExtglob(str) {
if (typeof str !== 'string' || str === '') {
return false;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
var match;
while ((match = /(\\).|([@?!+*]\(.*\))/g.exec(str))) {
if (match[2]) return true;
str = str.slice(match.index + match[0].length);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return false;
};
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 4466:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/*!
* is-glob <https://github.com/jonschlinkert/is-glob>
*
* Copyright (c) 2014-2017, Jon Schlinkert.
* Released under the MIT License.
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var isExtglob = __nccwpck_require__(6435);
var chars = { '{': '}', '(': ')', '[': ']'};
var strictRegex = /\\(.)|(^!|\*|[\].+)]\?|\[[^\\\]]+\]|\{[^\\}]+\}|\(\?[:!=][^\\)]+\)|\([^|]+\|[^\\)]+\))/;
var relaxedRegex = /\\(.)|(^!|[*?{}()[\]]|\(\?)/;
module.exports = function isGlob(str, options) {
if (typeof str !== 'string' || str === '') {
return false;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (isExtglob(str)) {
return true;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
var regex = strictRegex;
var match;
// optionally relax regex
if (options && options.strict === false) {
regex = relaxedRegex;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
while ((match = regex.exec(str))) {
if (match[2]) return true;
var idx = match.index + match[0].length;
// if an open bracket/brace/paren is escaped,
// set the index to the next closing character
var open = match[1];
var close = open ? chars[open] : null;
if (open && close) {
var n = str.indexOf(close, idx);
if (n !== -1) {
idx = n + 1;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
str = str.slice(idx);
}
return false;
};
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 5680:
2021-09-26 15:31:45 -04:00
/***/ ((module) => {
2022-05-31 14:18:28 -04:00
"use strict";
/*!
* is-number <https://github.com/jonschlinkert/is-number>
*
* Copyright (c) 2014-present, Jon Schlinkert.
* Released under the MIT License.
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = function(num) {
if (typeof num === 'number') {
return num - num === 0;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (typeof num === 'string' && num.trim() !== '') {
return Number.isFinite ? Number.isFinite(+num) : isFinite(+num);
}
return false;
};
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 3287:
/***/ ((__unused_webpack_module, exports) => {
2021-09-26 15:31:45 -04:00
"use strict";
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/*!
* is-plain-object <https://github.com/jonschlinkert/is-plain-object>
2021-09-26 15:31:45 -04:00
*
2022-05-31 14:18:28 -04:00
* Copyright (c) 2014-2017, Jon Schlinkert.
* Released under the MIT License.
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
function isObject(o) {
return Object.prototype.toString.call(o) === '[object Object]';
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isPlainObject(o) {
var ctor,prot;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (isObject(o) === false) return false;
// If has modified constructor
ctor = o.constructor;
if (ctor === undefined) return true;
// If has modified prototype
prot = ctor.prototype;
if (isObject(prot) === false) return false;
// If constructor does not have an Object-specific method
if (prot.hasOwnProperty('isPrototypeOf') === false) {
return false;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
// Most likely a plain Object
return true;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
exports.isPlainObject = isPlainObject;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 2578:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/*
* merge2
* https://github.com/teambition/merge2
2021-09-26 15:31:45 -04:00
*
2022-05-31 14:18:28 -04:00
* Copyright (c) 2014-2020 Teambition
* Licensed under the MIT license.
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
const Stream = __nccwpck_require__(2781)
const PassThrough = Stream.PassThrough
const slice = Array.prototype.slice
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = merge2
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function merge2 () {
const streamsQueue = []
const args = slice.call(arguments)
let merging = false
let options = args[args.length - 1]
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (options && !Array.isArray(options) && options.pipe == null) {
args.pop()
} else {
options = {}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
const doEnd = options.end !== false
const doPipeError = options.pipeError === true
if (options.objectMode == null) {
options.objectMode = true
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (options.highWaterMark == null) {
options.highWaterMark = 64 * 1024
}
const mergedStream = PassThrough(options)
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function addStream () {
for (let i = 0, len = arguments.length; i < len; i++) {
streamsQueue.push(pauseStreams(arguments[i], options))
}
mergeStream()
return this
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function mergeStream () {
if (merging) {
return
}
merging = true
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let streams = streamsQueue.shift()
if (!streams) {
process.nextTick(endStream)
return
}
if (!Array.isArray(streams)) {
streams = [streams]
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let pipesCount = streams.length + 1
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function next () {
if (--pipesCount > 0) {
return
}
merging = false
mergeStream()
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function pipe (stream) {
function onend () {
stream.removeListener('merge2UnpipeEnd', onend)
stream.removeListener('end', onend)
if (doPipeError) {
stream.removeListener('error', onerror)
}
next()
}
function onerror (err) {
mergedStream.emit('error', err)
}
// skip ended stream
if (stream._readableState.endEmitted) {
return next()
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
stream.on('merge2UnpipeEnd', onend)
stream.on('end', onend)
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (doPipeError) {
stream.on('error', onerror)
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
stream.pipe(mergedStream, { end: false })
// compatible for old stream
stream.resume()
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (let i = 0; i < streams.length; i++) {
pipe(streams[i])
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
next()
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function endStream () {
merging = false
// emit 'queueDrain' when all streams merged.
mergedStream.emit('queueDrain')
if (doEnd) {
mergedStream.end()
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
mergedStream.setMaxListeners(0)
mergedStream.add = addStream
mergedStream.on('unpipe', function (stream) {
stream.emit('merge2UnpipeEnd')
})
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (args.length) {
addStream.apply(null, args)
}
return mergedStream
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// check and pause streams for pipe.
function pauseStreams (streams, options) {
if (!Array.isArray(streams)) {
// Backwards-compat with old-style streams
if (!streams._readableState && streams.pipe) {
streams = streams.pipe(PassThrough(options))
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (!streams._readableState || !streams.pause || !streams.pipe) {
throw new Error('Only readable stream can be merged.')
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
streams.pause()
} else {
for (let i = 0, len = streams.length; i < len; i++) {
streams[i] = pauseStreams(streams[i], options)
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
return streams
}
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 6228:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
"use strict";
2022-05-31 14:18:28 -04:00
const util = __nccwpck_require__(3837);
const braces = __nccwpck_require__(610);
const picomatch = __nccwpck_require__(8569);
const utils = __nccwpck_require__(479);
const isEmptyString = val => val === '' || val === './';
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Returns an array of strings that match one or more glob patterns.
*
* ```js
* const mm = require('micromatch');
* // mm(list, patterns[, options]);
*
* console.log(mm(['a.js', 'a.txt'], ['*.js']));
* //=> [ 'a.js' ]
* ```
* @param {String|Array<string>} `list` List of strings to match.
* @param {String|Array<string>} `patterns` One or more glob patterns to use for matching.
* @param {Object} `options` See available [options](#options)
* @return {Array} Returns an array of matches
* @summary false
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const micromatch = (list, patterns, options) => {
patterns = [].concat(patterns);
list = [].concat(list);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let omit = new Set();
let keep = new Set();
let items = new Set();
let negatives = 0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let onResult = state => {
items.add(state.output);
if (options && options.onResult) {
options.onResult(state);
}
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (let i = 0; i < patterns.length; i++) {
let isMatch = picomatch(String(patterns[i]), { ...options, onResult }, true);
let negated = isMatch.state.negated || isMatch.state.negatedExtglob;
if (negated) negatives++;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (let item of list) {
let matched = isMatch(item, true);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let match = negated ? !matched.isMatch : matched.isMatch;
if (!match) continue;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (negated) {
omit.add(matched.output);
} else {
omit.delete(matched.output);
keep.add(matched.output);
2021-09-26 15:31:45 -04:00
}
}
}
2022-05-31 14:18:28 -04:00
let result = negatives === patterns.length ? [...items] : [...keep];
let matches = result.filter(item => !omit.has(item));
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (options && matches.length === 0) {
if (options.failglob === true) {
throw new Error(`No matches found for "${patterns.join(', ')}"`);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (options.nonull === true || options.nullglob === true) {
return options.unescape ? patterns.map(p => p.replace(/\\/g, '')) : patterns;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return matches;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Backwards compatibility
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.match = micromatch;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Returns a matcher function from the given glob `pattern` and `options`.
* The returned function takes a string to match as its only argument and returns
* true if the string is a match.
*
* ```js
* const mm = require('micromatch');
* // mm.matcher(pattern[, options]);
*
* const isMatch = mm.matcher('*.!(*a)');
* console.log(isMatch('a.a')); //=> false
* console.log(isMatch('a.b')); //=> true
* ```
* @param {String} `pattern` Glob pattern
* @param {Object} `options`
* @return {Function} Returns a matcher function.
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.matcher = (pattern, options) => picomatch(pattern, options);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Returns true if **any** of the given glob `patterns` match the specified `string`.
*
* ```js
* const mm = require('micromatch');
* // mm.isMatch(string, patterns[, options]);
*
* console.log(mm.isMatch('a.a', ['b.*', '*.a'])); //=> true
* console.log(mm.isMatch('a.a', 'b.*')); //=> false
* ```
* @param {String} `str` The string to test.
* @param {String|Array} `patterns` One or more glob patterns to use for matching.
* @param {Object} `[options]` See available [options](#options).
* @return {Boolean} Returns true if any patterns match `str`
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.isMatch = (str, patterns, options) => picomatch(patterns, options)(str);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Backwards compatibility
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.any = micromatch.isMatch;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Returns a list of strings that _**do not match any**_ of the given `patterns`.
*
* ```js
* const mm = require('micromatch');
* // mm.not(list, patterns[, options]);
*
* console.log(mm.not(['a.a', 'b.b', 'c.c'], '*.a'));
* //=> ['b.b', 'c.c']
* ```
* @param {Array} `list` Array of strings to match.
* @param {String|Array} `patterns` One or more glob pattern to use for matching.
* @param {Object} `options` See available [options](#options) for changing how matches are performed
* @return {Array} Returns an array of strings that **do not match** the given patterns.
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.not = (list, patterns, options = {}) => {
patterns = [].concat(patterns).map(String);
let result = new Set();
let items = [];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let onResult = state => {
if (options.onResult) options.onResult(state);
items.push(state.output);
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
let matches = new Set(micromatch(list, patterns, { ...options, onResult }));
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (let item of items) {
if (!matches.has(item)) {
result.add(item);
}
}
return [...result];
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Returns true if the given `string` contains the given pattern. Similar
* to [.isMatch](#isMatch) but the pattern can match any part of the string.
*
* ```js
* var mm = require('micromatch');
* // mm.contains(string, pattern[, options]);
*
* console.log(mm.contains('aa/bb/cc', '*b'));
* //=> true
* console.log(mm.contains('aa/bb/cc', '*d'));
* //=> false
* ```
* @param {String} `str` The string to match.
* @param {String|Array} `patterns` Glob pattern to use for matching.
* @param {Object} `options` See available [options](#options) for changing how matches are performed
* @return {Boolean} Returns true if any of the patterns matches any part of `str`.
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.contains = (str, pattern, options) => {
if (typeof str !== 'string') {
throw new TypeError(`Expected a string: "${util.inspect(str)}"`);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (Array.isArray(pattern)) {
return pattern.some(p => micromatch.contains(str, p, options));
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (typeof pattern === 'string') {
if (isEmptyString(str) || isEmptyString(pattern)) {
return false;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (str.includes(pattern) || (str.startsWith('./') && str.slice(2).includes(pattern))) {
return true;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return micromatch.isMatch(str, pattern, { ...options, contains: true });
};
2021-09-26 15:31:45 -04:00
/**
2022-05-31 14:18:28 -04:00
* Filter the keys of the given object with the given `glob` pattern
* and `options`. Does not attempt to match nested keys. If you need this feature,
* use [glob-object][] instead.
*
* ```js
* const mm = require('micromatch');
* // mm.matchKeys(object, patterns[, options]);
*
* const obj = { aa: 'a', ab: 'b', ac: 'c' };
* console.log(mm.matchKeys(obj, '*b'));
* //=> { ab: 'b' }
* ```
* @param {Object} `object` The object with keys to filter.
* @param {String|Array} `patterns` One or more glob patterns to use for matching.
* @param {Object} `options` See available [options](#options) for changing how matches are performed
* @return {Object} Returns an object with only keys that match the given patterns.
* @api public
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
micromatch.matchKeys = (obj, patterns, options) => {
if (!utils.isObject(obj)) {
throw new TypeError('Expected the first argument to be an object');
}
let keys = micromatch(Object.keys(obj), patterns, options);
let res = {};
for (let key of keys) res[key] = obj[key];
return res;
};
2021-09-26 15:31:45 -04:00
/**
2022-05-31 14:18:28 -04:00
* Returns true if some of the strings in the given `list` match any of the given glob `patterns`.
*
* ```js
* const mm = require('micromatch');
* // mm.some(list, patterns[, options]);
*
* console.log(mm.some(['foo.js', 'bar.js'], ['*.js', '!foo.js']));
* // true
* console.log(mm.some(['foo.js'], ['*.js', '!foo.js']));
* // false
* ```
* @param {String|Array} `list` The string or array of strings to test. Returns as soon as the first match is found.
* @param {String|Array} `patterns` One or more glob patterns to use for matching.
* @param {Object} `options` See available [options](#options) for changing how matches are performed
* @return {Boolean} Returns true if any `patterns` matches any of the strings in `list`
* @api public
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
micromatch.some = (list, patterns, options) => {
let items = [].concat(list);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (let pattern of [].concat(patterns)) {
let isMatch = picomatch(String(pattern), options);
if (items.some(item => isMatch(item))) {
return true;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return false;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Returns true if every string in the given `list` matches
* any of the given glob `patterns`.
*
* ```js
* const mm = require('micromatch');
* // mm.every(list, patterns[, options]);
*
* console.log(mm.every('foo.js', ['foo.js']));
* // true
* console.log(mm.every(['foo.js', 'bar.js'], ['*.js']));
* // true
* console.log(mm.every(['foo.js', 'bar.js'], ['*.js', '!foo.js']));
* // false
* console.log(mm.every(['foo.js'], ['*.js', '!foo.js']));
* // false
* ```
* @param {String|Array} `list` The string or array of strings to test.
* @param {String|Array} `patterns` One or more glob patterns to use for matching.
* @param {Object} `options` See available [options](#options) for changing how matches are performed
* @return {Boolean} Returns true if all `patterns` matches all of the strings in `list`
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.every = (list, patterns, options) => {
let items = [].concat(list);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (let pattern of [].concat(patterns)) {
let isMatch = picomatch(String(pattern), options);
if (!items.every(item => isMatch(item))) {
return false;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
return true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Returns true if **all** of the given `patterns` match
* the specified string.
*
* ```js
* const mm = require('micromatch');
* // mm.all(string, patterns[, options]);
*
* console.log(mm.all('foo.js', ['foo.js']));
* // true
*
* console.log(mm.all('foo.js', ['*.js', '!foo.js']));
* // false
*
* console.log(mm.all('foo.js', ['*.js', 'foo.js']));
* // true
*
* console.log(mm.all('foo.js', ['*.js', 'f*', '*o*', '*o.js']));
* // true
* ```
* @param {String|Array} `str` The string to test.
* @param {String|Array} `patterns` One or more glob patterns to use for matching.
* @param {Object} `options` See available [options](#options) for changing how matches are performed
* @return {Boolean} Returns true if any patterns match `str`
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.all = (str, patterns, options) => {
if (typeof str !== 'string') {
throw new TypeError(`Expected a string: "${util.inspect(str)}"`);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return [].concat(patterns).every(p => picomatch(p, options)(str));
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Returns an array of matches captured by `pattern` in `string, or `null` if the pattern did not match.
*
* ```js
* const mm = require('micromatch');
* // mm.capture(pattern, string[, options]);
*
* console.log(mm.capture('test/*.js', 'test/foo.js'));
* //=> ['foo']
* console.log(mm.capture('test/*.js', 'foo/bar.css'));
* //=> null
* ```
* @param {String} `glob` Glob pattern to use for matching.
* @param {String} `input` String to match
* @param {Object} `options` See available [options](#options) for changing how matches are performed
* @return {Array|null} Returns an array of captures if the input matches the glob pattern, otherwise `null`.
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.capture = (glob, input, options) => {
let posix = utils.isWindows(options);
let regex = picomatch.makeRe(String(glob), { ...options, capture: true });
let match = regex.exec(posix ? utils.toPosixSlashes(input) : input);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (match) {
return match.slice(1).map(v => v === void 0 ? '' : v);
}
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Create a regular expression from the given glob `pattern`.
*
* ```js
* const mm = require('micromatch');
* // mm.makeRe(pattern[, options]);
*
* console.log(mm.makeRe('*.js'));
* //=> /^(?:(\.[\\\/])?(?!\.)(?=.)[^\/]*?\.js)$/
* ```
* @param {String} `pattern` A glob pattern to convert to regex.
* @param {Object} `options`
* @return {RegExp} Returns a regex created from the given pattern.
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.makeRe = (...args) => picomatch.makeRe(...args);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Scan a glob pattern to separate the pattern into segments. Used
* by the [split](#split) method.
*
* ```js
* const mm = require('micromatch');
* const state = mm.scan(pattern[, options]);
* ```
* @param {String} `pattern`
* @param {Object} `options`
* @return {Object} Returns an object with
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.scan = (...args) => picomatch.scan(...args);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Parse a glob pattern to create the source string for a regular
* expression.
*
* ```js
* const mm = require('micromatch');
* const state = mm.parse(pattern[, options]);
* ```
* @param {String} `glob`
* @param {Object} `options`
* @return {Object} Returns an object with useful properties and output to be used as regex source string.
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.parse = (patterns, options) => {
let res = [];
for (let pattern of [].concat(patterns || [])) {
for (let str of braces(String(pattern), options)) {
res.push(picomatch.parse(str, options));
}
}
return res;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Process the given brace `pattern`.
*
* ```js
* const { braces } = require('micromatch');
* console.log(braces('foo/{a,b,c}/bar'));
* //=> [ 'foo/(a|b|c)/bar' ]
*
* console.log(braces('foo/{a,b,c}/bar', { expand: true }));
* //=> [ 'foo/a/bar', 'foo/b/bar', 'foo/c/bar' ]
* ```
* @param {String} `pattern` String with brace pattern to process.
* @param {Object} `options` Any [options](#options) to change how expansion is performed. See the [braces][] library for all available options.
* @return {Array}
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.braces = (pattern, options) => {
if (typeof pattern !== 'string') throw new TypeError('Expected a string');
if ((options && options.nobrace === true) || !/\{.*\}/.test(pattern)) {
return [pattern];
}
return braces(pattern, options);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Expand braces
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
micromatch.braceExpand = (pattern, options) => {
if (typeof pattern !== 'string') throw new TypeError('Expected a string');
return micromatch.braces(pattern, { ...options, expand: true });
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Expose micromatch
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = micromatch;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 7760:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/*! node-domexception. MIT License. Jimmy Wärting <https://jimmy.warting.se/opensource> */
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!globalThis.DOMException) {
try {
const { MessageChannel } = __nccwpck_require__(1267),
port = new MessageChannel().port1,
ab = new ArrayBuffer()
port.postMessage(ab, [ab, ab])
} catch (err) {
err.constructor.name === 'DOMException' && (
globalThis.DOMException = err.constructor
)
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = globalThis.DOMException
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 467:
/***/ ((module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var Stream = _interopDefault(__nccwpck_require__(2781));
var http = _interopDefault(__nccwpck_require__(3685));
var Url = _interopDefault(__nccwpck_require__(7310));
var whatwgUrl = _interopDefault(__nccwpck_require__(3323));
var https = _interopDefault(__nccwpck_require__(5687));
var zlib = _interopDefault(__nccwpck_require__(9796));
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Based on https://github.com/tmpvar/jsdom/blob/aa85b2abf07766ff7bf5c1f6daafb3726f2f2db5/lib/jsdom/living/blob.js
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// fix for "Readable" isn't a named export issue
const Readable = Stream.Readable;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const BUFFER = Symbol('buffer');
const TYPE = Symbol('type');
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class Blob {
constructor() {
this[TYPE] = '';
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const blobParts = arguments[0];
const options = arguments[1];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const buffers = [];
let size = 0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (blobParts) {
const a = blobParts;
const length = Number(a.length);
for (let i = 0; i < length; i++) {
const element = a[i];
let buffer;
if (element instanceof Buffer) {
buffer = element;
} else if (ArrayBuffer.isView(element)) {
buffer = Buffer.from(element.buffer, element.byteOffset, element.byteLength);
} else if (element instanceof ArrayBuffer) {
buffer = Buffer.from(element);
} else if (element instanceof Blob) {
buffer = element[BUFFER];
} else {
buffer = Buffer.from(typeof element === 'string' ? element : String(element));
}
size += buffer.length;
buffers.push(buffer);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this[BUFFER] = Buffer.concat(buffers);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let type = options && options.type !== undefined && String(options.type).toLowerCase();
if (type && !/[^\u0020-\u007E]/.test(type)) {
this[TYPE] = type;
}
}
get size() {
return this[BUFFER].length;
}
get type() {
return this[TYPE];
}
text() {
return Promise.resolve(this[BUFFER].toString());
}
arrayBuffer() {
const buf = this[BUFFER];
const ab = buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength);
return Promise.resolve(ab);
}
stream() {
const readable = new Readable();
readable._read = function () {};
readable.push(this[BUFFER]);
readable.push(null);
return readable;
}
toString() {
return '[object Blob]';
}
slice() {
const size = this.size;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const start = arguments[0];
const end = arguments[1];
let relativeStart, relativeEnd;
if (start === undefined) {
relativeStart = 0;
} else if (start < 0) {
relativeStart = Math.max(size + start, 0);
} else {
relativeStart = Math.min(start, size);
}
if (end === undefined) {
relativeEnd = size;
} else if (end < 0) {
relativeEnd = Math.max(size + end, 0);
} else {
relativeEnd = Math.min(end, size);
}
const span = Math.max(relativeEnd - relativeStart, 0);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const buffer = this[BUFFER];
const slicedBuffer = buffer.slice(relativeStart, relativeStart + span);
const blob = new Blob([], { type: arguments[2] });
blob[BUFFER] = slicedBuffer;
return blob;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperties(Blob.prototype, {
size: { enumerable: true },
type: { enumerable: true },
slice: { enumerable: true }
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(Blob.prototype, Symbol.toStringTag, {
value: 'Blob',
writable: false,
enumerable: false,
configurable: true
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* fetch-error.js
*
* FetchError interface for operational errors
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Create FetchError instance
*
* @param String message Error message for human
* @param String type Error type for machine
* @param String systemError For Node.js system error
* @return FetchError
*/
function FetchError(message, type, systemError) {
Error.call(this, message);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.message = message;
this.type = type;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// when err.type is `system`, err.code contains system error code
if (systemError) {
this.code = this.errno = systemError.code;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// hide custom error implementation details from end-users
Error.captureStackTrace(this, this.constructor);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
FetchError.prototype = Object.create(Error.prototype);
FetchError.prototype.constructor = FetchError;
FetchError.prototype.name = 'FetchError';
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let convert;
try {
convert = (__nccwpck_require__(2877).convert);
} catch (e) {}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const INTERNALS = Symbol('Body internals');
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// fix an issue where "PassThrough" isn't a named export for node <10
const PassThrough = Stream.PassThrough;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Body mixin
*
* Ref: https://fetch.spec.whatwg.org/#body
*
* @param Stream body Readable stream
* @param Object opts Response options
* @return Void
*/
function Body(body) {
var _this = this;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
_ref$size = _ref.size;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let size = _ref$size === undefined ? 0 : _ref$size;
var _ref$timeout = _ref.timeout;
let timeout = _ref$timeout === undefined ? 0 : _ref$timeout;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (body == null) {
// body is undefined or null
body = null;
} else if (isURLSearchParams(body)) {
// body is a URLSearchParams
body = Buffer.from(body.toString());
} else if (isBlob(body)) ; else if (Buffer.isBuffer(body)) ; else if (Object.prototype.toString.call(body) === '[object ArrayBuffer]') {
// body is ArrayBuffer
body = Buffer.from(body);
} else if (ArrayBuffer.isView(body)) {
// body is ArrayBufferView
body = Buffer.from(body.buffer, body.byteOffset, body.byteLength);
} else if (body instanceof Stream) ; else {
// none of the above
// coerce to string then buffer
body = Buffer.from(String(body));
}
this[INTERNALS] = {
body,
disturbed: false,
error: null
};
this.size = size;
this.timeout = timeout;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (body instanceof Stream) {
body.on('error', function (err) {
const error = err.name === 'AbortError' ? err : new FetchError(`Invalid response body while trying to fetch ${_this.url}: ${err.message}`, 'system', err);
_this[INTERNALS].error = error;
});
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Body.prototype = {
get body() {
return this[INTERNALS].body;
},
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get bodyUsed() {
return this[INTERNALS].disturbed;
},
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Decode response as ArrayBuffer
*
* @return Promise
*/
arrayBuffer() {
return consumeBody.call(this).then(function (buf) {
return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength);
});
},
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Return raw response as Blob
*
* @return Promise
*/
blob() {
let ct = this.headers && this.headers.get('content-type') || '';
return consumeBody.call(this).then(function (buf) {
return Object.assign(
// Prevent copying
new Blob([], {
type: ct.toLowerCase()
}), {
[BUFFER]: buf
});
});
},
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Decode response as json
*
* @return Promise
*/
json() {
var _this2 = this;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return consumeBody.call(this).then(function (buffer) {
try {
return JSON.parse(buffer.toString());
} catch (err) {
return Body.Promise.reject(new FetchError(`invalid json response body at ${_this2.url} reason: ${err.message}`, 'invalid-json'));
}
});
},
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Decode response as text
*
* @return Promise
*/
text() {
return consumeBody.call(this).then(function (buffer) {
return buffer.toString();
});
},
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Decode response as buffer (non-spec api)
*
* @return Promise
*/
buffer() {
return consumeBody.call(this);
},
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Decode response as text, while automatically detecting the encoding and
* trying to decode to UTF-8 (non-spec api)
*
* @return Promise
*/
textConverted() {
var _this3 = this;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return consumeBody.call(this).then(function (buffer) {
return convertBody(buffer, _this3.headers);
});
}
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// In browsers, all properties are enumerable.
Object.defineProperties(Body.prototype, {
body: { enumerable: true },
bodyUsed: { enumerable: true },
arrayBuffer: { enumerable: true },
blob: { enumerable: true },
json: { enumerable: true },
text: { enumerable: true }
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Body.mixIn = function (proto) {
for (const name of Object.getOwnPropertyNames(Body.prototype)) {
// istanbul ignore else: future proof
if (!(name in proto)) {
const desc = Object.getOwnPropertyDescriptor(Body.prototype, name);
Object.defineProperty(proto, name, desc);
}
}
2021-09-26 15:31:45 -04:00
};
/**
2022-05-31 14:18:28 -04:00
* Consume and convert an entire Body to a Buffer.
*
* Ref: https://fetch.spec.whatwg.org/#concept-body-consume-body
*
* @return Promise
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
function consumeBody() {
var _this4 = this;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (this[INTERNALS].disturbed) {
return Body.Promise.reject(new TypeError(`body used already for: ${this.url}`));
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this[INTERNALS].disturbed = true;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (this[INTERNALS].error) {
return Body.Promise.reject(this[INTERNALS].error);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let body = this.body;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// body is null
if (body === null) {
return Body.Promise.resolve(Buffer.alloc(0));
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// body is blob
if (isBlob(body)) {
body = body.stream();
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// body is buffer
if (Buffer.isBuffer(body)) {
return Body.Promise.resolve(body);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// istanbul ignore if: should never happen
if (!(body instanceof Stream)) {
return Body.Promise.resolve(Buffer.alloc(0));
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// body is stream
// get ready to actually consume the body
let accum = [];
let accumBytes = 0;
let abort = false;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return new Body.Promise(function (resolve, reject) {
let resTimeout;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// allow timeout on slow response body
if (_this4.timeout) {
resTimeout = setTimeout(function () {
abort = true;
reject(new FetchError(`Response timeout while trying to fetch ${_this4.url} (over ${_this4.timeout}ms)`, 'body-timeout'));
}, _this4.timeout);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// handle stream errors
body.on('error', function (err) {
if (err.name === 'AbortError') {
// if the request was aborted, reject with this Error
abort = true;
reject(err);
} else {
// other errors, such as incorrect content-encoding
reject(new FetchError(`Invalid response body while trying to fetch ${_this4.url}: ${err.message}`, 'system', err));
}
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
body.on('data', function (chunk) {
if (abort || chunk === null) {
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (_this4.size && accumBytes + chunk.length > _this4.size) {
abort = true;
reject(new FetchError(`content size at ${_this4.url} over limit: ${_this4.size}`, 'max-size'));
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
accumBytes += chunk.length;
accum.push(chunk);
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
body.on('end', function () {
if (abort) {
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
clearTimeout(resTimeout);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
try {
resolve(Buffer.concat(accum, accumBytes));
} catch (err) {
// handle streams that have accumulated too much data (issue #414)
reject(new FetchError(`Could not create Buffer from response body for ${_this4.url}: ${err.message}`, 'system', err));
}
});
});
}
2021-09-26 15:31:45 -04:00
/**
2022-05-31 14:18:28 -04:00
* Detect buffer encoding and convert to target encoding
* ref: http://www.w3.org/TR/2011/WD-html5-20110113/parsing.html#determining-the-character-encoding
2021-09-26 15:31:45 -04:00
*
2022-05-31 14:18:28 -04:00
* @param Buffer buffer Incoming buffer
* @param String encoding Target encoding
* @return String
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
function convertBody(buffer, headers) {
if (typeof convert !== 'function') {
throw new Error('The package `encoding` must be installed to use the textConverted() function');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const ct = headers.get('content-type');
let charset = 'utf-8';
let res, str;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// header
if (ct) {
res = /charset=([^;]*)/i.exec(ct);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// no charset in content type, peek at response body for at most 1024 bytes
str = buffer.slice(0, 1024).toString();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// html5
if (!res && str) {
res = /<meta.+?charset=(['"])(.+?)\1/i.exec(str);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// html4
if (!res && str) {
res = /<meta[\s]+?http-equiv=(['"])content-type\1[\s]+?content=(['"])(.+?)\2/i.exec(str);
if (!res) {
res = /<meta[\s]+?content=(['"])(.+?)\1[\s]+?http-equiv=(['"])content-type\3/i.exec(str);
if (res) {
res.pop(); // drop last quote
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (res) {
res = /charset=(.*)/i.exec(res.pop());
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// xml
if (!res && str) {
res = /<\?xml.+?encoding=(['"])(.+?)\1/i.exec(str);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// found charset
if (res) {
charset = res.pop();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// prevent decode issues when sites use incorrect encoding
// ref: https://hsivonen.fi/encoding-menu/
if (charset === 'gb2312' || charset === 'gbk') {
charset = 'gb18030';
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// turn raw buffers into a single utf-8 buffer
return convert(buffer, 'UTF-8', charset).toString();
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
/**
* Detect a URLSearchParams object
* ref: https://github.com/bitinn/node-fetch/issues/296#issuecomment-307598143
*
* @param Object obj Object to detect by type or brand
* @return String
*/
function isURLSearchParams(obj) {
// Duck-typing as a necessary condition.
if (typeof obj !== 'object' || typeof obj.append !== 'function' || typeof obj.delete !== 'function' || typeof obj.get !== 'function' || typeof obj.getAll !== 'function' || typeof obj.has !== 'function' || typeof obj.set !== 'function') {
return false;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Brand-checking and more duck-typing as optional condition.
return obj.constructor.name === 'URLSearchParams' || Object.prototype.toString.call(obj) === '[object URLSearchParams]' || typeof obj.sort === 'function';
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Check if `obj` is a W3C `Blob` object (which `File` inherits from)
* @param {*} obj
* @return {boolean}
*/
function isBlob(obj) {
return typeof obj === 'object' && typeof obj.arrayBuffer === 'function' && typeof obj.type === 'string' && typeof obj.stream === 'function' && typeof obj.constructor === 'function' && typeof obj.constructor.name === 'string' && /^(Blob|File)$/.test(obj.constructor.name) && /^(Blob|File)$/.test(obj[Symbol.toStringTag]);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Clone body given Res/Req instance
*
* @param Mixed instance Response or Request instance
* @return Mixed
*/
function clone(instance) {
let p1, p2;
let body = instance.body;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// don't allow cloning a used body
if (instance.bodyUsed) {
throw new Error('cannot clone body after it is used');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// check that body is a stream and not form-data object
// note: we can't clone the form-data object without having it as a dependency
if (body instanceof Stream && typeof body.getBoundary !== 'function') {
// tee instance body
p1 = new PassThrough();
p2 = new PassThrough();
body.pipe(p1);
body.pipe(p2);
// set instance body to teed body and return the other teed body
instance[INTERNALS].body = p1;
body = p2;
}
return body;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
/**
* Performs the operation "extract a `Content-Type` value from |object|" as
* specified in the specification:
* https://fetch.spec.whatwg.org/#concept-bodyinit-extract
*
* This function assumes that instance.body is present.
*
* @param Mixed instance Any options.body input
*/
function extractContentType(body) {
if (body === null) {
// body is null
return null;
} else if (typeof body === 'string') {
// body is string
return 'text/plain;charset=UTF-8';
} else if (isURLSearchParams(body)) {
// body is a URLSearchParams
return 'application/x-www-form-urlencoded;charset=UTF-8';
} else if (isBlob(body)) {
// body is blob
return body.type || null;
} else if (Buffer.isBuffer(body)) {
// body is buffer
return null;
} else if (Object.prototype.toString.call(body) === '[object ArrayBuffer]') {
// body is ArrayBuffer
return null;
} else if (ArrayBuffer.isView(body)) {
// body is ArrayBufferView
return null;
} else if (typeof body.getBoundary === 'function') {
// detect form data input from form-data module
return `multipart/form-data;boundary=${body.getBoundary()}`;
} else if (body instanceof Stream) {
// body is stream
// can't really do much about this
return null;
} else {
// Body constructor defaults other things to string
return 'text/plain;charset=UTF-8';
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* The Fetch Standard treats this as if "total bytes" is a property on the body.
* For us, we have to explicitly get it with a function.
*
* ref: https://fetch.spec.whatwg.org/#concept-body-total-bytes
*
* @param Body instance Instance of Body
* @return Number? Number of bytes, or null if not possible
*/
function getTotalBytes(instance) {
const body = instance.body;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (body === null) {
// body is null
return 0;
} else if (isBlob(body)) {
return body.size;
} else if (Buffer.isBuffer(body)) {
// body is buffer
return body.length;
} else if (body && typeof body.getLengthSync === 'function') {
// detect form data input from form-data module
if (body._lengthRetrievers && body._lengthRetrievers.length == 0 || // 1.x
body.hasKnownLength && body.hasKnownLength()) {
// 2.x
return body.getLengthSync();
}
return null;
} else {
// body is stream
return null;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
2021-09-26 15:31:45 -04:00
/**
2022-05-31 14:18:28 -04:00
* Write a Body to a Node.js WritableStream (e.g. http.Request) object.
2021-09-26 15:31:45 -04:00
*
2022-05-31 14:18:28 -04:00
* @param Body instance Instance of Body
* @return Void
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
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);
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
// expose Promise
Body.Promise = global.Promise;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* headers.js
*
* Headers class offers convenient helpers
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const invalidTokenRegex = /[^\^_`a-zA-Z\-0-9!#$%&'*+.|~]/;
const invalidHeaderCharRegex = /[^\t\x20-\x7e\x80-\xff]/;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function validateName(name) {
name = `${name}`;
if (invalidTokenRegex.test(name) || name === '') {
throw new TypeError(`${name} is not a legal HTTP header name`);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function validateValue(value) {
value = `${value}`;
if (invalidHeaderCharRegex.test(value)) {
throw new TypeError(`${value} is not a legal HTTP header value`);
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
/**
* Find the key in the map object given a header name.
*
* Returns undefined if not found.
*
* @param String name Header name
* @return String|Undefined
*/
function find(map, name) {
name = name.toLowerCase();
for (const key in map) {
if (key.toLowerCase() === name) {
return key;
}
}
return undefined;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const MAP = Symbol('map');
class Headers {
/**
* Headers class
*
* @param Object headers Response headers
* @return Void
*/
constructor() {
let init = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : undefined;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this[MAP] = Object.create(null);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (init instanceof Headers) {
const rawHeaders = init.raw();
const headerNames = Object.keys(rawHeaders);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (const headerName of headerNames) {
for (const value of rawHeaders[headerName]) {
this.append(headerName, value);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// We don't worry about converting prop to ByteString here as append()
// will handle it.
if (init == null) ; else if (typeof init === 'object') {
const method = init[Symbol.iterator];
if (method != null) {
if (typeof method !== 'function') {
throw new TypeError('Header pairs must be iterable');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// sequence<sequence<ByteString>>
// Note: per spec we have to first exhaust the lists then process them
const pairs = [];
for (const pair of init) {
if (typeof pair !== 'object' || typeof pair[Symbol.iterator] !== 'function') {
throw new TypeError('Each header pair must be iterable');
}
pairs.push(Array.from(pair));
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (const pair of pairs) {
if (pair.length !== 2) {
throw new TypeError('Each header pair must be a name/value tuple');
}
this.append(pair[0], pair[1]);
}
} else {
// record<ByteString, ByteString>
for (const key of Object.keys(init)) {
const value = init[key];
this.append(key, value);
}
}
} else {
throw new TypeError('Provided initializer must be an object');
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Return combined header value given name
*
* @param String name Header name
* @return Mixed
*/
get(name) {
name = `${name}`;
validateName(name);
const key = find(this[MAP], name);
if (key === undefined) {
return null;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return this[MAP][key].join(', ');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Iterate over all headers
*
* @param Function callback Executed for each item with parameters (value, name, thisArg)
* @param Boolean thisArg `this` context for callback function
* @return Void
*/
forEach(callback) {
let thisArg = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let pairs = getHeaders(this);
let i = 0;
while (i < pairs.length) {
var _pairs$i = pairs[i];
const name = _pairs$i[0],
value = _pairs$i[1];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
callback.call(thisArg, value, name, this);
pairs = getHeaders(this);
i++;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Overwrite header values given name
*
* @param String name Header name
* @param String value Header value
* @return Void
*/
set(name, value) {
name = `${name}`;
value = `${value}`;
validateName(name);
validateValue(value);
const key = find(this[MAP], name);
this[MAP][key !== undefined ? key : name] = [value];
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Append a value onto existing header
*
* @param String name Header name
* @param String value Header value
* @return Void
*/
append(name, value) {
name = `${name}`;
value = `${value}`;
validateName(name);
validateValue(value);
const key = find(this[MAP], name);
if (key !== undefined) {
this[MAP][key].push(value);
} else {
this[MAP][name] = [value];
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Check for header name existence
*
* @param String name Header name
* @return Boolean
*/
has(name) {
name = `${name}`;
validateName(name);
return find(this[MAP], name) !== undefined;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Delete all header values given name
*
* @param String name Header name
* @return Void
*/
delete(name) {
name = `${name}`;
validateName(name);
const key = find(this[MAP], name);
if (key !== undefined) {
delete this[MAP][key];
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Return raw headers (non-spec api)
*
* @return Object
*/
raw() {
return this[MAP];
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* 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');
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
Headers.prototype.entries = Headers.prototype[Symbol.iterator];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(Headers.prototype, Symbol.toStringTag, {
value: 'Headers',
writable: false,
enumerable: false,
configurable: true
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperties(Headers.prototype, {
get: { enumerable: true },
forEach: { enumerable: true },
set: { enumerable: true },
append: { enumerable: true },
has: { enumerable: true },
delete: { enumerable: true },
keys: { enumerable: true },
values: { enumerable: true },
entries: { enumerable: true }
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function getHeaders(headers) {
let kind = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'key+value';
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const keys = Object.keys(headers[MAP]).sort();
return keys.map(kind === 'key' ? function (k) {
return k.toLowerCase();
} : kind === 'value' ? function (k) {
return headers[MAP][k].join(', ');
} : function (k) {
return [k.toLowerCase(), headers[MAP][k].join(', ')];
});
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const INTERNAL = Symbol('internal');
function createHeadersIterator(target, kind) {
const iterator = Object.create(HeadersIteratorPrototype);
iterator[INTERNAL] = {
target,
kind,
index: 0
};
return iterator;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
const HeadersIteratorPrototype = Object.setPrototypeOf({
next() {
// istanbul ignore if
if (!this || Object.getPrototypeOf(this) !== HeadersIteratorPrototype) {
throw new TypeError('Value of `this` is not a HeadersIterator');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var _INTERNAL = this[INTERNAL];
const target = _INTERNAL.target,
kind = _INTERNAL.kind,
index = _INTERNAL.index;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const values = getHeaders(target, kind);
const len = values.length;
if (index >= len) {
return {
value: undefined,
done: true
};
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this[INTERNAL].index = index + 1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return {
value: values[index],
done: false
};
}
}, Object.getPrototypeOf(Object.getPrototypeOf([][Symbol.iterator]())));
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(HeadersIteratorPrototype, Symbol.toStringTag, {
value: 'HeadersIterator',
writable: false,
enumerable: false,
configurable: true
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Export the Headers object in a form that Node.js can consume.
*
* @param Headers headers
* @return Object
*/
function exportNodeCompatibleHeaders(headers) {
const obj = Object.assign({ __proto__: null }, headers[MAP]);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// http.request() only supports string as Host header. This hack makes
// specifying custom Host header possible.
const hostHeaderKey = find(headers[MAP], 'Host');
if (hostHeaderKey !== undefined) {
obj[hostHeaderKey] = obj[hostHeaderKey][0];
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return obj;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Create a Headers object from an object of headers, ignoring those that do
* not conform to HTTP grammar productions.
*
* @param Object obj Object of headers
* @return Headers
*/
function createHeadersLenient(obj) {
const headers = new Headers();
for (const name of Object.keys(obj)) {
if (invalidTokenRegex.test(name)) {
continue;
}
if (Array.isArray(obj[name])) {
for (const val of obj[name]) {
if (invalidHeaderCharRegex.test(val)) {
continue;
}
if (headers[MAP][name] === undefined) {
headers[MAP][name] = [val];
} else {
headers[MAP][name].push(val);
}
}
} else if (!invalidHeaderCharRegex.test(obj[name])) {
headers[MAP][name] = [obj[name]];
}
}
return headers;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
const INTERNALS$1 = Symbol('Response internals');
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// fix an issue where "STATUS_CODES" aren't a named export for node <10
const STATUS_CODES = http.STATUS_CODES;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Response class
*
* @param Stream body Readable stream
* @param Object opts Response options
* @return Void
*/
class Response {
constructor() {
let body = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;
let opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Body.call(this, body, opts);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const status = opts.status || 200;
const headers = new Headers(opts.headers);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (body != null && !headers.has('Content-Type')) {
const contentType = extractContentType(body);
if (contentType) {
headers.append('Content-Type', contentType);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this[INTERNALS$1] = {
url: opts.url,
status,
statusText: opts.statusText || STATUS_CODES[status],
headers,
counter: opts.counter
};
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get url() {
return this[INTERNALS$1].url || '';
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get status() {
return this[INTERNALS$1].status;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Convenience property representing if the request ended normally
*/
get ok() {
return this[INTERNALS$1].status >= 200 && this[INTERNALS$1].status < 300;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get redirected() {
return this[INTERNALS$1].counter > 0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get statusText() {
return this[INTERNALS$1].statusText;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get headers() {
return this[INTERNALS$1].headers;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Clone this response
*
* @return Response
*/
clone() {
return new Response(clone(this), {
url: this.url,
status: this.status,
statusText: this.statusText,
headers: this.headers,
ok: this.ok,
redirected: this.redirected
});
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Body.mixIn(Response.prototype);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperties(Response.prototype, {
url: { enumerable: true },
status: { enumerable: true },
ok: { enumerable: true },
redirected: { enumerable: true },
statusText: { enumerable: true },
headers: { enumerable: true },
clone: { enumerable: true }
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(Response.prototype, Symbol.toStringTag, {
value: 'Response',
writable: false,
enumerable: false,
configurable: true
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const INTERNALS$2 = Symbol('Request internals');
const URL = Url.URL || whatwgUrl.URL;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// fix an issue where "format", "parse" aren't a named export for node <10
const parse_url = Url.parse;
const format_url = Url.format;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Wrapper around `new URL` to handle arbitrary URLs
*
* @param {string} urlStr
* @return {void}
*/
function parseURL(urlStr) {
/*
Check whether the URL is absolute or not
Scheme: https://tools.ietf.org/html/rfc3986#section-3.1
Absolute URL: https://tools.ietf.org/html/rfc3986#section-4.3
*/
if (/^[a-zA-Z][a-zA-Z\d+\-.]*:/.exec(urlStr)) {
urlStr = new URL(urlStr).toString();
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Fallback to old implementation for arbitrary URLs
return parse_url(urlStr);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
const streamDestructionSupported = 'destroy' in Stream.Readable.prototype;
2021-09-26 15:31:45 -04:00
/**
2022-05-31 14:18:28 -04:00
* Check if a value is an instance of Request.
*
* @param Mixed input
* @return Boolean
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
function isRequest(input) {
return typeof input === 'object' && typeof input[INTERNALS$2] === 'object';
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function isAbortSignal(signal) {
const proto = signal && typeof signal === 'object' && Object.getPrototypeOf(signal);
return !!(proto && proto.constructor.name === 'AbortSignal');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Request class
*
* @param Mixed input Url or Request instance
* @param Object init Custom options
* @return Void
*/
class Request {
constructor(input) {
let init = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let parsedURL;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// normalize input
if (!isRequest(input)) {
if (input && input.href) {
// in order to support Node.js' Url objects; though WHATWG's URL objects
// will fall into this branch also (since their `toString()` will return
// `href` property anyway)
parsedURL = parseURL(input.href);
} else {
// coerce input to a string before attempting to parse
parsedURL = parseURL(`${input}`);
}
input = {};
} else {
parsedURL = parseURL(input.url);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let method = init.method || input.method || 'GET';
method = method.toUpperCase();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if ((init.body != null || isRequest(input) && input.body !== null) && (method === 'GET' || method === 'HEAD')) {
throw new TypeError('Request with GET/HEAD method cannot have body');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let inputBody = init.body != null ? init.body : isRequest(input) && input.body !== null ? clone(input) : null;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Body.call(this, inputBody, {
timeout: init.timeout || input.timeout || 0,
size: init.size || input.size || 0
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const headers = new Headers(init.headers || input.headers || {});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (inputBody != null && !headers.has('Content-Type')) {
const contentType = extractContentType(inputBody);
if (contentType) {
headers.append('Content-Type', contentType);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let signal = isRequest(input) ? input.signal : null;
if ('signal' in init) signal = init.signal;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (signal != null && !isAbortSignal(signal)) {
throw new TypeError('Expected signal to be an instanceof AbortSignal');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this[INTERNALS$2] = {
method,
redirect: init.redirect || input.redirect || 'follow',
headers,
parsedURL,
signal
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// node-fetch-only options
this.follow = init.follow !== undefined ? init.follow : input.follow !== undefined ? input.follow : 20;
this.compress = init.compress !== undefined ? init.compress : input.compress !== undefined ? input.compress : true;
this.counter = init.counter || input.counter || 0;
this.agent = init.agent || input.agent;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get method() {
return this[INTERNALS$2].method;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get url() {
return format_url(this[INTERNALS$2].parsedURL);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get headers() {
return this[INTERNALS$2].headers;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get redirect() {
return this[INTERNALS$2].redirect;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get signal() {
return this[INTERNALS$2].signal;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Clone this request
*
* @return Request
*/
clone() {
return new Request(this);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Body.mixIn(Request.prototype);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(Request.prototype, Symbol.toStringTag, {
value: 'Request',
writable: false,
enumerable: false,
configurable: true
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperties(Request.prototype, {
method: { enumerable: true },
url: { enumerable: true },
headers: { enumerable: true },
redirect: { enumerable: true },
clone: { enumerable: true },
signal: { enumerable: true }
});
2021-09-26 15:31:45 -04:00
/**
2022-05-31 14:18:28 -04:00
* Convert a Request to Node.js http request options.
*
* @param Request A Request instance
* @return Object The options object to be passed to http.request
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
function getNodeRequestOptions(request) {
const parsedURL = request[INTERNALS$2].parsedURL;
const headers = new Headers(request[INTERNALS$2].headers);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// fetch step 1.3
if (!headers.has('Accept')) {
headers.set('Accept', '*/*');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Basic fetch
if (!parsedURL.protocol || !parsedURL.hostname) {
throw new TypeError('Only absolute URLs are supported');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!/^https?:$/.test(parsedURL.protocol)) {
throw new TypeError('Only HTTP(S) protocols are supported');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (request.signal && request.body instanceof Stream.Readable && !streamDestructionSupported) {
throw new Error('Cancellation of streamed requests with AbortSignal is not supported in node < 8');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// HTTP-network-or-cache fetch steps 2.4-2.7
let contentLengthValue = null;
if (request.body == null && /^(POST|PUT)$/i.test(request.method)) {
contentLengthValue = '0';
}
if (request.body != null) {
const totalBytes = getTotalBytes(request);
if (typeof totalBytes === 'number') {
contentLengthValue = String(totalBytes);
}
}
if (contentLengthValue) {
headers.set('Content-Length', contentLengthValue);
}
// HTTP-network-or-cache fetch step 2.11
if (!headers.has('User-Agent')) {
headers.set('User-Agent', 'node-fetch/1.0 (+https://github.com/bitinn/node-fetch)');
}
// HTTP-network-or-cache fetch step 2.15
if (request.compress && !headers.has('Accept-Encoding')) {
headers.set('Accept-Encoding', 'gzip,deflate');
}
let agent = request.agent;
if (typeof agent === 'function') {
agent = agent(parsedURL);
}
if (!headers.has('Connection') && !agent) {
headers.set('Connection', 'close');
}
// HTTP-network fetch step 4.2
// chunked encoding is handled by Node.js
return Object.assign({}, parsedURL, {
method: request.method,
headers: exportNodeCompatibleHeaders(headers),
agent
});
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
2021-09-26 15:31:45 -04:00
/**
2022-05-31 14:18:28 -04:00
* abort-error.js
2021-09-26 15:31:45 -04:00
*
2022-05-31 14:18:28 -04:00
* AbortError interface for cancelled requests
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
2021-09-26 15:31:45 -04:00
/**
2022-05-31 14:18:28 -04:00
* Create AbortError instance
2021-09-26 15:31:45 -04:00
*
2022-05-31 14:18:28 -04:00
* @param String message Error message for human
* @return AbortError
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
function AbortError(message) {
Error.call(this, message);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.type = 'aborted';
this.message = message;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// hide custom error implementation details from end-users
Error.captureStackTrace(this, this.constructor);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
AbortError.prototype = Object.create(Error.prototype);
AbortError.prototype.constructor = AbortError;
AbortError.prototype.name = 'AbortError';
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const URL$1 = Url.URL || whatwgUrl.URL;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// fix an issue where "PassThrough", "resolve" aren't a named export for node <10
const PassThrough$1 = Stream.PassThrough;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const isDomainOrSubdomain = function isDomainOrSubdomain(destination, original) {
const orig = new URL$1(original).hostname;
const dest = new URL$1(destination).hostname;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return orig === dest || orig[orig.length - dest.length - 1] === '.' && orig.endsWith(dest);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Fetch function
*
* @param Mixed url Absolute url or Request instance
* @param Object opts Fetch options
* @return Promise
*/
function fetch(url, opts) {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// allow custom promise
if (!fetch.Promise) {
throw new Error('native promise missing, set fetch.Promise to your favorite alternative');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Body.Promise = fetch.Promise;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// wrap http.request into fetch
return new fetch.Promise(function (resolve, reject) {
// build request object
const request = new Request(url, opts);
const options = getNodeRequestOptions(request);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const send = (options.protocol === 'https:' ? https : http).request;
const signal = request.signal;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let response = null;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const abort = function abort() {
let error = new AbortError('The user aborted a request.');
reject(error);
if (request.body && request.body instanceof Stream.Readable) {
request.body.destroy(error);
}
if (!response || !response.body) return;
response.body.emit('error', error);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (signal && signal.aborted) {
abort();
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const abortAndFinalize = function abortAndFinalize() {
abort();
finalize();
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// send request
const req = send(options);
let reqTimeout;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (signal) {
signal.addEventListener('abort', abortAndFinalize);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function finalize() {
req.abort();
if (signal) signal.removeEventListener('abort', abortAndFinalize);
clearTimeout(reqTimeout);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (request.timeout) {
req.once('socket', function (socket) {
reqTimeout = setTimeout(function () {
reject(new FetchError(`network timeout at: ${request.url}`, 'request-timeout'));
finalize();
}, request.timeout);
});
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
req.on('error', function (err) {
reject(new FetchError(`request to ${request.url} failed, reason: ${err.message}`, 'system', err));
finalize();
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
req.on('response', function (res) {
clearTimeout(reqTimeout);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const headers = createHeadersLenient(res.headers);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// HTTP fetch step 5
if (fetch.isRedirect(res.statusCode)) {
// HTTP fetch step 5.2
const location = headers.get('Location');
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// HTTP fetch step 5.3
let locationURL = null;
try {
locationURL = location === null ? null : new URL$1(location, request.url).toString();
} catch (err) {
// error here can only be invalid URL in Location: header
// do not throw when options.redirect == manual
// let the user extract the errorneous redirect URL
if (request.redirect !== 'manual') {
reject(new FetchError(`uri requested responds with an invalid redirect URL: ${location}`, 'invalid-redirect'));
finalize();
return;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// HTTP fetch step 5.5
switch (request.redirect) {
case 'error':
reject(new FetchError(`uri requested responds with a redirect, redirect mode is set to error: ${request.url}`, 'no-redirect'));
finalize();
return;
case 'manual':
// node-fetch-specific step: make manual redirect a bit easier to use by setting the Location header value to the resolved URL.
if (locationURL !== null) {
// handle corrupted header
try {
headers.set('Location', locationURL);
} catch (err) {
// istanbul ignore next: nodejs server prevent invalid response headers, we can't test this through normal request
reject(err);
}
}
break;
case 'follow':
// HTTP-redirect fetch step 2
if (locationURL === null) {
break;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// HTTP-redirect fetch step 5
if (request.counter >= request.follow) {
reject(new FetchError(`maximum redirect reached at: ${request.url}`, 'max-redirect'));
finalize();
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// HTTP-redirect fetch step 6 (counter increment)
// Create a new Request object.
const requestOpts = {
headers: new Headers(request.headers),
follow: request.follow,
counter: request.counter + 1,
agent: request.agent,
compress: request.compress,
method: request.method,
body: request.body,
signal: request.signal,
timeout: request.timeout,
size: request.size
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!isDomainOrSubdomain(request.url, locationURL)) {
for (const name of ['authorization', 'www-authenticate', 'cookie', 'cookie2']) {
requestOpts.headers.delete(name);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04: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;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// HTTP-redirect fetch step 11
if (res.statusCode === 303 || (res.statusCode === 301 || res.statusCode === 302) && request.method === 'POST') {
requestOpts.method = 'GET';
requestOpts.body = undefined;
requestOpts.headers.delete('content-length');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// HTTP-redirect fetch step 15
resolve(fetch(new Request(locationURL, requestOpts)));
finalize();
return;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// prepare response
res.once('end', function () {
if (signal) signal.removeEventListener('abort', abortAndFinalize);
});
let body = res.pipe(new PassThrough$1());
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const response_options = {
url: request.url,
status: res.statusCode,
statusText: res.statusMessage,
headers: headers,
size: request.size,
timeout: request.timeout,
counter: request.counter
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// HTTP-network fetch step 12.1.1.3
const codings = headers.get('Content-Encoding');
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// HTTP-network fetch step 12.1.1.4: handle content codings
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// in following scenarios we ignore compression support
// 1. compression support is disabled
// 2. HEAD request
// 3. no Content-Encoding header
// 4. no content response (204)
// 5. content not modified response (304)
if (!request.compress || request.method === 'HEAD' || codings === null || res.statusCode === 204 || res.statusCode === 304) {
response = new Response(body, response_options);
resolve(response);
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// For Node v6+
// Be less strict when decoding compressed responses, since sometimes
// servers send slightly invalid responses that are still accepted
// by common browsers.
// Always using Z_SYNC_FLUSH is what cURL does.
const zlibOptions = {
flush: zlib.Z_SYNC_FLUSH,
finishFlush: zlib.Z_SYNC_FLUSH
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// for gzip
if (codings == 'gzip' || codings == 'x-gzip') {
body = body.pipe(zlib.createGunzip(zlibOptions));
response = new Response(body, response_options);
resolve(response);
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// for deflate
if (codings == 'deflate' || codings == 'x-deflate') {
// handle the infamous raw deflate response from old servers
// a hack for old IIS and Apache servers
const raw = res.pipe(new PassThrough$1());
raw.once('data', function (chunk) {
// see http://stackoverflow.com/questions/37519828
if ((chunk[0] & 0x0F) === 0x08) {
body = body.pipe(zlib.createInflate());
} else {
body = body.pipe(zlib.createInflateRaw());
}
response = new Response(body, response_options);
resolve(response);
});
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// for br
if (codings == 'br' && typeof zlib.createBrotliDecompress === 'function') {
body = body.pipe(zlib.createBrotliDecompress());
response = new Response(body, response_options);
resolve(response);
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// otherwise, use response as-is
response = new Response(body, response_options);
resolve(response);
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
writeToStream(req, request);
});
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
/**
* Redirect code matching
*
* @param Number code Status code
* @return Boolean
*/
fetch.isRedirect = function (code) {
return code === 301 || code === 302 || code === 303 || code === 307 || code === 308;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// expose Promise
fetch.Promise = global.Promise;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = exports = fetch;
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports["default"] = exports;
exports.Headers = Headers;
exports.Request = Request;
exports.Response = Response;
exports.FetchError = FetchError;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 2299:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var punycode = __nccwpck_require__(5477);
var mappingTable = __nccwpck_require__(1907);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var PROCESSING_OPTIONS = {
TRANSITIONAL: 0,
NONTRANSITIONAL: 1
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function normalize(str) { // fix bug in v8
return str.split('\u0000').map(function (s) { return s.normalize('NFC'); }).join('\u0000');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function findStatus(val) {
var start = 0;
var end = mappingTable.length - 1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return null;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var regexAstralSymbols = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function countSymbols(string) {
return string
// replace every surrogate pair with a BMP symbol
.replace(regexAstralSymbols, '_')
// then get the length
.length;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function mapChars(domain_name, useSTD3, processing_option) {
var hasError = false;
var processed = "";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var len = countSymbols(domain_name);
for (var i = 0; i < len; ++i) {
var codePoint = domain_name.codePointAt(i);
var status = findStatus(codePoint);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
processed += String.fromCodePoint(codePoint);
break;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return {
string: processed,
error: hasError
};
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var combiningMarksRegex = /[\u0300-\u036F\u0483-\u0489\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u0610-\u061A\u064B-\u065F\u0670\u06D6-\u06DC\u06DF-\u06E4\u06E7\u06E8\u06EA-\u06ED\u0711\u0730-\u074A\u07A6-\u07B0\u07EB-\u07F3\u0816-\u0819\u081B-\u0823\u0825-\u0827\u0829-\u082D\u0859-\u085B\u08E4-\u0903\u093A-\u093C\u093E-\u094F\u0951-\u0957\u0962\u0963\u0981-\u0983\u09BC\u09BE-\u09C4\u09C7\u09C8\u09CB-\u09CD\u09D7\u09E2\u09E3\u0A01-\u0A03\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A70\u0A71\u0A75\u0A81-\u0A83\u0ABC\u0ABE-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AE2\u0AE3\u0B01-\u0B03\u0B3C\u0B3E-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B62\u0B63\u0B82\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD7\u0C00-\u0C03\u0C3E-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C62\u0C63\u0C81-\u0C83\u0CBC\u0CBE-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CE2\u0CE3\u0D01-\u0D03\u0D3E-\u0D44\u0D46-\u0D48\u0D4A-\u0D4D\u0D57\u0D62\u0D63\u0D82\u0D83\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DF2\u0DF3\u0E31\u0E34-\u0E3A\u0E47-\u0E4E\u0EB1\u0EB4-\u0EB9\u0EBB\u0EBC\u0EC8-\u0ECD\u0F18\u0F19\u0F35\u0F37\u0F39\u0F3E\u0F3F\u0F71-\u0F84\u0F86\u0F87\u0F8D-\u0F97\u0F99-\u0FBC\u0FC6\u102B-\u103E\u1056-\u1059\u105E-\u1060\u1062-\u1064\u1067-\u106D\u1071-\u1074\u1082-\u108D\u108F\u109A-\u109D\u135D-\u135F\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17B4-\u17D3\u17DD\u180B-\u180D\u18A9\u1920-\u192B\u1930-\u193B\u19B0-\u19C0\u19C8\u19C9\u1A17-\u1A1B\u1A55-\u1A5E\u1A60-\u1A7C\u1A7F\u1AB0-\u1ABE\u1B00-\u1B04\u1B34-\u1B44\u1B6B-\u1B73\u1B80-\u1B82\u1BA1-\u1BAD\u1BE6-\u1BF3\u1C24-\u1C37\u1CD0-\u1CD2\u1CD4-\u1CE8\u1CED\u1CF2-\u1CF4\u1CF8\u1CF9\u1DC0-\u1DF5\u1DFC-\u1DFF\u20D0-\u20F0\u2CEF-\u2CF1\u2D7F\u2DE0-\u2DFF\u302A-\u302F\u3099\u309A\uA66F-\uA672\uA674-\uA67D\uA69F\uA6F0\uA6F1\uA802\uA806\uA80B\uA823-\uA827\uA880\uA881\uA8B4-\uA8C4\uA8E0-\uA8F1\uA926-\uA92D\uA947-\uA953\uA980-\uA983\uA9B3-\uA9C0\uA9E5\uAA29-\uAA36\uAA43\uAA4C\uAA4D\uAA7B-\uAA7D\uAAB0\uAAB2-\uAAB4\uAAB7\uAAB8\uAABE\uAABF\uAAC1\uAAEB-\uAAEF\uAAF5\uAAF6\uABE3-\uABEA\uABEC\uABED\uFB1E\uFE00-\uFE0F\uFE20-\uFE2D]|\uD800[\uDDFD\uDEE0\uDF76-\uDF7A]|\uD802[\uDE01-\uDE03\uDE05\uDE06\uDE0C-\uDE0F\uDE38-\uDE3A\uDE3F\uDEE5\uDEE6]|\uD804[\uDC00-\uDC02\uDC38-\uDC46\uDC7F-\uDC82\uDCB0-\uDCBA\uDD00-\uDD02\uDD27-\uDD34\uDD73\uDD80-\uDD82\uDDB3-\uDDC0\uDE2C-\uDE37\uDEDF-\uDEEA\uDF01-\uDF03\uDF3C\uDF3E-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF57\uDF62\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDCB0-\uDCC3\uDDAF-\uDDB5\uDDB8-\uDDC0\uDE30-\uDE40\uDEAB-\uDEB7]|\uD81A[\uDEF0-\uDEF4\uDF30-\uDF36]|\uD81B[\uDF51-\uDF7E\uDF8F-\uDF92]|\uD82F[\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD83A[\uDCD0-\uDCD6]|\uDB40[\uDD00-\uDDEF]/;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function validateLabel(label, processing_option) {
if (label.substr(0, 4) === "xn--") {
label = punycode.toUnicode(label);
processing_option = PROCESSING_OPTIONS.NONTRANSITIONAL;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var error = false;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (normalize(label) !== label ||
(label[3] === "-" && label[4] === "-") ||
label[0] === "-" || label[label.length - 1] === "-" ||
label.indexOf(".") !== -1 ||
label.search(combiningMarksRegex) === 0) {
error = true;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
var len = countSymbols(label);
for (var i = 0; i < len; ++i) {
var status = findStatus(label.codePointAt(i));
if ((processing === PROCESSING_OPTIONS.TRANSITIONAL && status[1] !== "valid") ||
(processing === PROCESSING_OPTIONS.NONTRANSITIONAL &&
status[1] !== "valid" && status[1] !== "deviation")) {
error = true;
break;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return {
label: label,
error: error
};
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function processing(domain_name, useSTD3, processing_option) {
var result = mapChars(domain_name, useSTD3, processing_option);
result.string = normalize(result.string);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return {
string: labels.join("."),
error: result.error
};
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.toASCII = function(domain_name, useSTD3, processing_option, verifyDnsLength) {
var result = processing(domain_name, useSTD3, processing_option);
var labels = result.string.split(".");
labels = labels.map(function(l) {
try {
return punycode.toASCII(l);
} catch(e) {
result.error = true;
return l;
}
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (verifyDnsLength) {
var total = labels.slice(0, labels.length - 1).join(".").length;
if (total.length > 253 || total.length === 0) {
result.error = true;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (var i=0; i < labels.length; ++i) {
if (labels.length > 63 || labels.length === 0) {
result.error = true;
break;
}
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (result.error) return null;
return labels.join(".");
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
module.exports.toUnicode = function(domain_name, useSTD3) {
var result = processing(domain_name, useSTD3, PROCESSING_OPTIONS.NONTRANSITIONAL);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return {
domain: result.string,
error: result.error
};
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
module.exports.PROCESSING_OPTIONS = PROCESSING_OPTIONS;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 5871:
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var conversions = {};
module.exports = conversions;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function sign(x) {
return x < 0 ? -1 : 1;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function evenRound(x) {
// Round x to the nearest integer, choosing the even integer if it lies halfway between two.
if ((x % 1) === 0.5 && (x & 1) === 0) { // [even number].5; round down (i.e. floor)
return Math.floor(x);
2021-09-26 15:31:45 -04:00
} else {
2022-05-31 14:18:28 -04:00
return Math.round(x);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function createNumberConversion(bitLength, typeOpts) {
if (!typeOpts.unsigned) {
--bitLength;
}
const lowerBound = typeOpts.unsigned ? 0 : -Math.pow(2, bitLength);
const upperBound = Math.pow(2, bitLength) - 1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const moduloVal = typeOpts.moduloBitLength ? Math.pow(2, typeOpts.moduloBitLength) : Math.pow(2, bitLength);
const moduloBound = typeOpts.moduloBitLength ? Math.pow(2, typeOpts.moduloBitLength - 1) : Math.pow(2, bitLength - 1);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return function(V, opts) {
if (!opts) opts = {};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let x = +V;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (opts.enforceRange) {
if (!Number.isFinite(x)) {
throw new TypeError("Argument is not a finite number");
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
x = sign(x) * Math.floor(Math.abs(x));
if (x < lowerBound || x > upperBound) {
throw new TypeError("Argument is not in byte range");
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return x;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!isNaN(x) && opts.clamp) {
x = evenRound(x);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (x < lowerBound) x = lowerBound;
if (x > upperBound) x = upperBound;
return x;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!Number.isFinite(x) || x === 0) {
return 0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
conversions["boolean"] = function (val) {
return !!val;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
conversions["byte"] = createNumberConversion(8, { unsigned: false });
conversions["octet"] = createNumberConversion(8, { unsigned: true });
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
conversions["short"] = createNumberConversion(16, { unsigned: false });
conversions["unsigned short"] = createNumberConversion(16, { unsigned: true });
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
conversions["long"] = createNumberConversion(32, { unsigned: false });
conversions["unsigned long"] = createNumberConversion(32, { unsigned: true });
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
conversions["long long"] = createNumberConversion(32, { unsigned: false, moduloBitLength: 64 });
conversions["unsigned long long"] = createNumberConversion(32, { unsigned: true, moduloBitLength: 64 });
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
conversions["double"] = function (V) {
const x = +V;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!Number.isFinite(x)) {
throw new TypeError("Argument is not a finite floating-point value");
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return x;
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
conversions["unrestricted double"] = function (V) {
const x = +V;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (isNaN(x)) {
throw new TypeError("Argument is NaN");
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return x;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// not quite valid, but good enough for JS
conversions["float"] = conversions["double"];
conversions["unrestricted float"] = conversions["unrestricted double"];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
conversions["DOMString"] = function (V, opts) {
if (!opts) opts = {};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (opts.treatNullAsEmptyString && V === null) {
return "";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return String(V);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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");
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return x;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
conversions["USVString"] = function (V) {
const S = String(V);
const n = S.length;
const U = [];
for (let i = 0; i < n; ++i) {
const c = S.charCodeAt(i);
if (c < 0xD800 || c > 0xDFFF) {
U.push(String.fromCodePoint(c));
} else if (0xDC00 <= c && c <= 0xDFFF) {
U.push(String.fromCodePoint(0xFFFD));
} else {
if (i === n - 1) {
U.push(String.fromCodePoint(0xFFFD));
} else {
const d = S.charCodeAt(i + 1);
if (0xDC00 <= d && d <= 0xDFFF) {
const a = c & 0x3FF;
const b = d & 0x3FF;
U.push(String.fromCodePoint((2 << 15) + (2 << 9) * a + b));
++i;
} else {
U.push(String.fromCodePoint(0xFFFD));
}
}
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return U.join('');
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
conversions["Date"] = function (V, opts) {
if (!(V instanceof Date)) {
throw new TypeError("Argument is not a Date object");
}
if (isNaN(V)) {
return undefined;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return V;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
conversions["RegExp"] = function (V, opts) {
if (!(V instanceof RegExp)) {
V = new RegExp(V);
}
return V;
2021-09-26 15:31:45 -04:00
};
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 8262:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const usm = __nccwpck_require__(33);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
exports.implementation = class URLImpl {
constructor(constructorArgs) {
const url = constructorArgs[0];
const base = constructorArgs[1];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let parsedBase = null;
if (base !== undefined) {
parsedBase = usm.basicURLParse(base);
if (parsedBase === "failure") {
throw new TypeError("Invalid base URL");
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const parsedURL = usm.basicURLParse(url, { baseURL: parsedBase });
if (parsedURL === "failure") {
throw new TypeError("Invalid URL");
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this._url = parsedURL;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// TODO: query stuff
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get href() {
return usm.serializeURL(this._url);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
set href(v) {
const parsedURL = usm.basicURLParse(v);
if (parsedURL === "failure") {
throw new TypeError("Invalid URL");
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this._url = parsedURL;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
get origin() {
return usm.serializeURLOrigin(this._url);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
get protocol() {
return this._url.scheme + ":";
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
set protocol(v) {
usm.basicURLParse(v + ":", { url: this._url, stateOverride: "scheme start" });
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get username() {
return this._url.username;
}
set username(v) {
if (usm.cannotHaveAUsernamePasswordPort(this._url)) {
return;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
usm.setTheUsername(this._url, v);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
get password() {
return this._url.password;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
set password(v) {
if (usm.cannotHaveAUsernamePasswordPort(this._url)) {
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
usm.setThePassword(this._url, v);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get host() {
const url = this._url;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (url.host === null) {
return "";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (url.port === null) {
return usm.serializeHost(url.host);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return usm.serializeHost(url.host) + ":" + usm.serializeInteger(url.port);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
set host(v) {
if (this._url.cannotBeABaseURL) {
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
usm.basicURLParse(v, { url: this._url, stateOverride: "host" });
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get hostname() {
if (this._url.host === null) {
return "";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return usm.serializeHost(this._url.host);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
set hostname(v) {
if (this._url.cannotBeABaseURL) {
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
usm.basicURLParse(v, { url: this._url, stateOverride: "hostname" });
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get port() {
if (this._url.port === null) {
return "";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return usm.serializeInteger(this._url.port);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
set port(v) {
if (usm.cannotHaveAUsernamePasswordPort(this._url)) {
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (v === "") {
this._url.port = null;
} else {
usm.basicURLParse(v, { url: this._url, stateOverride: "port" });
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get pathname() {
if (this._url.cannotBeABaseURL) {
return this._url.path[0];
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (this._url.path.length === 0) {
return "";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return "/" + this._url.path.join("/");
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
set pathname(v) {
if (this._url.cannotBeABaseURL) {
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this._url.path = [];
usm.basicURLParse(v, { url: this._url, stateOverride: "path start" });
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get search() {
if (this._url.query === null || this._url.query === "") {
return "";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return "?" + this._url.query;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
set search(v) {
// TODO: query stuff
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const url = this._url;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (v === "") {
url.query = null;
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const input = v[0] === "?" ? v.substring(1) : v;
url.query = "";
usm.basicURLParse(input, { url, stateOverride: "query" });
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get hash() {
if (this._url.fragment === null || this._url.fragment === "") {
return "";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return "#" + this._url.fragment;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
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" });
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
toJSON() {
return this.href;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 653:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const conversions = __nccwpck_require__(5871);
const utils = __nccwpck_require__(276);
const Impl = __nccwpck_require__(8262);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const impl = utils.implSymbol;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function URL(url) {
if (!this || this[impl] || !(this instanceof URL)) {
throw new TypeError("Failed to construct 'URL': Please use the 'new' operator, this DOM object constructor cannot be called as a function.");
}
if (arguments.length < 1) {
throw new TypeError("Failed to construct 'URL': 1 argument required, but only " + arguments.length + " present.");
}
const args = [];
for (let i = 0; i < arguments.length && i < 2; ++i) {
args[i] = arguments[i];
}
args[0] = conversions["USVString"](args[0]);
if (args[1] !== undefined) {
args[1] = conversions["USVString"](args[1]);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.setup(this, args);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
URL.prototype.toJSON = function toJSON() {
if (!this || !module.exports.is(this)) {
throw new TypeError("Illegal invocation");
}
const args = [];
for (let i = 0; i < arguments.length && i < 0; ++i) {
args[i] = arguments[i];
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return this[impl].toJSON.apply(this[impl], args);
};
Object.defineProperty(URL.prototype, "href", {
get() {
return this[impl].href;
},
set(V) {
V = conversions["USVString"](V);
this[impl].href = V;
},
enumerable: true,
configurable: true
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
URL.prototype.toString = function () {
if (!this || !module.exports.is(this)) {
throw new TypeError("Illegal invocation");
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return this.href;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(URL.prototype, "origin", {
get() {
return this[impl].origin;
},
enumerable: true,
configurable: true
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(URL.prototype, "protocol", {
get() {
return this[impl].protocol;
},
set(V) {
V = conversions["USVString"](V);
this[impl].protocol = V;
},
enumerable: true,
configurable: true
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(URL.prototype, "username", {
get() {
return this[impl].username;
},
set(V) {
V = conversions["USVString"](V);
this[impl].username = V;
},
enumerable: true,
configurable: true
});
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 }
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
};
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 3323:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
"use strict";
2022-05-31 14:18:28 -04:00
exports.URL = __nccwpck_require__(653)["interface"];
exports.serializeURL = __nccwpck_require__(33).serializeURL;
exports.serializeURLOrigin = __nccwpck_require__(33).serializeURLOrigin;
exports.basicURLParse = __nccwpck_require__(33).basicURLParse;
exports.setTheUsername = __nccwpck_require__(33).setTheUsername;
exports.setThePassword = __nccwpck_require__(33).setThePassword;
exports.serializeHost = __nccwpck_require__(33).serializeHost;
exports.serializeInteger = __nccwpck_require__(33).serializeInteger;
exports.parseURL = __nccwpck_require__(33).parseURL;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 33:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const punycode = __nccwpck_require__(5477);
const tr46 = __nccwpck_require__(2299);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const specialSchemes = {
ftp: 21,
file: null,
gopher: 70,
http: 80,
https: 443,
ws: 80,
wss: 443
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const failure = Symbol("failure");
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function countSymbols(str) {
return punycode.ucs2.decode(str).length;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function at(input, idx) {
const c = input[idx];
return isNaN(c) ? undefined : String.fromCodePoint(c);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isASCIIDigit(c) {
return c >= 0x30 && c <= 0x39;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isASCIIAlpha(c) {
return (c >= 0x41 && c <= 0x5A) || (c >= 0x61 && c <= 0x7A);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isASCIIAlphanumeric(c) {
return isASCIIAlpha(c) || isASCIIDigit(c);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isASCIIHex(c) {
return isASCIIDigit(c) || (c >= 0x41 && c <= 0x46) || (c >= 0x61 && c <= 0x66);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isSingleDot(buffer) {
return buffer === "." || buffer.toLowerCase() === "%2e";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isDoubleDot(buffer) {
buffer = buffer.toLowerCase();
return buffer === ".." || buffer === "%2e." || buffer === ".%2e" || buffer === "%2e%2e";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isWindowsDriveLetterCodePoints(cp1, cp2) {
return isASCIIAlpha(cp1) && (cp2 === 58 || cp2 === 124);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isWindowsDriveLetterString(string) {
return string.length === 2 && isASCIIAlpha(string.codePointAt(0)) && (string[1] === ":" || string[1] === "|");
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isNormalizedWindowsDriveLetterString(string) {
return string.length === 2 && isASCIIAlpha(string.codePointAt(0)) && string[1] === ":";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function containsForbiddenHostCodePoint(string) {
return string.search(/\u0000|\u0009|\u000A|\u000D|\u0020|#|%|\/|:|\?|@|\[|\\|\]/) !== -1;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function containsForbiddenHostCodePointExcludingPercent(string) {
return string.search(/\u0000|\u0009|\u000A|\u000D|\u0020|#|\/|:|\?|@|\[|\\|\]/) !== -1;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isSpecialScheme(scheme) {
return specialSchemes[scheme] !== undefined;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isSpecial(url) {
return isSpecialScheme(url.scheme);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function defaultPort(scheme) {
return specialSchemes[scheme];
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function percentEncode(c) {
let hex = c.toString(16).toUpperCase();
if (hex.length === 1) {
hex = "0" + hex;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return "%" + hex;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function utf8PercentEncode(c) {
const buf = Buffer.from(c);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let str = "";
for (let i = 0; i < buf.length; ++i) {
str += percentEncode(buf[i]);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return str;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function utf8PercentDecode(str) {
const input = Buffer.from(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]);
2021-09-26 15:31:45 -04:00
}
}
2022-05-31 14:18:28 -04:00
return Buffer.from(output).toString();
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isC0ControlPercentEncode(c) {
return c <= 0x1F || c > 0x7E;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const extraPathPercentEncodeSet = new Set([32, 34, 35, 60, 62, 63, 96, 123, 125]);
function isPathPercentEncode(c) {
return isC0ControlPercentEncode(c) || extraPathPercentEncodeSet.has(c);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const extraUserinfoPercentEncodeSet =
new Set([47, 58, 59, 61, 64, 91, 92, 93, 94, 124]);
function isUserinfoPercentEncode(c) {
return isPathPercentEncode(c) || extraUserinfoPercentEncodeSet.has(c);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function percentEncodeChar(c, encodeSetPredicate) {
const cStr = String.fromCodePoint(c);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (encodeSetPredicate(c)) {
return utf8PercentEncode(cStr);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return cStr;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function parseIPv4Number(input) {
let R = 10;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (input === "") {
return 0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const regex = R === 10 ? /[^0-9]/ : (R === 16 ? /[^0-9A-Fa-f]/ : /[^0-7]/);
if (regex.test(input)) {
return failure;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return parseInt(input, R);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function parseIPv4(input) {
const parts = input.split(".");
if (parts[parts.length - 1] === "") {
if (parts.length > 1) {
parts.pop();
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (parts.length > 4) {
return input;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const numbers = [];
for (const part of parts) {
if (part === "") {
return input;
}
const n = parseIPv4Number(part);
if (n === failure) {
return input;
}
numbers.push(n);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let ipv4 = numbers.pop();
let counter = 0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (const n of numbers) {
ipv4 += n * Math.pow(256, 3 - counter);
++counter;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return ipv4;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function serializeIPv4(address) {
let output = "";
let n = address;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (let i = 1; i <= 4; ++i) {
output = String(n % 256) + output;
if (i !== 4) {
output = "." + output;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
n = Math.floor(n / 256);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return output;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function parseIPv6(input) {
const address = [0, 0, 0, 0, 0, 0, 0, 0];
let pieceIndex = 0;
let compress = null;
let pointer = 0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
input = punycode.ucs2.decode(input);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (input[pointer] === 58) {
if (input[pointer + 1] !== 58) {
return failure;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
pointer += 2;
++pieceIndex;
compress = pieceIndex;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (pointer < input.length) {
if (pieceIndex === 8) {
return failure;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (input[pointer] === 58) {
if (compress !== null) {
return failure;
}
++pointer;
++pieceIndex;
compress = pieceIndex;
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let value = 0;
let length = 0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (length < 4 && isASCIIHex(input[pointer])) {
value = value * 0x10 + parseInt(at(input, pointer), 16);
++pointer;
++length;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (input[pointer] === 46) {
if (length === 0) {
return failure;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
pointer -= length;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (pieceIndex > 6) {
return failure;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let numbersSeen = 0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (input[pointer] !== undefined) {
let ipv4Piece = null;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (numbersSeen > 0) {
if (input[pointer] === 46 && numbersSeen < 4) {
++pointer;
} else {
return failure;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!isASCIIDigit(input[pointer])) {
return failure;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
address[pieceIndex] = address[pieceIndex] * 0x100 + ipv4Piece;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
++numbersSeen;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (numbersSeen === 2 || numbersSeen === 4) {
++pieceIndex;
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (numbersSeen !== 4) {
return failure;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
break;
} else if (input[pointer] === 58) {
++pointer;
if (input[pointer] === undefined) {
return failure;
}
} else if (input[pointer] !== undefined) {
return failure;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
address[pieceIndex] = value;
++pieceIndex;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
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;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return address;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function serializeIPv6(address) {
let output = "";
const seqResult = findLongestZeroSequence(address);
const compress = seqResult.idx;
let ignore0 = false;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
for (let pieceIndex = 0; pieceIndex <= 7; ++pieceIndex) {
if (ignore0 && address[pieceIndex] === 0) {
continue;
} else if (ignore0) {
ignore0 = false;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (compress === pieceIndex) {
const separator = pieceIndex === 0 ? "::" : ":";
output += separator;
ignore0 = true;
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
output += address[pieceIndex].toString(16);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (pieceIndex !== 7) {
output += ":";
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return output;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function parseHost(input, isSpecialArg) {
if (input[0] === "[") {
if (input[input.length - 1] !== "]") {
return failure;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return parseIPv6(input.substring(1, input.length - 1));
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!isSpecialArg) {
return parseOpaqueHost(input);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const domain = utf8PercentDecode(input);
const asciiDomain = tr46.toASCII(domain, false, tr46.PROCESSING_OPTIONS.NONTRANSITIONAL, false);
if (asciiDomain === null) {
return failure;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (containsForbiddenHostCodePoint(asciiDomain)) {
return failure;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const ipv4Host = parseIPv4(asciiDomain);
if (typeof ipv4Host === "number" || ipv4Host === failure) {
return ipv4Host;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return asciiDomain;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function parseOpaqueHost(input) {
if (containsForbiddenHostCodePointExcludingPercent(input)) {
return failure;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// if trailing zeros
if (currLen > maxLen) {
maxIdx = currStart;
maxLen = currLen;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return {
idx: maxIdx,
len: maxLen
};
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function serializeHost(host) {
if (typeof host === "number") {
return serializeIPv4(host);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// IPv6 serializer
if (host instanceof Array) {
return "[" + serializeIPv6(host) + "]";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return host;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function trimControlChars(url) {
return url.replace(/^[\u0000-\u001F\u0020]+|[\u0000-\u001F\u0020]+$/g, "");
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function trimTabAndNewline(url) {
return url.replace(/\u0009|\u000A|\u000D/g, "");
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function shortenPath(url) {
const path = url.path;
if (path.length === 0) {
return;
}
if (url.scheme === "file" && path.length === 1 && isNormalizedWindowsDriveLetter(path[0])) {
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
path.pop();
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function includesCredentials(url) {
return url.username !== "" || url.password !== "";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function cannotHaveAUsernamePasswordPort(url) {
return url.host === null || url.host === "" || url.cannotBeABaseURL || url.scheme === "file";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function isNormalizedWindowsDriveLetter(string) {
return /^[A-Za-z]:$/.test(string);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (!this.url) {
this.url = {
scheme: "",
username: "",
password: "",
host: null,
port: null,
path: [],
query: null,
fragment: null,
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
cannotBeABaseURL: false
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const res = trimControlChars(this.input);
if (res !== this.input) {
this.parseError = true;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
this.input = res;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const res = trimTabAndNewline(this.input);
if (res !== this.input) {
this.parseError = true;
}
this.input = res;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.state = stateOverride || "scheme start";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.buffer = "";
this.atFlag = false;
this.arrFlag = false;
this.passwordTokenSeenFlag = false;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.input = punycode.ucs2.decode(this.input);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (; this.pointer <= this.input.length; ++this.pointer) {
const c = this.input[this.pointer];
const cStr = isNaN(c) ? undefined : String.fromCodePoint(c);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// exec state machine
const ret = this["parse " + this.state](c, cStr);
if (!ret) {
break; // terminate algorithm
} else if (ret === failure) {
this.failure = true;
break;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!isSpecial(this.url) && isSpecialScheme(this.buffer)) {
return false;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if ((includesCredentials(this.url) || this.url.port !== null) && this.buffer === "file") {
return false;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (this.url.scheme === "file" && (this.url.host === "" || this.url.host === null)) {
return false;
}
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
this.url.scheme = this.buffer;
this.buffer = "";
if (this.stateOverride) {
return false;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
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";
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else if (!this.stateOverride) {
this.buffer = "";
this.state = "no scheme";
this.pointer = -1;
} else {
this.parseError = true;
return failure;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
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;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
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;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
URLStateMachine.prototype["parse path or authority"] = function parsePathOrAuthority(c) {
if (c === 47) {
this.state = "authority";
} else {
this.state = "path";
--this.pointer;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
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);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
this.state = "path";
--this.pointer;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
URLStateMachine.prototype["parse relative slash"] = function parseRelativeSlash(c) {
if (isSpecial(this.url) && (c === 47 || c === 92)) {
if (c === 92) {
this.parseError = true;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
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;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
URLStateMachine.prototype["parse special authority ignore slashes"] = function parseSpecialAuthorityIgnoreSlashes(c) {
if (c !== 47 && c !== 92) {
this.state = "authority";
--this.pointer;
} else {
this.parseError = true;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
};
URLStateMachine.prototype["parse authority"] = function parseAuthority(c, cStr) {
if (c === 64) {
this.parseError = true;
if (this.atFlag) {
this.buffer = "%40" + this.buffer;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
this.atFlag = true;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// 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;
}
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const host = parseHost(this.buffer, isSpecial(this.url));
if (host === failure) {
return failure;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const host = parseHost(this.buffer, isSpecial(this.url));
if (host === failure) {
return failure;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
this.buffer += cStr;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
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 = "";
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (this.stateOverride) {
return false;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
this.state = "path start";
--this.pointer;
} else {
this.parseError = true;
return failure;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const fileOtherwiseCodePoints = new Set([47, 92, 63, 35]);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
URLStateMachine.prototype["parse file"] = function parseFile(c) {
this.url.scheme = "file";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (c === 47 || c === 92) {
if (c === 92) {
this.parseError = true;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
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;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
this.state = "path";
--this.pointer;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
this.state = "path";
--this.pointer;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
URLStateMachine.prototype["parse file slash"] = function parseFileSlash(c) {
if (c === 47 || c === 92) {
if (c === 92) {
this.parseError = true;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (this.stateOverride) {
return false;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.buffer = "";
this.state = "path start";
}
} else {
this.buffer += cStr;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
URLStateMachine.prototype["parse path start"] = function parsePathStart(c) {
if (isSpecial(this.url)) {
if (c === 92) {
this.parseError = true;
}
this.state = "path";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
}
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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.
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (c === 37 &&
(!isASCIIHex(this.input[this.pointer + 1]) ||
!isASCIIHex(this.input[this.pointer + 2]))) {
this.parseError = true;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.buffer += percentEncodeChar(c, isPathPercentEncode);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (c === 37 &&
(!isASCIIHex(this.input[this.pointer + 1]) ||
!isASCIIHex(this.input[this.pointer + 2]))) {
this.parseError = true;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!isNaN(c)) {
this.url.path[0] = this.url.path[0] + percentEncodeChar(c, isC0ControlPercentEncode);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const buffer = Buffer.from(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]);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.buffer += cStr;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
2021-12-11 08:00:14 -05:00
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.url.fragment += percentEncodeChar(c, isC0ControlPercentEncode);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return true;
2021-12-11 08:00:14 -05:00
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function serializeURL(url, excludeFragment) {
let output = url.scheme + ":";
if (url.host !== null) {
output += "//";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (url.username !== "" || url.password !== "") {
output += url.username;
if (url.password !== "") {
output += ":" + url.password;
}
output += "@";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
output += serializeHost(url.host);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (url.port !== null) {
output += ":" + url.port;
}
} else if (url.host === null && url.scheme === "file") {
output += "//";
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (url.cannotBeABaseURL) {
output += url.path[0];
} else {
for (const string of url.path) {
output += "/" + string;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (url.query !== null) {
output += "?" + url.query;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!excludeFragment && url.fragment !== null) {
output += "#" + url.fragment;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return output;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function serializeOrigin(tuple) {
let result = tuple.scheme + "://";
result += serializeHost(tuple.host);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (tuple.port !== null) {
result += ":" + tuple.port;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.serializeURL = serializeURL;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.serializeURLOrigin = function (url) {
// https://url.spec.whatwg.org/#concept-url-origin
switch (url.scheme) {
case "blob":
try {
return module.exports.serializeURLOrigin(module.exports.parseURL(url.path[0]));
} catch (e) {
// serializing an opaque origin returns "null"
return "null";
}
case "ftp":
case "gopher":
case "http":
case "https":
case "ws":
case "wss":
return serializeOrigin({
scheme: url.scheme,
host: url.host,
port: url.port
});
case "file":
// spec says "exercise to the reader", chrome says "file://"
return "file://";
default:
// serializing an opaque origin returns "null"
return "null";
}
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.basicURLParse = function (input, options) {
if (options === undefined) {
options = {};
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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);
2021-12-11 08:00:14 -05:00
}
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
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);
}
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.serializeHost = serializeHost;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.cannotHaveAUsernamePasswordPort = cannotHaveAUsernamePasswordPort;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.serializeInteger = function (integer) {
return String(integer);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.parseURL = function (input, options) {
if (options === undefined) {
options = {};
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// We don't handle blobs, so this just delegates:
return module.exports.basicURLParse(input, { baseURL: options.baseURL, encodingOverride: options.encodingOverride });
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 276:
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.mixin = function mixin(target, source) {
const keys = Object.getOwnPropertyNames(source);
for (let i = 0; i < keys.length; ++i) {
Object.defineProperty(target, keys[i], Object.getOwnPropertyDescriptor(source, keys[i]));
2021-12-11 08:00:14 -05:00
}
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.wrapperSymbol = Symbol("wrapper");
module.exports.implSymbol = Symbol("impl");
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.wrapperForImpl = function (impl) {
return impl[module.exports.wrapperSymbol];
2021-12-11 08:00:14 -05:00
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports.implForWrapper = function (wrapper) {
return wrapper[module.exports.implSymbol];
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 8119:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* @license node-stream-zip | (c) 2020 Antelle | https://github.com/antelle/node-stream-zip/blob/master/LICENSE
* Portions copyright https://github.com/cthackers/adm-zip | https://raw.githubusercontent.com/cthackers/adm-zip/master/LICENSE
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let fs = __nccwpck_require__(7147);
const util = __nccwpck_require__(3837);
const path = __nccwpck_require__(1017);
const events = __nccwpck_require__(2361);
const zlib = __nccwpck_require__(9796);
const stream = __nccwpck_require__(2781);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const consts = {
/* The local file header */
LOCHDR: 30, // LOC header size
LOCSIG: 0x04034b50, // "PK\003\004"
LOCVER: 4, // version needed to extract
LOCFLG: 6, // general purpose bit flag
LOCHOW: 8, // compression method
LOCTIM: 10, // modification time (2 bytes time, 2 bytes date)
LOCCRC: 14, // uncompressed file crc-32 value
LOCSIZ: 18, // compressed size
LOCLEN: 22, // uncompressed size
LOCNAM: 26, // filename length
LOCEXT: 28, // extra field length
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/* The Data descriptor */
EXTSIG: 0x08074b50, // "PK\007\008"
EXTHDR: 16, // EXT header size
EXTCRC: 4, // uncompressed file crc-32 value
EXTSIZ: 8, // compressed size
EXTLEN: 12, // uncompressed size
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/* The central directory file header */
CENHDR: 46, // CEN header size
CENSIG: 0x02014b50, // "PK\001\002"
CENVEM: 4, // version made by
CENVER: 6, // version needed to extract
CENFLG: 8, // encrypt, decrypt flags
CENHOW: 10, // compression method
CENTIM: 12, // modification time (2 bytes time, 2 bytes date)
CENCRC: 16, // uncompressed file crc-32 value
CENSIZ: 20, // compressed size
CENLEN: 24, // uncompressed size
CENNAM: 28, // filename length
CENEXT: 30, // extra field length
CENCOM: 32, // file comment length
CENDSK: 34, // volume number start
CENATT: 36, // internal file attributes
CENATX: 38, // external file attributes (host system dependent)
CENOFF: 42, // LOC header offset
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/* The entries in the end of central directory */
ENDHDR: 22, // END header size
ENDSIG: 0x06054b50, // "PK\005\006"
ENDSIGFIRST: 0x50,
ENDSUB: 8, // number of entries on this disk
ENDTOT: 10, // total number of entries
ENDSIZ: 12, // central directory size in bytes
ENDOFF: 16, // offset of first CEN header
ENDCOM: 20, // zip file comment length
MAXFILECOMMENT: 0xffff,
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/* The entries in the end of ZIP64 central directory locator */
ENDL64HDR: 20, // ZIP64 end of central directory locator header size
ENDL64SIG: 0x07064b50, // ZIP64 end of central directory locator signature
ENDL64SIGFIRST: 0x50,
ENDL64OFS: 8, // ZIP64 end of central directory offset
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/* The entries in the end of ZIP64 central directory */
END64HDR: 56, // ZIP64 end of central directory header size
END64SIG: 0x06064b50, // ZIP64 end of central directory signature
END64SIGFIRST: 0x50,
END64SUB: 24, // number of entries on this disk
END64TOT: 32, // total number of entries
END64SIZ: 40,
END64OFF: 48,
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/* Compression methods */
STORED: 0, // no compression
SHRUNK: 1, // shrunk
REDUCED1: 2, // reduced with compression factor 1
REDUCED2: 3, // reduced with compression factor 2
REDUCED3: 4, // reduced with compression factor 3
REDUCED4: 5, // reduced with compression factor 4
IMPLODED: 6, // imploded
// 7 reserved
DEFLATED: 8, // deflated
ENHANCED_DEFLATED: 9, // deflate64
PKWARE: 10, // PKWare DCL imploded
// 11 reserved
BZIP2: 12, // compressed using BZIP2
// 13 reserved
LZMA: 14, // LZMA
// 15-17 reserved
IBM_TERSE: 18, // compressed using IBM TERSE
IBM_LZ77: 19, //IBM LZ77 z
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/* General purpose bit flag */
FLG_ENC: 0, // encrypted file
FLG_COMP1: 1, // compression option
FLG_COMP2: 2, // compression option
FLG_DESC: 4, // data descriptor
FLG_ENH: 8, // enhanced deflation
FLG_STR: 16, // strong encryption
FLG_LNG: 1024, // language encoding
FLG_MSK: 4096, // mask header values
FLG_ENTRY_ENC: 1,
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/* 4.5 Extensible data fields */
EF_ID: 0,
EF_SIZE: 2,
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/* Header IDs */
ID_ZIP64: 0x0001,
ID_AVINFO: 0x0007,
ID_PFS: 0x0008,
ID_OS2: 0x0009,
ID_NTFS: 0x000a,
ID_OPENVMS: 0x000c,
ID_UNIX: 0x000d,
ID_FORK: 0x000e,
ID_PATCH: 0x000f,
ID_X509_PKCS7: 0x0014,
ID_X509_CERTID_F: 0x0015,
ID_X509_CERTID_C: 0x0016,
ID_STRONGENC: 0x0017,
ID_RECORD_MGT: 0x0018,
ID_X509_PKCS7_RL: 0x0019,
ID_IBM1: 0x0065,
ID_IBM2: 0x0066,
ID_POSZIP: 0x4690,
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
EF_ZIP64_OR_32: 0xffffffff,
EF_ZIP64_OR_16: 0xffff,
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const StreamZip = function (config) {
let fd, fileSize, chunkSize, op, centralDirectory, closed;
const ready = false,
that = this,
entries = config.storeEntries !== false ? {} : null,
fileName = config.file,
textDecoder = config.nameEncoding ? new TextDecoder(config.nameEncoding) : null;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
open();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function open() {
if (config.fd) {
fd = config.fd;
readFile();
} else {
fs.open(fileName, 'r', (err, f) => {
if (err) {
return that.emit('error', err);
}
fd = f;
readFile();
});
}
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function readFile() {
fs.fstat(fd, (err, stat) => {
if (err) {
return that.emit('error', err);
}
fileSize = stat.size;
chunkSize = config.chunkSize || Math.round(fileSize / 1000);
chunkSize = Math.max(
Math.min(chunkSize, Math.min(128 * 1024, fileSize)),
Math.min(1024, fileSize)
);
readCentralDirectory();
});
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function readUntilFoundCallback(err, bytesRead) {
if (err || !bytesRead) {
return that.emit('error', err || new Error('Archive read error'));
}
let pos = op.lastPos;
let bufferPosition = pos - op.win.position;
const buffer = op.win.buffer;
const minPos = op.minPos;
while (--pos >= minPos && --bufferPosition >= 0) {
if (buffer.length - bufferPosition >= 4 && buffer[bufferPosition] === op.firstByte) {
// quick check first signature byte
if (buffer.readUInt32LE(bufferPosition) === op.sig) {
op.lastBufferPosition = bufferPosition;
op.lastBytesRead = bytesRead;
op.complete();
return;
}
}
}
if (pos === minPos) {
return that.emit('error', new Error('Bad archive'));
}
op.lastPos = pos + 1;
op.chunkSize *= 2;
if (pos <= minPos) {
return that.emit('error', new Error('Bad archive'));
}
const expandLength = Math.min(op.chunkSize, pos - minPos);
op.win.expandLeft(expandLength, readUntilFoundCallback);
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function readCentralDirectory() {
const totalReadLength = Math.min(consts.ENDHDR + consts.MAXFILECOMMENT, fileSize);
op = {
win: new FileWindowBuffer(fd),
totalReadLength,
minPos: fileSize - totalReadLength,
lastPos: fileSize,
chunkSize: Math.min(1024, chunkSize),
firstByte: consts.ENDSIGFIRST,
sig: consts.ENDSIG,
complete: readCentralDirectoryComplete,
};
op.win.read(fileSize - op.chunkSize, op.chunkSize, readUntilFoundCallback);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function readCentralDirectoryComplete() {
const buffer = op.win.buffer;
const pos = op.lastBufferPosition;
try {
centralDirectory = new CentralDirectoryHeader();
centralDirectory.read(buffer.slice(pos, pos + consts.ENDHDR));
centralDirectory.headerOffset = op.win.position + pos;
if (centralDirectory.commentLength) {
that.comment = buffer
.slice(
pos + consts.ENDHDR,
pos + consts.ENDHDR + centralDirectory.commentLength
)
.toString();
} else {
that.comment = null;
}
that.entriesCount = centralDirectory.volumeEntries;
that.centralDirectory = centralDirectory;
if (
(centralDirectory.volumeEntries === consts.EF_ZIP64_OR_16 &&
centralDirectory.totalEntries === consts.EF_ZIP64_OR_16) ||
centralDirectory.size === consts.EF_ZIP64_OR_32 ||
centralDirectory.offset === consts.EF_ZIP64_OR_32
) {
readZip64CentralDirectoryLocator();
} else {
op = {};
readEntries();
}
} catch (err) {
that.emit('error', err);
}
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function readZip64CentralDirectoryLocator() {
const length = consts.ENDL64HDR;
if (op.lastBufferPosition > length) {
op.lastBufferPosition -= length;
readZip64CentralDirectoryLocatorComplete();
} else {
op = {
win: op.win,
totalReadLength: length,
minPos: op.win.position - length,
lastPos: op.win.position,
chunkSize: op.chunkSize,
firstByte: consts.ENDL64SIGFIRST,
sig: consts.ENDL64SIG,
complete: readZip64CentralDirectoryLocatorComplete,
};
op.win.read(op.lastPos - op.chunkSize, op.chunkSize, readUntilFoundCallback);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function readZip64CentralDirectoryLocatorComplete() {
const buffer = op.win.buffer;
const locHeader = new CentralDirectoryLoc64Header();
locHeader.read(
buffer.slice(op.lastBufferPosition, op.lastBufferPosition + consts.ENDL64HDR)
);
const readLength = fileSize - locHeader.headerOffset;
op = {
win: op.win,
totalReadLength: readLength,
minPos: locHeader.headerOffset,
lastPos: op.lastPos,
chunkSize: op.chunkSize,
firstByte: consts.END64SIGFIRST,
sig: consts.END64SIG,
complete: readZip64CentralDirectoryComplete,
};
op.win.read(fileSize - op.chunkSize, op.chunkSize, readUntilFoundCallback);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function readZip64CentralDirectoryComplete() {
const buffer = op.win.buffer;
const zip64cd = new CentralDirectoryZip64Header();
zip64cd.read(buffer.slice(op.lastBufferPosition, op.lastBufferPosition + consts.END64HDR));
that.centralDirectory.volumeEntries = zip64cd.volumeEntries;
that.centralDirectory.totalEntries = zip64cd.totalEntries;
that.centralDirectory.size = zip64cd.size;
that.centralDirectory.offset = zip64cd.offset;
that.entriesCount = zip64cd.volumeEntries;
op = {};
readEntries();
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function readEntries() {
op = {
win: new FileWindowBuffer(fd),
pos: centralDirectory.offset,
chunkSize,
entriesLeft: centralDirectory.volumeEntries,
};
op.win.read(op.pos, Math.min(chunkSize, fileSize - op.pos), readEntriesCallback);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function readEntriesCallback(err, bytesRead) {
if (err || !bytesRead) {
return that.emit('error', err || new Error('Entries read error'));
}
let bufferPos = op.pos - op.win.position;
let entry = op.entry;
const buffer = op.win.buffer;
const bufferLength = buffer.length;
try {
while (op.entriesLeft > 0) {
if (!entry) {
entry = new ZipEntry();
entry.readHeader(buffer, bufferPos);
entry.headerOffset = op.win.position + bufferPos;
op.entry = entry;
op.pos += consts.CENHDR;
bufferPos += consts.CENHDR;
}
const entryHeaderSize = entry.fnameLen + entry.extraLen + entry.comLen;
const advanceBytes = entryHeaderSize + (op.entriesLeft > 1 ? consts.CENHDR : 0);
if (bufferLength - bufferPos < advanceBytes) {
op.win.moveRight(chunkSize, readEntriesCallback, bufferPos);
op.move = true;
return;
}
entry.read(buffer, bufferPos, textDecoder);
if (!config.skipEntryNameValidation) {
entry.validateName();
}
if (entries) {
entries[entry.name] = entry;
}
that.emit('entry', entry);
op.entry = entry = null;
op.entriesLeft--;
op.pos += entryHeaderSize;
bufferPos += entryHeaderSize;
}
that.emit('ready');
} catch (err) {
that.emit('error', err);
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function checkEntriesExist() {
if (!entries) {
throw new Error('storeEntries disabled');
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(this, 'ready', {
get() {
return ready;
},
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.entry = function (name) {
checkEntriesExist();
return entries[name];
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.entries = function () {
checkEntriesExist();
return entries;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
this.stream = function (entry, callback) {
return this.openEntry(
entry,
(err, entry) => {
if (err) {
return callback(err);
}
const offset = dataOffset(entry);
let entryStream = new EntryDataReaderStream(fd, offset, entry.compressedSize);
if (entry.method === consts.STORED) {
// nothing to do
} else if (entry.method === consts.DEFLATED) {
entryStream = entryStream.pipe(zlib.createInflateRaw());
} else {
return callback(new Error('Unknown compression method: ' + entry.method));
}
if (canVerifyCrc(entry)) {
entryStream = entryStream.pipe(
new EntryVerifyStream(entryStream, entry.crc, entry.size)
);
}
callback(null, entryStream);
},
false
);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.entryDataSync = function (entry) {
let err = null;
this.openEntry(
entry,
(e, en) => {
err = e;
entry = en;
},
true
);
if (err) {
throw err;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
let data = Buffer.alloc(entry.compressedSize);
new FsRead(fd, data, 0, entry.compressedSize, dataOffset(entry), (e) => {
err = e;
}).read(true);
if (err) {
throw err;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (entry.method === consts.STORED) {
// nothing to do
} else if (entry.method === consts.DEFLATED || entry.method === consts.ENHANCED_DEFLATED) {
data = zlib.inflateRawSync(data);
} else {
throw new Error('Unknown compression method: ' + entry.method);
}
if (data.length !== entry.size) {
throw new Error('Invalid size');
}
if (canVerifyCrc(entry)) {
const verify = new CrcVerify(entry.crc, entry.size);
verify.data(data);
}
return data;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.openEntry = function (entry, callback, sync) {
if (typeof entry === 'string') {
checkEntriesExist();
entry = entries[entry];
if (!entry) {
return callback(new Error('Entry not found'));
}
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (!entry.isFile) {
return callback(new Error('Entry is not file'));
}
if (!fd) {
return callback(new Error('Archive closed'));
}
const buffer = Buffer.alloc(consts.LOCHDR);
new FsRead(fd, buffer, 0, buffer.length, entry.offset, (err) => {
if (err) {
return callback(err);
}
let readEx;
try {
entry.readDataHeader(buffer);
if (entry.encrypted) {
readEx = new Error('Entry encrypted');
}
} catch (ex) {
readEx = ex;
}
callback(readEx, entry);
}).read(sync);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function dataOffset(entry) {
return entry.offset + consts.LOCHDR + entry.fnameLen + entry.extraLen;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function canVerifyCrc(entry) {
// if bit 3 (0x08) of the general-purpose flags field is set, then the CRC-32 and file sizes are not known when the header is written
return (entry.flags & 0x8) !== 0x8;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function extract(entry, outPath, callback) {
that.stream(entry, (err, stm) => {
if (err) {
callback(err);
} else {
let fsStm, errThrown;
stm.on('error', (err) => {
errThrown = err;
if (fsStm) {
stm.unpipe(fsStm);
fsStm.close(() => {
callback(err);
});
}
});
fs.open(outPath, 'w', (err, fdFile) => {
if (err) {
return callback(err);
}
if (errThrown) {
fs.close(fd, () => {
callback(errThrown);
});
return;
}
fsStm = fs.createWriteStream(outPath, { fd: fdFile });
fsStm.on('finish', () => {
that.emit('extract', entry, outPath);
if (!errThrown) {
callback();
}
});
stm.pipe(fsStm);
});
}
});
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function createDirectories(baseDir, dirs, callback) {
if (!dirs.length) {
return callback();
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
let dir = dirs.shift();
dir = path.join(baseDir, path.join(...dir));
fs.mkdir(dir, { recursive: true }, (err) => {
if (err && err.code !== 'EEXIST') {
return callback(err);
}
createDirectories(baseDir, dirs, callback);
});
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function extractFiles(baseDir, baseRelPath, files, callback, extractedCount) {
if (!files.length) {
return callback(null, extractedCount);
}
const file = files.shift();
const targetPath = path.join(baseDir, file.name.replace(baseRelPath, ''));
extract(file, targetPath, (err) => {
if (err) {
return callback(err, extractedCount);
}
extractFiles(baseDir, baseRelPath, files, callback, extractedCount + 1);
});
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
this.extract = function (entry, outPath, callback) {
let entryName = entry || '';
if (typeof entry === 'string') {
entry = this.entry(entry);
if (entry) {
entryName = entry.name;
} else {
if (entryName.length && entryName[entryName.length - 1] !== '/') {
entryName += '/';
}
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (!entry || entry.isDirectory) {
const files = [],
dirs = [],
allDirs = {};
for (const e in entries) {
if (
Object.prototype.hasOwnProperty.call(entries, e) &&
e.lastIndexOf(entryName, 0) === 0
) {
let relPath = e.replace(entryName, '');
const childEntry = entries[e];
if (childEntry.isFile) {
files.push(childEntry);
relPath = path.dirname(relPath);
}
if (relPath && !allDirs[relPath] && relPath !== '.') {
allDirs[relPath] = true;
let parts = relPath.split('/').filter((f) => {
return f;
});
if (parts.length) {
dirs.push(parts);
}
while (parts.length > 1) {
parts = parts.slice(0, parts.length - 1);
const partsPath = parts.join('/');
if (allDirs[partsPath] || partsPath === '.') {
break;
}
allDirs[partsPath] = true;
dirs.push(parts);
}
}
}
}
dirs.sort((x, y) => {
return x.length - y.length;
});
if (dirs.length) {
createDirectories(outPath, dirs, (err) => {
if (err) {
callback(err);
} else {
extractFiles(outPath, entryName, files, callback, 0);
}
});
} else {
extractFiles(outPath, entryName, files, callback, 0);
}
} else {
fs.stat(outPath, (err, stat) => {
if (stat && stat.isDirectory()) {
extract(entry, path.join(outPath, path.basename(entry.name)), callback);
} else {
extract(entry, outPath, callback);
}
});
}
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.close = function (callback) {
if (closed || !fd) {
closed = true;
if (callback) {
callback();
}
} else {
closed = true;
fs.close(fd, (err) => {
fd = null;
if (callback) {
callback(err);
}
});
}
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const originalEmit = events.EventEmitter.prototype.emit;
this.emit = function (...args) {
if (!closed) {
return originalEmit.call(this, ...args);
}
};
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
StreamZip.setFs = function (customFs) {
fs = customFs;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
StreamZip.debugLog = (...args) => {
if (StreamZip.debug) {
// eslint-disable-next-line no-console
console.log(...args);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
util.inherits(StreamZip, events.EventEmitter);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const propZip = Symbol('zip');
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
StreamZip.async = class StreamZipAsync extends events.EventEmitter {
constructor(config) {
super();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const zip = new StreamZip(config);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
zip.on('entry', (entry) => this.emit('entry', entry));
zip.on('extract', (entry, outPath) => this.emit('extract', entry, outPath));
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this[propZip] = new Promise((resolve, reject) => {
zip.on('ready', () => {
zip.removeListener('error', reject);
resolve(zip);
});
zip.on('error', reject);
});
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
get entriesCount() {
return this[propZip].then((zip) => zip.entriesCount);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
get comment() {
return this[propZip].then((zip) => zip.comment);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
async entry(name) {
const zip = await this[propZip];
return zip.entry(name);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
async entries() {
const zip = await this[propZip];
return zip.entries();
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
async stream(entry) {
const zip = await this[propZip];
return new Promise((resolve, reject) => {
zip.stream(entry, (err, stm) => {
if (err) {
reject(err);
} else {
resolve(stm);
}
});
});
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
async entryData(entry) {
const stm = await this.stream(entry);
return new Promise((resolve, reject) => {
const data = [];
stm.on('data', (chunk) => data.push(chunk));
stm.on('end', () => {
resolve(Buffer.concat(data));
});
stm.on('error', (err) => {
stm.removeAllListeners('end');
reject(err);
});
});
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
async extract(entry, outPath) {
const zip = await this[propZip];
return new Promise((resolve, reject) => {
zip.extract(entry, outPath, (err, res) => {
if (err) {
reject(err);
} else {
resolve(res);
}
});
});
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
async close() {
const zip = await this[propZip];
return new Promise((resolve, reject) => {
zip.close((err) => {
if (err) {
reject(err);
} else {
resolve();
}
});
});
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class CentralDirectoryHeader {
read(data) {
if (data.length !== consts.ENDHDR || data.readUInt32LE(0) !== consts.ENDSIG) {
throw new Error('Invalid central directory');
}
// number of entries on this volume
this.volumeEntries = data.readUInt16LE(consts.ENDSUB);
// total number of entries
this.totalEntries = data.readUInt16LE(consts.ENDTOT);
// central directory size in bytes
this.size = data.readUInt32LE(consts.ENDSIZ);
// offset of first CEN header
this.offset = data.readUInt32LE(consts.ENDOFF);
// zip file comment length
this.commentLength = data.readUInt16LE(consts.ENDCOM);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class CentralDirectoryLoc64Header {
read(data) {
if (data.length !== consts.ENDL64HDR || data.readUInt32LE(0) !== consts.ENDL64SIG) {
throw new Error('Invalid zip64 central directory locator');
}
// ZIP64 EOCD header offset
this.headerOffset = readUInt64LE(data, consts.ENDSUB);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class CentralDirectoryZip64Header {
read(data) {
if (data.length !== consts.END64HDR || data.readUInt32LE(0) !== consts.END64SIG) {
throw new Error('Invalid central directory');
}
// number of entries on this volume
this.volumeEntries = readUInt64LE(data, consts.END64SUB);
// total number of entries
this.totalEntries = readUInt64LE(data, consts.END64TOT);
// central directory size in bytes
this.size = readUInt64LE(data, consts.END64SIZ);
// offset of first CEN header
this.offset = readUInt64LE(data, consts.END64OFF);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class ZipEntry {
readHeader(data, offset) {
// data should be 46 bytes and start with "PK 01 02"
if (data.length < offset + consts.CENHDR || data.readUInt32LE(offset) !== consts.CENSIG) {
throw new Error('Invalid entry header');
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
// version made by
this.verMade = data.readUInt16LE(offset + consts.CENVEM);
// version needed to extract
this.version = data.readUInt16LE(offset + consts.CENVER);
// encrypt, decrypt flags
this.flags = data.readUInt16LE(offset + consts.CENFLG);
// compression method
this.method = data.readUInt16LE(offset + consts.CENHOW);
// modification time (2 bytes time, 2 bytes date)
const timebytes = data.readUInt16LE(offset + consts.CENTIM);
const datebytes = data.readUInt16LE(offset + consts.CENTIM + 2);
this.time = parseZipTime(timebytes, datebytes);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// uncompressed file crc-32 value
this.crc = data.readUInt32LE(offset + consts.CENCRC);
// compressed size
this.compressedSize = data.readUInt32LE(offset + consts.CENSIZ);
// uncompressed size
this.size = data.readUInt32LE(offset + consts.CENLEN);
// filename length
this.fnameLen = data.readUInt16LE(offset + consts.CENNAM);
// extra field length
this.extraLen = data.readUInt16LE(offset + consts.CENEXT);
// file comment length
this.comLen = data.readUInt16LE(offset + consts.CENCOM);
// volume number start
this.diskStart = data.readUInt16LE(offset + consts.CENDSK);
// internal file attributes
this.inattr = data.readUInt16LE(offset + consts.CENATT);
// external file attributes
this.attr = data.readUInt32LE(offset + consts.CENATX);
// LOC header offset
this.offset = data.readUInt32LE(offset + consts.CENOFF);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
readDataHeader(data) {
// 30 bytes and should start with "PK\003\004"
if (data.readUInt32LE(0) !== consts.LOCSIG) {
throw new Error('Invalid local header');
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
// version needed to extract
this.version = data.readUInt16LE(consts.LOCVER);
// general purpose bit flag
this.flags = data.readUInt16LE(consts.LOCFLG);
// compression method
this.method = data.readUInt16LE(consts.LOCHOW);
// modification time (2 bytes time ; 2 bytes date)
const timebytes = data.readUInt16LE(consts.LOCTIM);
const datebytes = data.readUInt16LE(consts.LOCTIM + 2);
this.time = parseZipTime(timebytes, datebytes);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
// uncompressed file crc-32 value
this.crc = data.readUInt32LE(consts.LOCCRC) || this.crc;
// compressed size
const compressedSize = data.readUInt32LE(consts.LOCSIZ);
if (compressedSize && compressedSize !== consts.EF_ZIP64_OR_32) {
this.compressedSize = compressedSize;
}
// uncompressed size
const size = data.readUInt32LE(consts.LOCLEN);
if (size && size !== consts.EF_ZIP64_OR_32) {
this.size = size;
}
// filename length
this.fnameLen = data.readUInt16LE(consts.LOCNAM);
// extra field length
this.extraLen = data.readUInt16LE(consts.LOCEXT);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
read(data, offset, textDecoder) {
const nameData = data.slice(offset, (offset += this.fnameLen));
this.name = textDecoder
? textDecoder.decode(new Uint8Array(nameData))
: nameData.toString('utf8');
const lastChar = data[offset - 1];
this.isDirectory = lastChar === 47 || lastChar === 92;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (this.extraLen) {
this.readExtra(data, offset);
offset += this.extraLen;
}
this.comment = this.comLen ? data.slice(offset, offset + this.comLen).toString() : null;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
validateName() {
if (/\\|^\w+:|^\/|(^|\/)\.\.(\/|$)/.test(this.name)) {
throw new Error('Malicious entry: ' + this.name);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
readExtra(data, offset) {
let signature, size;
const maxPos = offset + this.extraLen;
while (offset < maxPos) {
signature = data.readUInt16LE(offset);
offset += 2;
size = data.readUInt16LE(offset);
offset += 2;
if (consts.ID_ZIP64 === signature) {
this.parseZip64Extra(data, offset, size);
}
offset += size;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
parseZip64Extra(data, offset, length) {
if (length >= 8 && this.size === consts.EF_ZIP64_OR_32) {
this.size = readUInt64LE(data, offset);
offset += 8;
length -= 8;
}
if (length >= 8 && this.compressedSize === consts.EF_ZIP64_OR_32) {
this.compressedSize = readUInt64LE(data, offset);
offset += 8;
length -= 8;
}
if (length >= 8 && this.offset === consts.EF_ZIP64_OR_32) {
this.offset = readUInt64LE(data, offset);
offset += 8;
length -= 8;
}
if (length >= 4 && this.diskStart === consts.EF_ZIP64_OR_16) {
this.diskStart = data.readUInt32LE(offset);
// offset += 4; length -= 4;
}
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get encrypted() {
return (this.flags & consts.FLG_ENTRY_ENC) === consts.FLG_ENTRY_ENC;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
get isFile() {
return !this.isDirectory;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class FsRead {
constructor(fd, buffer, offset, length, position, callback) {
this.fd = fd;
this.buffer = buffer;
this.offset = offset;
this.length = length;
this.position = position;
this.callback = callback;
this.bytesRead = 0;
this.waiting = false;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
read(sync) {
StreamZip.debugLog('read', this.position, this.bytesRead, this.length, this.offset);
this.waiting = true;
let err;
if (sync) {
let bytesRead = 0;
try {
bytesRead = fs.readSync(
this.fd,
this.buffer,
this.offset + this.bytesRead,
this.length - this.bytesRead,
this.position + this.bytesRead
);
} catch (e) {
err = e;
}
this.readCallback(sync, err, err ? bytesRead : null);
} else {
fs.read(
this.fd,
this.buffer,
this.offset + this.bytesRead,
this.length - this.bytesRead,
this.position + this.bytesRead,
this.readCallback.bind(this, sync)
);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
readCallback(sync, err, bytesRead) {
if (typeof bytesRead === 'number') {
this.bytesRead += bytesRead;
}
if (err || !bytesRead || this.bytesRead === this.length) {
this.waiting = false;
return this.callback(err, this.bytesRead);
} else {
this.read(sync);
}
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class FileWindowBuffer {
constructor(fd) {
this.position = 0;
this.buffer = Buffer.alloc(0);
this.fd = fd;
this.fsOp = null;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
checkOp() {
if (this.fsOp && this.fsOp.waiting) {
throw new Error('Operation in progress');
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
read(pos, length, callback) {
this.checkOp();
if (this.buffer.length < length) {
this.buffer = Buffer.alloc(length);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
this.position = pos;
this.fsOp = new FsRead(this.fd, this.buffer, 0, length, this.position, callback).read();
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
expandLeft(length, callback) {
this.checkOp();
this.buffer = Buffer.concat([Buffer.alloc(length), this.buffer]);
this.position -= length;
if (this.position < 0) {
this.position = 0;
}
this.fsOp = new FsRead(this.fd, this.buffer, 0, length, this.position, callback).read();
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
expandRight(length, callback) {
this.checkOp();
const offset = this.buffer.length;
this.buffer = Buffer.concat([this.buffer, Buffer.alloc(length)]);
this.fsOp = new FsRead(
this.fd,
this.buffer,
offset,
length,
this.position + offset,
callback
).read();
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
moveRight(length, callback, shift) {
this.checkOp();
if (shift) {
this.buffer.copy(this.buffer, 0, shift);
} else {
shift = 0;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
this.position += shift;
this.fsOp = new FsRead(
this.fd,
this.buffer,
this.buffer.length - shift,
shift,
this.position + this.buffer.length - shift,
callback
).read();
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class EntryDataReaderStream extends stream.Readable {
constructor(fd, offset, length) {
super();
this.fd = fd;
this.offset = offset;
this.length = length;
this.pos = 0;
this.readCallback = this.readCallback.bind(this);
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
_read(n) {
const buffer = Buffer.alloc(Math.min(n, this.length - this.pos));
if (buffer.length) {
fs.read(this.fd, buffer, 0, buffer.length, this.offset + this.pos, this.readCallback);
} else {
this.push(null);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
readCallback(err, bytesRead, buffer) {
this.pos += bytesRead;
if (err) {
this.emit('error', err);
this.push(null);
} else if (!bytesRead) {
this.push(null);
} else {
if (bytesRead !== buffer.length) {
buffer = buffer.slice(0, bytesRead);
}
this.push(buffer);
}
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class EntryVerifyStream extends stream.Transform {
constructor(baseStm, crc, size) {
super();
this.verify = new CrcVerify(crc, size);
baseStm.on('error', (e) => {
this.emit('error', e);
});
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
_transform(data, encoding, callback) {
let err;
try {
this.verify.data(data);
} catch (e) {
err = e;
}
callback(err, data);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class CrcVerify {
constructor(crc, size) {
this.crc = crc;
this.size = size;
this.state = {
crc: ~0,
size: 0,
};
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
data(data) {
const crcTable = CrcVerify.getCrcTable();
let crc = this.state.crc;
let off = 0;
let len = data.length;
while (--len >= 0) {
crc = crcTable[(crc ^ data[off++]) & 0xff] ^ (crc >>> 8);
}
this.state.crc = crc;
this.state.size += data.length;
if (this.state.size >= this.size) {
const buf = Buffer.alloc(4);
buf.writeInt32LE(~this.state.crc & 0xffffffff, 0);
crc = buf.readUInt32LE(0);
if (crc !== this.crc) {
throw new Error('Invalid CRC');
}
if (this.state.size !== this.size) {
throw new Error('Invalid size');
}
}
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
static getCrcTable() {
let crcTable = CrcVerify.crcTable;
if (!crcTable) {
CrcVerify.crcTable = crcTable = [];
const b = Buffer.alloc(4);
for (let n = 0; n < 256; n++) {
let c = n;
for (let k = 8; --k >= 0; ) {
if ((c & 1) !== 0) {
c = 0xedb88320 ^ (c >>> 1);
} else {
c = c >>> 1;
}
}
if (c < 0) {
b.writeInt32LE(c, 0);
c = b.readUInt32LE(0);
}
crcTable[n] = c;
}
}
return crcTable;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function parseZipTime(timebytes, datebytes) {
const timebits = toBits(timebytes, 16);
const datebits = toBits(datebytes, 16);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const mt = {
h: parseInt(timebits.slice(0, 5).join(''), 2),
m: parseInt(timebits.slice(5, 11).join(''), 2),
s: parseInt(timebits.slice(11, 16).join(''), 2) * 2,
Y: parseInt(datebits.slice(0, 7).join(''), 2) + 1980,
M: parseInt(datebits.slice(7, 11).join(''), 2),
D: parseInt(datebits.slice(11, 16).join(''), 2),
};
const dt_str = [mt.Y, mt.M, mt.D].join('-') + ' ' + [mt.h, mt.m, mt.s].join(':') + ' GMT+0';
return new Date(dt_str).getTime();
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function toBits(dec, size) {
let b = (dec >>> 0).toString(2);
while (b.length < size) {
b = '0' + b;
}
return b.split('');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function readUInt64LE(buffer, offset) {
return buffer.readUInt32LE(offset + 4) * 0x0000000100000000 + buffer.readUInt32LE(offset);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = StreamZip;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 1223:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var wrappy = __nccwpck_require__(2940)
module.exports = wrappy(once)
module.exports.strict = wrappy(onceStrict)
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
once.proto = once(function () {
Object.defineProperty(Function.prototype, 'once', {
value: function () {
return once(this)
},
configurable: true
})
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(Function.prototype, 'onceStrict', {
value: function () {
return onceStrict(this)
},
configurable: true
})
})
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function once (fn) {
var f = function () {
if (f.called) return f.value
f.called = true
return f.value = fn.apply(this, arguments)
}
f.called = false
return f
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function onceStrict (fn) {
var f = function () {
if (f.called)
throw new Error(f.onceError)
f.called = true
return f.value = fn.apply(this, arguments)
}
var name = fn.name || 'Function wrapped with `once`'
f.onceError = name + " shouldn't be called more than once"
f.called = false
return f
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 8569:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = __nccwpck_require__(3322);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 6099:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const path = __nccwpck_require__(1017);
const WIN_SLASH = '\\\\/';
const WIN_NO_SLASH = `[^${WIN_SLASH}]`;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Posix glob regex
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const DOT_LITERAL = '\\.';
const PLUS_LITERAL = '\\+';
const QMARK_LITERAL = '\\?';
const SLASH_LITERAL = '\\/';
const ONE_CHAR = '(?=.)';
const QMARK = '[^/]';
const END_ANCHOR = `(?:${SLASH_LITERAL}|$)`;
const START_ANCHOR = `(?:^|${SLASH_LITERAL})`;
const DOTS_SLASH = `${DOT_LITERAL}{1,2}${END_ANCHOR}`;
const NO_DOT = `(?!${DOT_LITERAL})`;
const NO_DOTS = `(?!${START_ANCHOR}${DOTS_SLASH})`;
const NO_DOT_SLASH = `(?!${DOT_LITERAL}{0,1}${END_ANCHOR})`;
const NO_DOTS_SLASH = `(?!${DOTS_SLASH})`;
const QMARK_NO_DOT = `[^.${SLASH_LITERAL}]`;
const STAR = `${QMARK}*?`;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const POSIX_CHARS = {
DOT_LITERAL,
PLUS_LITERAL,
QMARK_LITERAL,
SLASH_LITERAL,
ONE_CHAR,
QMARK,
END_ANCHOR,
DOTS_SLASH,
NO_DOT,
NO_DOTS,
NO_DOT_SLASH,
NO_DOTS_SLASH,
QMARK_NO_DOT,
STAR,
START_ANCHOR
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Windows glob regex
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const WINDOWS_CHARS = {
...POSIX_CHARS,
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
SLASH_LITERAL: `[${WIN_SLASH}]`,
QMARK: WIN_NO_SLASH,
STAR: `${WIN_NO_SLASH}*?`,
DOTS_SLASH: `${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$)`,
NO_DOT: `(?!${DOT_LITERAL})`,
NO_DOTS: `(?!(?:^|[${WIN_SLASH}])${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$))`,
NO_DOT_SLASH: `(?!${DOT_LITERAL}{0,1}(?:[${WIN_SLASH}]|$))`,
NO_DOTS_SLASH: `(?!${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$))`,
QMARK_NO_DOT: `[^.${WIN_SLASH}]`,
START_ANCHOR: `(?:^|[${WIN_SLASH}])`,
END_ANCHOR: `(?:[${WIN_SLASH}]|$)`
2021-09-26 15:31:45 -04:00
};
/**
2022-05-31 14:18:28 -04:00
* POSIX Bracket Regex
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
const POSIX_REGEX_SOURCE = {
alnum: 'a-zA-Z0-9',
alpha: 'a-zA-Z',
ascii: '\\x00-\\x7F',
blank: ' \\t',
cntrl: '\\x00-\\x1F\\x7F',
digit: '0-9',
graph: '\\x21-\\x7E',
lower: 'a-z',
print: '\\x20-\\x7E ',
punct: '\\-!"#$%&\'()\\*+,./:;<=>?@[\\]^_`{|}~',
space: ' \\t\\r\\n\\v\\f',
upper: 'A-Z',
word: 'A-Za-z0-9_',
xdigit: 'A-Fa-f0-9'
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = {
MAX_LENGTH: 1024 * 64,
POSIX_REGEX_SOURCE,
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// regular expressions
REGEX_BACKSLASH: /\\(?![*+?^${}(|)[\]])/g,
REGEX_NON_SPECIAL_CHARS: /^[^@![\].,$*+?^{}()|\\/]+/,
REGEX_SPECIAL_CHARS: /[-*+?.^${}(|)[\]]/,
REGEX_SPECIAL_CHARS_BACKREF: /(\\?)((\W)(\3*))/g,
REGEX_SPECIAL_CHARS_GLOBAL: /([-*+?.^${}(|)[\]])/g,
REGEX_REMOVE_BACKSLASH: /(?:\[.*?[^\\]\]|\\(?=.))/g,
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Replace globs with equivalent patterns to reduce parsing time.
REPLACEMENTS: {
'***': '*',
'**/**': '**',
'**/**/**': '**'
},
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Digits
CHAR_0: 48, /* 0 */
CHAR_9: 57, /* 9 */
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Alphabet chars.
CHAR_UPPERCASE_A: 65, /* A */
CHAR_LOWERCASE_A: 97, /* a */
CHAR_UPPERCASE_Z: 90, /* Z */
CHAR_LOWERCASE_Z: 122, /* z */
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
CHAR_LEFT_PARENTHESES: 40, /* ( */
CHAR_RIGHT_PARENTHESES: 41, /* ) */
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
CHAR_ASTERISK: 42, /* * */
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Non-alphabetic chars.
CHAR_AMPERSAND: 38, /* & */
CHAR_AT: 64, /* @ */
CHAR_BACKWARD_SLASH: 92, /* \ */
CHAR_CARRIAGE_RETURN: 13, /* \r */
CHAR_CIRCUMFLEX_ACCENT: 94, /* ^ */
CHAR_COLON: 58, /* : */
CHAR_COMMA: 44, /* , */
CHAR_DOT: 46, /* . */
CHAR_DOUBLE_QUOTE: 34, /* " */
CHAR_EQUAL: 61, /* = */
CHAR_EXCLAMATION_MARK: 33, /* ! */
CHAR_FORM_FEED: 12, /* \f */
CHAR_FORWARD_SLASH: 47, /* / */
CHAR_GRAVE_ACCENT: 96, /* ` */
CHAR_HASH: 35, /* # */
CHAR_HYPHEN_MINUS: 45, /* - */
CHAR_LEFT_ANGLE_BRACKET: 60, /* < */
CHAR_LEFT_CURLY_BRACE: 123, /* { */
CHAR_LEFT_SQUARE_BRACKET: 91, /* [ */
CHAR_LINE_FEED: 10, /* \n */
CHAR_NO_BREAK_SPACE: 160, /* \u00A0 */
CHAR_PERCENT: 37, /* % */
CHAR_PLUS: 43, /* + */
CHAR_QUESTION_MARK: 63, /* ? */
CHAR_RIGHT_ANGLE_BRACKET: 62, /* > */
CHAR_RIGHT_CURLY_BRACE: 125, /* } */
CHAR_RIGHT_SQUARE_BRACKET: 93, /* ] */
CHAR_SEMICOLON: 59, /* ; */
CHAR_SINGLE_QUOTE: 39, /* ' */
CHAR_SPACE: 32, /* */
CHAR_TAB: 9, /* \t */
CHAR_UNDERSCORE: 95, /* _ */
CHAR_VERTICAL_LINE: 124, /* | */
CHAR_ZERO_WIDTH_NOBREAK_SPACE: 65279, /* \uFEFF */
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
SEP: path.sep,
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Create EXTGLOB_CHARS
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
extglobChars(chars) {
return {
'!': { type: 'negate', open: '(?:(?!(?:', close: `))${chars.STAR})` },
'?': { type: 'qmark', open: '(?:', close: ')?' },
'+': { type: 'plus', open: '(?:', close: ')+' },
'*': { type: 'star', open: '(?:', close: ')*' },
'@': { type: 'at', open: '(?:', close: ')' }
};
},
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Create GLOB_CHARS
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
globChars(win32) {
return win32 === true ? WINDOWS_CHARS : POSIX_CHARS;
2021-09-26 15:31:45 -04:00
}
};
2021-12-11 08:00:14 -05:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 2139:
2021-12-11 08:00:14 -05:00
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
"use strict";
const constants = __nccwpck_require__(6099);
2022-05-31 14:18:28 -04:00
const utils = __nccwpck_require__(479);
2021-12-11 08:00:14 -05:00
2021-09-26 15:31:45 -04:00
/**
2022-05-31 14:18:28 -04:00
* Constants
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
const {
MAX_LENGTH,
POSIX_REGEX_SOURCE,
REGEX_NON_SPECIAL_CHARS,
REGEX_SPECIAL_CHARS_BACKREF,
REPLACEMENTS
} = constants;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Helpers
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const expandRange = (args, options) => {
if (typeof options.expandRange === 'function') {
return options.expandRange(...args, options);
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
args.sort();
const value = `[${args.join('-')}]`;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
try {
/* eslint-disable-next-line no-new */
new RegExp(value);
} catch (ex) {
return args.map(v => utils.escapeRegex(v)).join('..');
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return value;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Create the message for a syntax error
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const syntaxError = (type, char) => {
return `Missing ${type}: "${char}" - use "\\\\${char}" to match literal characters`;
2021-09-26 15:31:45 -04:00
};
/**
2022-05-31 14:18:28 -04:00
* Parse the given input string.
* @param {String} input
* @param {Object} options
* @return {Object}
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
const parse = (input, options) => {
2021-12-11 08:00:14 -05:00
if (typeof input !== 'string') {
2022-05-31 14:18:28 -04:00
throw new TypeError('Expected a string');
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
input = REPLACEMENTS[input] || input;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const opts = { ...options };
const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let len = input.length;
if (len > max) {
throw new SyntaxError(`Input length: ${len}, exceeds maximum allowed length: ${max}`);
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const bos = { type: 'bos', value: '', output: opts.prepend || '' };
const tokens = [bos];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const capture = opts.capture ? '' : '?:';
const win32 = utils.isWindows(options);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// create constants based on platform, for windows or posix
const PLATFORM_CHARS = constants.globChars(win32);
const EXTGLOB_CHARS = constants.extglobChars(PLATFORM_CHARS);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const {
DOT_LITERAL,
PLUS_LITERAL,
SLASH_LITERAL,
ONE_CHAR,
DOTS_SLASH,
NO_DOT,
NO_DOT_SLASH,
NO_DOTS_SLASH,
QMARK,
QMARK_NO_DOT,
STAR,
START_ANCHOR
} = PLATFORM_CHARS;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const globstar = opts => {
return `(${capture}(?:(?!${START_ANCHOR}${opts.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const nodot = opts.dot ? '' : NO_DOT;
const qmarkNoDot = opts.dot ? QMARK : QMARK_NO_DOT;
let star = opts.bash === true ? globstar(opts) : STAR;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (opts.capture) {
star = `(${star})`;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// minimatch options support
if (typeof opts.noext === 'boolean') {
opts.noextglob = opts.noext;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const state = {
input,
index: -1,
start: 0,
dot: opts.dot === true,
consumed: '',
output: '',
prefix: '',
backtrack: false,
negated: false,
brackets: 0,
braces: 0,
parens: 0,
quotes: 0,
globstar: false,
tokens
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
input = utils.removePrefix(input, state);
len = input.length;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const extglobs = [];
const braces = [];
const stack = [];
let prev = bos;
let value;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Tokenizing helpers
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const eos = () => state.index === len - 1;
const peek = state.peek = (n = 1) => input[state.index + n];
const advance = state.advance = () => input[++state.index] || '';
const remaining = () => input.slice(state.index + 1);
const consume = (value = '', num = 0) => {
state.consumed += value;
state.index += num;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const append = token => {
state.output += token.output != null ? token.output : token.value;
consume(token.value);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const negate = () => {
let count = 1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (peek() === '!' && (peek(2) !== '(' || peek(3) === '?')) {
advance();
state.start++;
count++;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (count % 2 === 0) {
return false;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
state.negated = true;
state.start++;
return true;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const increment = type => {
state[type]++;
stack.push(type);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const decrement = type => {
state[type]--;
stack.pop();
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Push tokens onto the tokens array. This helper speeds up
* tokenizing by 1) helping us avoid backtracking as much as possible,
* and 2) helping us avoid creating extra tokens when consecutive
* characters are plain text. This improves performance and simplifies
* lookbehinds.
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const push = tok => {
if (prev.type === 'globstar') {
const isBrace = state.braces > 0 && (tok.type === 'comma' || tok.type === 'brace');
const isExtglob = tok.extglob === true || (extglobs.length && (tok.type === 'pipe' || tok.type === 'paren'));
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (tok.type !== 'slash' && tok.type !== 'paren' && !isBrace && !isExtglob) {
state.output = state.output.slice(0, -prev.output.length);
prev.type = 'star';
prev.value = '*';
prev.output = star;
state.output += prev.output;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (extglobs.length && tok.type !== 'paren') {
extglobs[extglobs.length - 1].inner += tok.value;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (tok.value || tok.output) append(tok);
if (prev && prev.type === 'text' && tok.type === 'text') {
prev.value += tok.value;
prev.output = (prev.output || '') + tok.value;
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
tok.prev = prev;
tokens.push(tok);
prev = tok;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const extglobOpen = (type, value) => {
const token = { ...EXTGLOB_CHARS[value], conditions: 1, inner: '' };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
token.prev = prev;
token.parens = state.parens;
token.output = state.output;
const output = (opts.capture ? '(' : '') + token.open;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
increment('parens');
push({ type, value, output: state.output ? '' : ONE_CHAR });
push({ type: 'paren', extglob: true, value: advance(), output });
extglobs.push(token);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const extglobClose = token => {
let output = token.close + (opts.capture ? ')' : '');
let rest;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (token.type === 'negate') {
let extglobStar = star;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (token.inner && token.inner.length > 1 && token.inner.includes('/')) {
extglobStar = globstar(opts);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (extglobStar !== star || eos() || /^\)+$/.test(remaining())) {
output = token.close = `)$))${extglobStar}`;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (token.inner.includes('*') && (rest = remaining()) && /^\.[^\\/.]+$/.test(rest)) {
// Any non-magical string (`.ts`) or even nested expression (`.{ts,tsx}`) can follow after the closing parenthesis.
// In this case, we need to parse the string and use it in the output of the original pattern.
// Suitable patterns: `/!(*.d).ts`, `/!(*.d).{ts,tsx}`, `**/!(*-dbg).@(js)`.
//
// Disabling the `fastpaths` option due to a problem with parsing strings as `.ts` in the pattern like `**/!(*.d).ts`.
const expression = parse(rest, { ...options, fastpaths: false }).output;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
output = token.close = `)${expression})${extglobStar})`;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (token.prev.type === 'bos') {
state.negatedExtglob = true;
2021-09-26 15:31:45 -04:00
}
}
2022-05-31 14:18:28 -04:00
push({ type: 'paren', extglob: true, value, output });
decrement('parens');
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Fast paths
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (opts.fastpaths !== false && !/(^[*!]|[/()[\]{}"])/.test(input)) {
let backslashes = false;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let output = input.replace(REGEX_SPECIAL_CHARS_BACKREF, (m, esc, chars, first, rest, index) => {
if (first === '\\') {
backslashes = true;
return m;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (first === '?') {
if (esc) {
return esc + first + (rest ? QMARK.repeat(rest.length) : '');
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (index === 0) {
return qmarkNoDot + (rest ? QMARK.repeat(rest.length) : '');
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
return QMARK.repeat(chars.length);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (first === '.') {
return DOT_LITERAL.repeat(chars.length);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (first === '*') {
if (esc) {
return esc + first + (rest ? star : '');
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
return star;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
return esc ? m : `\\${m}`;
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (backslashes === true) {
if (opts.unescape === true) {
output = output.replace(/\\/g, '');
} else {
output = output.replace(/\\+/g, m => {
return m.length % 2 === 0 ? '\\\\' : (m ? '\\' : '');
});
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (output === input && opts.contains === true) {
state.output = input;
return state;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
state.output = utils.wrapOutput(output, state, options);
return state;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Tokenize input until we reach end-of-string
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (!eos()) {
value = advance();
if (value === '\u0000') {
2021-12-11 08:00:14 -05:00
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Escaped characters
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === '\\') {
const next = peek();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (next === '/' && opts.bash !== true) {
continue;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (next === '.' || next === ';') {
2021-12-11 08:00:14 -05:00
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!next) {
value += '\\';
push({ type: 'text', value });
2021-12-11 08:00:14 -05:00
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// collapse slashes to reduce potential for exploits
const match = /^\\+/.exec(remaining());
let slashes = 0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (match && match[0].length > 2) {
slashes = match[0].length;
state.index += slashes;
if (slashes % 2 !== 0) {
value += '\\';
2021-12-11 08:00:14 -05:00
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (opts.unescape === true) {
value = advance();
} else {
value += advance();
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (state.brackets === 0) {
push({ type: 'text', value });
continue;
}
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* If we're inside a regex character class, continue
* until we reach the closing bracket.
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (state.brackets > 0 && (value !== ']' || prev.value === '[' || prev.value === '[^')) {
if (opts.posix !== false && value === ':') {
const inner = prev.value.slice(1);
if (inner.includes('[')) {
prev.posix = true;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (inner.includes(':')) {
const idx = prev.value.lastIndexOf('[');
const pre = prev.value.slice(0, idx);
const rest = prev.value.slice(idx + 2);
const posix = POSIX_REGEX_SOURCE[rest];
if (posix) {
prev.value = pre + posix;
state.backtrack = true;
advance();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!bos.output && tokens.indexOf(prev) === 1) {
bos.output = ONE_CHAR;
}
continue;
}
2021-12-11 08:00:14 -05:00
}
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if ((value === '[' && peek() !== ':') || (value === '-' && peek() === ']')) {
value = `\\${value}`;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === ']' && (prev.value === '[' || prev.value === '[^')) {
value = `\\${value}`;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (opts.posix === true && value === '!' && prev.value === '[') {
value = '^';
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
prev.value += value;
append({ value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* If we're inside a quoted string, continue
* until we reach the closing double quote.
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (state.quotes === 1 && value !== '"') {
value = utils.escapeRegex(value);
prev.value += value;
append({ value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Double quotes
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === '"') {
state.quotes = state.quotes === 1 ? 0 : 1;
if (opts.keepQuotes === true) {
push({ type: 'text', value });
}
continue;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
/**
* Parentheses
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === '(') {
increment('parens');
push({ type: 'paren', value });
continue;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === ')') {
if (state.parens === 0 && opts.strictBrackets === true) {
throw new SyntaxError(syntaxError('opening', '('));
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const extglob = extglobs[extglobs.length - 1];
if (extglob && state.parens === extglob.parens + 1) {
extglobClose(extglobs.pop());
continue;
}
push({ type: 'paren', value, output: state.parens ? ')' : '\\)' });
decrement('parens');
continue;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Square brackets
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === '[') {
if (opts.nobracket === true || !remaining().includes(']')) {
if (opts.nobracket !== true && opts.strictBrackets === true) {
throw new SyntaxError(syntaxError('closing', ']'));
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
value = `\\${value}`;
} else {
increment('brackets');
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
push({ type: 'bracket', value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === ']') {
if (opts.nobracket === true || (prev && prev.type === 'bracket' && prev.value.length === 1)) {
push({ type: 'text', value, output: `\\${value}` });
continue;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (state.brackets === 0) {
if (opts.strictBrackets === true) {
throw new SyntaxError(syntaxError('opening', '['));
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
push({ type: 'text', value, output: `\\${value}` });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
decrement('brackets');
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const prevValue = prev.value.slice(1);
if (prev.posix !== true && prevValue[0] === '^' && !prevValue.includes('/')) {
value = `/${value}`;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
prev.value += value;
append({ value });
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// when literal brackets are explicitly disabled
// assume we should match with a regex character class
if (opts.literalBrackets === false || utils.hasRegexChars(prevValue)) {
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const escaped = utils.escapeRegex(prev.value);
state.output = state.output.slice(0, -prev.value.length);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// when literal brackets are explicitly enabled
// assume we should escape the brackets to match literal characters
if (opts.literalBrackets === true) {
state.output += escaped;
prev.value = escaped;
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// when the user specifies nothing, try to match both
prev.value = `(${capture}${escaped}|${prev.value})`;
state.output += prev.value;
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Braces
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === '{' && opts.nobrace !== true) {
increment('braces');
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const open = {
type: 'brace',
value,
output: '(',
outputIndex: state.output.length,
tokensIndex: state.tokens.length
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
braces.push(open);
push(open);
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === '}') {
const brace = braces[braces.length - 1];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (opts.nobrace === true || !brace) {
push({ type: 'text', value, output: value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let output = ')';
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (brace.dots === true) {
const arr = tokens.slice();
const range = [];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (let i = arr.length - 1; i >= 0; i--) {
tokens.pop();
if (arr[i].type === 'brace') {
break;
}
if (arr[i].type !== 'dots') {
range.unshift(arr[i].value);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
output = expandRange(range, opts);
state.backtrack = true;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (brace.comma !== true && brace.dots !== true) {
const out = state.output.slice(0, brace.outputIndex);
const toks = state.tokens.slice(brace.tokensIndex);
brace.value = brace.output = '\\{';
value = output = '\\}';
state.output = out;
for (const t of toks) {
state.output += (t.output || t.value);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
push({ type: 'brace', value, output });
decrement('braces');
braces.pop();
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Pipes
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === '|') {
if (extglobs.length > 0) {
extglobs[extglobs.length - 1].conditions++;
}
push({ type: 'text', value });
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Commas
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === ',') {
let output = value;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const brace = braces[braces.length - 1];
if (brace && stack[stack.length - 1] === 'braces') {
brace.comma = true;
output = '|';
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
push({ type: 'comma', value, output });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Slashes
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (value === '/') {
// if the beginning of the glob is "./", advance the start
// to the current index, and don't add the "./" characters
// to the state. This greatly simplifies lookbehinds when
// checking for BOS characters like "!" and "." (not "./")
if (prev.type === 'dot' && state.index === state.start + 1) {
state.start = state.index + 1;
state.consumed = '';
state.output = '';
tokens.pop();
prev = bos; // reset "prev" to the first token
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
push({ type: 'slash', value, output: SLASH_LITERAL });
continue;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
/**
* Dots
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (value === '.') {
if (state.braces > 0 && prev.type === 'dot') {
if (prev.value === '.') prev.output = DOT_LITERAL;
const brace = braces[braces.length - 1];
prev.type = 'dots';
prev.output += value;
prev.value += value;
brace.dots = true;
continue;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if ((state.braces + state.parens) === 0 && prev.type !== 'bos' && prev.type !== 'slash') {
push({ type: 'text', value, output: DOT_LITERAL });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
push({ type: 'dot', value, output: DOT_LITERAL });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Question marks
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (value === '?') {
const isGroup = prev && prev.value === '(';
if (!isGroup && opts.noextglob !== true && peek() === '(' && peek(2) !== '?') {
extglobOpen('qmark', value);
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (prev && prev.type === 'paren') {
const next = peek();
let output = value;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (next === '<' && !utils.supportsLookbehinds()) {
throw new Error('Node.js v10 or higher is required for regex lookbehinds');
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if ((prev.value === '(' && !/[!=<:]/.test(next)) || (next === '<' && !/<([!=]|\w+>)/.test(remaining()))) {
output = `\\${value}`;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
push({ type: 'text', value, output });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (opts.dot !== true && (prev.type === 'slash' || prev.type === 'bos')) {
push({ type: 'qmark', value, output: QMARK_NO_DOT });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
push({ type: 'qmark', value, output: QMARK });
continue;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
/**
* Exclamation
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (value === '!') {
if (opts.noextglob !== true && peek() === '(') {
if (peek(2) !== '?' || !/[!=<:]/.test(peek(3))) {
extglobOpen('negate', value);
continue;
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (opts.nonegate !== true && state.index === 0) {
negate();
continue;
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Plus
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (value === '+') {
if (opts.noextglob !== true && peek() === '(' && peek(2) !== '?') {
extglobOpen('plus', value);
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if ((prev && prev.value === '(') || opts.regex === false) {
push({ type: 'plus', value, output: PLUS_LITERAL });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if ((prev && (prev.type === 'bracket' || prev.type === 'paren' || prev.type === 'brace')) || state.parens > 0) {
push({ type: 'plus', value });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
push({ type: 'plus', value: PLUS_LITERAL });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Plain text
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (value === '@') {
if (opts.noextglob !== true && peek() === '(' && peek(2) !== '?') {
push({ type: 'at', extglob: true, value, output: '' });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
push({ type: 'text', value });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Plain text
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (value !== '*') {
if (value === '$' || value === '^') {
value = `\\${value}`;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const match = REGEX_NON_SPECIAL_CHARS.exec(remaining());
if (match) {
value += match[0];
state.index += match[0].length;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
push({ type: 'text', value });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Stars
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (prev && (prev.type === 'globstar' || prev.star === true)) {
prev.type = 'star';
prev.star = true;
prev.value += value;
prev.output = star;
state.backtrack = true;
state.globstar = true;
consume(value);
continue;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
let rest = remaining();
if (opts.noextglob !== true && /^\([^?]/.test(rest)) {
extglobOpen('star', value);
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (prev.type === 'star') {
if (opts.noglobstar === true) {
consume(value);
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const prior = prev.prev;
const before = prior.prev;
const isStart = prior.type === 'slash' || prior.type === 'bos';
const afterStar = before && (before.type === 'star' || before.type === 'globstar');
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (opts.bash === true && (!isStart || (rest[0] && rest[0] !== '/'))) {
push({ type: 'star', value, output: '' });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const isBrace = state.braces > 0 && (prior.type === 'comma' || prior.type === 'brace');
const isExtglob = extglobs.length && (prior.type === 'pipe' || prior.type === 'paren');
if (!isStart && prior.type !== 'paren' && !isBrace && !isExtglob) {
push({ type: 'star', value, output: '' });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
// strip consecutive `/**/`
while (rest.slice(0, 3) === '/**') {
const after = input[state.index + 4];
if (after && after !== '/') {
break;
}
rest = rest.slice(3);
consume('/**', 3);
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (prior.type === 'bos' && eos()) {
prev.type = 'globstar';
prev.value += value;
prev.output = globstar(opts);
state.output = prev.output;
state.globstar = true;
consume(value);
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (prior.type === 'slash' && prior.prev.type !== 'bos' && !afterStar && eos()) {
state.output = state.output.slice(0, -(prior.output + prev.output).length);
prior.output = `(?:${prior.output}`;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
prev.type = 'globstar';
prev.output = globstar(opts) + (opts.strictSlashes ? ')' : '|$)');
prev.value += value;
state.globstar = true;
state.output += prior.output + prev.output;
consume(value);
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (prior.type === 'slash' && prior.prev.type !== 'bos' && rest[0] === '/') {
const end = rest[1] !== void 0 ? '|$' : '';
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
state.output = state.output.slice(0, -(prior.output + prev.output).length);
prior.output = `(?:${prior.output}`;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
prev.type = 'globstar';
prev.output = `${globstar(opts)}${SLASH_LITERAL}|${SLASH_LITERAL}${end})`;
prev.value += value;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
state.output += prior.output + prev.output;
state.globstar = true;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
consume(value + advance());
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
push({ type: 'slash', value: '/', output: '' });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (prior.type === 'bos' && rest[0] === '/') {
prev.type = 'globstar';
prev.value += value;
prev.output = `(?:^|${SLASH_LITERAL}|${globstar(opts)}${SLASH_LITERAL})`;
state.output = prev.output;
state.globstar = true;
consume(value + advance());
push({ type: 'slash', value: '/', output: '' });
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
// remove single star from output
state.output = state.output.slice(0, -prev.output.length);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
// reset previous token to globstar
prev.type = 'globstar';
prev.output = globstar(opts);
prev.value += value;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
// reset output with globstar
state.output += prev.output;
state.globstar = true;
consume(value);
continue;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const token = { type: 'star', value, output: star };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (opts.bash === true) {
token.output = '.*?';
if (prev.type === 'bos' || prev.type === 'slash') {
token.output = nodot + token.output;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
push(token);
2021-09-26 15:31:45 -04:00
continue;
}
2022-05-31 14:18:28 -04:00
if (prev && (prev.type === 'bracket' || prev.type === 'paren') && opts.regex === true) {
token.output = value;
push(token);
continue;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (state.index === state.start || prev.type === 'slash' || prev.type === 'dot') {
if (prev.type === 'dot') {
state.output += NO_DOT_SLASH;
prev.output += NO_DOT_SLASH;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
} else if (opts.dot === true) {
state.output += NO_DOTS_SLASH;
prev.output += NO_DOTS_SLASH;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
} else {
state.output += nodot;
prev.output += nodot;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (peek() !== '*') {
state.output += ONE_CHAR;
prev.output += ONE_CHAR;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
push(token);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
while (state.brackets > 0) {
if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', ']'));
state.output = utils.escapeLast(state.output, '[');
decrement('brackets');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (state.parens > 0) {
if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', ')'));
state.output = utils.escapeLast(state.output, '(');
decrement('parens');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (state.braces > 0) {
if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', '}'));
state.output = utils.escapeLast(state.output, '{');
decrement('braces');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (opts.strictSlashes !== true && (prev.type === 'star' || prev.type === 'bracket')) {
push({ type: 'maybe_slash', value: '', output: `${SLASH_LITERAL}?` });
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// rebuild the output if we had to backtrack at any point
if (state.backtrack === true) {
state.output = '';
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
for (const token of state.tokens) {
state.output += token.output != null ? token.output : token.value;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (token.suffix) {
state.output += token.suffix;
}
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return state;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Fast paths for creating regular expressions for common glob patterns.
* This can significantly speed up processing and has very little downside
* impact when none of the fast paths match.
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
parse.fastpaths = (input, options) => {
const opts = { ...options };
const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH;
const len = input.length;
if (len > max) {
throw new SyntaxError(`Input length: ${len}, exceeds maximum allowed length: ${max}`);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
input = REPLACEMENTS[input] || input;
const win32 = utils.isWindows(options);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// create constants based on platform, for windows or posix
const {
DOT_LITERAL,
SLASH_LITERAL,
ONE_CHAR,
DOTS_SLASH,
NO_DOT,
NO_DOTS,
NO_DOTS_SLASH,
STAR,
START_ANCHOR
} = constants.globChars(win32);
const nodot = opts.dot ? NO_DOTS : NO_DOT;
const slashDot = opts.dot ? NO_DOTS_SLASH : NO_DOT;
const capture = opts.capture ? '' : '?:';
const state = { negated: false, prefix: '' };
let star = opts.bash === true ? '.*?' : STAR;
if (opts.capture) {
star = `(${star})`;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
const globstar = opts => {
if (opts.noglobstar === true) return star;
return `(${capture}(?:(?!${START_ANCHOR}${opts.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const create = str => {
switch (str) {
case '*':
return `${nodot}${ONE_CHAR}${star}`;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
case '.*':
return `${DOT_LITERAL}${ONE_CHAR}${star}`;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
case '*.*':
return `${nodot}${star}${DOT_LITERAL}${ONE_CHAR}${star}`;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
case '*/*':
return `${nodot}${star}${SLASH_LITERAL}${ONE_CHAR}${slashDot}${star}`;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
case '**':
return nodot + globstar(opts);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
case '**/*':
return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${slashDot}${ONE_CHAR}${star}`;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
case '**/*.*':
return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${slashDot}${star}${DOT_LITERAL}${ONE_CHAR}${star}`;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
case '**/.*':
return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${DOT_LITERAL}${ONE_CHAR}${star}`;
default: {
const match = /^(.*?)\.(\w+)$/.exec(str);
if (!match) return;
const source = create(match[1]);
if (!source) return;
return source + DOT_LITERAL + match[2];
}
}
};
const output = utils.removePrefix(input, state);
let source = create(output);
if (source && opts.strictSlashes !== true) {
source += `${SLASH_LITERAL}?`;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
return source;
2021-12-11 08:00:14 -05:00
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = parse;
2021-09-26 15:31:45 -04:00
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 3322:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
"use strict";
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const path = __nccwpck_require__(1017);
const scan = __nccwpck_require__(2429);
const parse = __nccwpck_require__(2139);
const utils = __nccwpck_require__(479);
const constants = __nccwpck_require__(6099);
const isObject = val => val && typeof val === 'object' && !Array.isArray(val);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Creates a matcher function from one or more glob patterns. The
* returned function takes a string to match as its first argument,
* and returns true if the string is a match. The returned matcher
* function also takes a boolean as the second argument that, when true,
* returns an object with additional information.
*
* ```js
* const picomatch = require('picomatch');
* // picomatch(glob[, options]);
*
* const isMatch = picomatch('*.!(*a)');
* console.log(isMatch('a.a')); //=> false
* console.log(isMatch('a.b')); //=> true
* ```
* @name picomatch
* @param {String|Array} `globs` One or more glob patterns.
* @param {Object=} `options`
* @return {Function=} Returns a matcher function.
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const picomatch = (glob, options, returnState = false) => {
if (Array.isArray(glob)) {
const fns = glob.map(input => picomatch(input, options, returnState));
const arrayMatcher = str => {
for (const isMatch of fns) {
const state = isMatch(str);
if (state) return state;
}
return false;
};
return arrayMatcher;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const isState = isObject(glob) && glob.tokens && glob.input;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (glob === '' || (typeof glob !== 'string' && !isState)) {
throw new TypeError('Expected pattern to be a non-empty string');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const opts = options || {};
const posix = utils.isWindows(options);
const regex = isState
? picomatch.compileRe(glob, options)
: picomatch.makeRe(glob, options, false, true);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const state = regex.state;
delete regex.state;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let isIgnored = () => false;
if (opts.ignore) {
const ignoreOpts = { ...options, ignore: null, onMatch: null, onResult: null };
isIgnored = picomatch(opts.ignore, ignoreOpts, returnState);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
const matcher = (input, returnObject = false) => {
const { isMatch, match, output } = picomatch.test(input, regex, options, { glob, posix });
const result = { glob, state, regex, posix, input, output, match, isMatch };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (typeof opts.onResult === 'function') {
opts.onResult(result);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (isMatch === false) {
result.isMatch = false;
return returnObject ? result : false;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (isIgnored(input)) {
if (typeof opts.onIgnore === 'function') {
opts.onIgnore(result);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
result.isMatch = false;
return returnObject ? result : false;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (typeof opts.onMatch === 'function') {
opts.onMatch(result);
}
return returnObject ? result : true;
};
if (returnState) {
matcher.state = state;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return matcher;
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Test `input` with the given `regex`. This is used by the main
* `picomatch()` function to test the input string.
*
* ```js
* const picomatch = require('picomatch');
* // picomatch.test(input, regex[, options]);
*
* console.log(picomatch.test('foo/bar', /^(?:([^/]*?)\/([^/]*?))$/));
* // { isMatch: true, match: [ 'foo/', 'foo', 'bar' ], output: 'foo/bar' }
* ```
* @param {String} `input` String to test.
* @param {RegExp} `regex`
* @return {Object} Returns an object with matching info.
* @api public
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
picomatch.test = (input, regex, options, { glob, posix } = {}) => {
if (typeof input !== 'string') {
throw new TypeError('Expected input to be a string');
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (input === '') {
return { isMatch: false, output: '' };
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
const opts = options || {};
const format = opts.format || (posix ? utils.toPosixSlashes : null);
let match = input === glob;
let output = (match && format) ? format(input) : input;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (match === false) {
output = format ? format(input) : input;
match = output === glob;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (match === false || opts.capture === true) {
if (opts.matchBase === true || opts.basename === true) {
match = picomatch.matchBase(input, regex, options, posix);
2021-09-26 15:31:45 -04:00
} else {
2022-05-31 14:18:28 -04:00
match = regex.exec(output);
2021-09-26 15:31:45 -04:00
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return { isMatch: Boolean(match), match, output };
2021-12-11 08:00:14 -05:00
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Match the basename of a filepath.
*
* ```js
* const picomatch = require('picomatch');
* // picomatch.matchBase(input, glob[, options]);
* console.log(picomatch.matchBase('foo/bar.js', '*.js'); // true
* ```
* @param {String} `input` String to test.
* @param {RegExp|String} `glob` Glob pattern or regex created by [.makeRe](#makeRe).
* @return {Boolean}
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
picomatch.matchBase = (input, glob, options, posix = utils.isWindows(options)) => {
const regex = glob instanceof RegExp ? glob : picomatch.makeRe(glob, options);
return regex.test(path.basename(input));
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Returns true if **any** of the given glob `patterns` match the specified `string`.
*
* ```js
* const picomatch = require('picomatch');
* // picomatch.isMatch(string, patterns[, options]);
*
* console.log(picomatch.isMatch('a.a', ['b.*', '*.a'])); //=> true
* console.log(picomatch.isMatch('a.a', 'b.*')); //=> false
* ```
* @param {String|Array} str The string to test.
* @param {String|Array} patterns One or more glob patterns to use for matching.
* @param {Object} [options] See available [options](#options).
* @return {Boolean} Returns true if any patterns match `str`
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
picomatch.isMatch = (str, patterns, options) => picomatch(patterns, options)(str);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Parse a glob pattern to create the source string for a regular
* expression.
*
* ```js
* const picomatch = require('picomatch');
* const result = picomatch.parse(pattern[, options]);
* ```
* @param {String} `pattern`
* @param {Object} `options`
* @return {Object} Returns an object with useful properties and output to be used as a regex source string.
* @api public
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
picomatch.parse = (pattern, options) => {
if (Array.isArray(pattern)) return pattern.map(p => picomatch.parse(p, options));
return parse(pattern, { ...options, fastpaths: false });
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Scan a glob pattern to separate the pattern into segments.
*
* ```js
* const picomatch = require('picomatch');
* // picomatch.scan(input[, options]);
*
* const result = picomatch.scan('!./foo/*.js');
* console.log(result);
* { prefix: '!./',
* input: '!./foo/*.js',
* start: 3,
* base: 'foo',
* glob: '*.js',
* isBrace: false,
* isBracket: false,
* isGlob: true,
* isExtglob: false,
* isGlobstar: false,
* negated: true }
* ```
* @param {String} `input` Glob pattern to scan.
* @param {Object} `options`
* @return {Object} Returns an object with
* @api public
*/
picomatch.scan = (input, options) => scan(input, options);
/**
* Compile a regular expression from the `state` object returned by the
* [parse()](#parse) method.
*
* @param {Object} `state`
* @param {Object} `options`
* @param {Boolean} `returnOutput` Intended for implementors, this argument allows you to return the raw output from the parser.
* @param {Boolean} `returnState` Adds the state to a `state` property on the returned regex. Useful for implementors and debugging.
* @return {RegExp}
* @api public
*/
picomatch.compileRe = (state, options, returnOutput = false, returnState = false) => {
if (returnOutput === true) {
return state.output;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
const opts = options || {};
const prepend = opts.contains ? '' : '^';
const append = opts.contains ? '' : '$';
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
let source = `${prepend}(?:${state.output})${append}`;
if (state && state.negated === true) {
source = `^(?!${source}).*$`;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const regex = picomatch.toRegex(source, options);
if (returnState === true) {
regex.state = state;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return regex;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Create a regular expression from a parsed glob pattern.
*
* ```js
* const picomatch = require('picomatch');
* const state = picomatch.parse('*.js');
* // picomatch.compileRe(state[, options]);
*
* console.log(picomatch.compileRe(state));
* //=> /^(?:(?!\.)(?=.)[^/]*?\.js)$/
* ```
* @param {String} `state` The object returned from the `.parse` method.
* @param {Object} `options`
* @param {Boolean} `returnOutput` Implementors may use this argument to return the compiled output, instead of a regular expression. This is not exposed on the options to prevent end-users from mutating the result.
* @param {Boolean} `returnState` Implementors may use this argument to return the state from the parsed glob with the returned regular expression.
* @return {RegExp} Returns a regex created from the given pattern.
* @api public
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
picomatch.makeRe = (input, options = {}, returnOutput = false, returnState = false) => {
if (!input || typeof input !== 'string') {
throw new TypeError('Expected a non-empty string');
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
let parsed = { negated: false, fastpaths: true };
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (options.fastpaths !== false && (input[0] === '.' || input[0] === '*')) {
parsed.output = parse.fastpaths(input, options);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (!parsed.output) {
parsed = parse(input, options);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return picomatch.compileRe(parsed, options, returnOutput, returnState);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Create a regular expression from the given regex source string.
*
* ```js
* const picomatch = require('picomatch');
* // picomatch.toRegex(source[, options]);
*
* const { output } = picomatch.parse('*.js');
* console.log(picomatch.toRegex(output));
* //=> /^(?:(?!\.)(?=.)[^/]*?\.js)$/
* ```
* @param {String} `source` Regular expression source string.
* @param {Object} `options`
* @return {RegExp}
* @api public
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
picomatch.toRegex = (source, options) => {
try {
const opts = options || {};
return new RegExp(source, opts.flags || (opts.nocase ? 'i' : ''));
} catch (err) {
if (options && options.debug === true) throw err;
return /$^/;
}
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Picomatch constants.
* @return {Object}
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
picomatch.constants = constants;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/**
* Expose "picomatch"
*/
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = picomatch;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 2429:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const utils = __nccwpck_require__(479);
const {
CHAR_ASTERISK, /* * */
CHAR_AT, /* @ */
CHAR_BACKWARD_SLASH, /* \ */
CHAR_COMMA, /* , */
CHAR_DOT, /* . */
CHAR_EXCLAMATION_MARK, /* ! */
CHAR_FORWARD_SLASH, /* / */
CHAR_LEFT_CURLY_BRACE, /* { */
CHAR_LEFT_PARENTHESES, /* ( */
CHAR_LEFT_SQUARE_BRACKET, /* [ */
CHAR_PLUS, /* + */
CHAR_QUESTION_MARK, /* ? */
CHAR_RIGHT_CURLY_BRACE, /* } */
CHAR_RIGHT_PARENTHESES, /* ) */
CHAR_RIGHT_SQUARE_BRACKET /* ] */
} = __nccwpck_require__(6099);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const isPathSeparator = code => {
return code === CHAR_FORWARD_SLASH || code === CHAR_BACKWARD_SLASH;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const depth = token => {
if (token.isPrefix !== true) {
token.depth = token.isGlobstar ? Infinity : 1;
}
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Quickly scans a glob pattern and returns an object with a handful of
* useful properties, like `isGlob`, `path` (the leading non-glob, if it exists),
* `glob` (the actual pattern), `negated` (true if the path starts with `!` but not
* with `!(`) and `negatedExtglob` (true if the path starts with `!(`).
*
* ```js
* const pm = require('picomatch');
* console.log(pm.scan('foo/bar/*.js'));
* { isGlob: true, input: 'foo/bar/*.js', base: 'foo/bar', glob: '*.js' }
* ```
* @param {String} `str`
* @param {Object} `options`
* @return {Object} Returns an object with tokens and regex source string.
* @api public
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const scan = (input, options) => {
const opts = options || {};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const length = input.length - 1;
const scanToEnd = opts.parts === true || opts.scanToEnd === true;
const slashes = [];
const tokens = [];
const parts = [];
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
let str = input;
let index = -1;
let start = 0;
let lastIndex = 0;
let isBrace = false;
let isBracket = false;
let isGlob = false;
let isExtglob = false;
let isGlobstar = false;
let braceEscaped = false;
let backslashes = false;
let negated = false;
let negatedExtglob = false;
let finished = false;
let braces = 0;
let prev;
let code;
let token = { value: '', depth: 0, isGlob: false };
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const eos = () => index >= length;
const peek = () => str.charCodeAt(index + 1);
const advance = () => {
prev = code;
return str.charCodeAt(++index);
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
while (index < length) {
code = advance();
let next;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (code === CHAR_BACKWARD_SLASH) {
backslashes = token.backslashes = true;
code = advance();
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (code === CHAR_LEFT_CURLY_BRACE) {
braceEscaped = true;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (braceEscaped === true || code === CHAR_LEFT_CURLY_BRACE) {
braces++;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
while (eos() !== true && (code = advance())) {
if (code === CHAR_BACKWARD_SLASH) {
backslashes = token.backslashes = true;
advance();
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (code === CHAR_LEFT_CURLY_BRACE) {
braces++;
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (braceEscaped !== true && code === CHAR_DOT && (code = advance()) === CHAR_DOT) {
isBrace = token.isBrace = true;
isGlob = token.isGlob = true;
finished = true;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (scanToEnd === true) {
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
break;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (braceEscaped !== true && code === CHAR_COMMA) {
isBrace = token.isBrace = true;
isGlob = token.isGlob = true;
finished = true;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (scanToEnd === true) {
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
break;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (code === CHAR_RIGHT_CURLY_BRACE) {
braces--;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (braces === 0) {
braceEscaped = false;
isBrace = token.isBrace = true;
finished = true;
break;
}
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (scanToEnd === true) {
continue;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
break;
}
if (code === CHAR_FORWARD_SLASH) {
slashes.push(index);
tokens.push(token);
token = { value: '', depth: 0, isGlob: false };
if (finished === true) continue;
if (prev === CHAR_DOT && index === (start + 1)) {
start += 2;
continue;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
lastIndex = index + 1;
continue;
}
if (opts.noext !== true) {
const isExtglobChar = code === CHAR_PLUS
|| code === CHAR_AT
|| code === CHAR_ASTERISK
|| code === CHAR_QUESTION_MARK
|| code === CHAR_EXCLAMATION_MARK;
if (isExtglobChar === true && peek() === CHAR_LEFT_PARENTHESES) {
isGlob = token.isGlob = true;
isExtglob = token.isExtglob = true;
finished = true;
if (code === CHAR_EXCLAMATION_MARK && index === start) {
negatedExtglob = true;
}
if (scanToEnd === true) {
while (eos() !== true && (code = advance())) {
if (code === CHAR_BACKWARD_SLASH) {
backslashes = token.backslashes = true;
code = advance();
continue;
}
if (code === CHAR_RIGHT_PARENTHESES) {
isGlob = token.isGlob = true;
finished = true;
break;
2021-12-11 08:00:14 -05:00
}
}
2022-05-31 14:18:28 -04:00
continue;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
break;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
if (code === CHAR_ASTERISK) {
if (prev === CHAR_ASTERISK) isGlobstar = token.isGlobstar = true;
isGlob = token.isGlob = true;
finished = true;
if (scanToEnd === true) {
continue;
}
break;
}
if (code === CHAR_QUESTION_MARK) {
isGlob = token.isGlob = true;
finished = true;
if (scanToEnd === true) {
continue;
}
break;
}
if (code === CHAR_LEFT_SQUARE_BRACKET) {
while (eos() !== true && (next = advance())) {
if (next === CHAR_BACKWARD_SLASH) {
backslashes = token.backslashes = true;
advance();
continue;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (next === CHAR_RIGHT_SQUARE_BRACKET) {
isBracket = token.isBracket = true;
isGlob = token.isGlob = true;
finished = true;
break;
2021-09-26 15:31:45 -04:00
}
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (scanToEnd === true) {
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
break;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (opts.nonegate !== true && code === CHAR_EXCLAMATION_MARK && index === start) {
negated = token.negated = true;
start++;
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (opts.noparen !== true && code === CHAR_LEFT_PARENTHESES) {
isGlob = token.isGlob = true;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (scanToEnd === true) {
while (eos() !== true && (code = advance())) {
if (code === CHAR_LEFT_PARENTHESES) {
backslashes = token.backslashes = true;
code = advance();
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (code === CHAR_RIGHT_PARENTHESES) {
finished = true;
break;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
continue;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
break;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (isGlob === true) {
finished = true;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (scanToEnd === true) {
continue;
}
break;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (opts.noext === true) {
isExtglob = false;
isGlob = false;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
let base = str;
let prefix = '';
let glob = '';
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (start > 0) {
prefix = str.slice(0, start);
str = str.slice(start);
lastIndex -= start;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (base && isGlob === true && lastIndex > 0) {
base = str.slice(0, lastIndex);
glob = str.slice(lastIndex);
} else if (isGlob === true) {
base = '';
glob = str;
} else {
base = str;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (base && base !== '' && base !== '/' && base !== str) {
if (isPathSeparator(base.charCodeAt(base.length - 1))) {
base = base.slice(0, -1);
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (opts.unescape === true) {
if (glob) glob = utils.removeBackslashes(glob);
if (base && backslashes === true) {
base = utils.removeBackslashes(base);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const state = {
prefix,
input,
start,
base,
glob,
isBrace,
isBracket,
isGlob,
isExtglob,
isGlobstar,
negated,
negatedExtglob
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (opts.tokens === true) {
state.maxDepth = 0;
if (!isPathSeparator(code)) {
tokens.push(token);
}
state.tokens = tokens;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (opts.parts === true || opts.tokens === true) {
let prevIndex;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
for (let idx = 0; idx < slashes.length; idx++) {
const n = prevIndex ? prevIndex + 1 : start;
const i = slashes[idx];
const value = input.slice(n, i);
if (opts.tokens) {
if (idx === 0 && start !== 0) {
tokens[idx].isPrefix = true;
tokens[idx].value = prefix;
2021-12-11 08:00:14 -05:00
} else {
2022-05-31 14:18:28 -04:00
tokens[idx].value = value;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
depth(tokens[idx]);
state.maxDepth += tokens[idx].depth;
}
if (idx !== 0 || value !== '') {
parts.push(value);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
prevIndex = i;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (prevIndex && prevIndex + 1 < input.length) {
const value = input.slice(prevIndex + 1);
parts.push(value);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (opts.tokens) {
tokens[tokens.length - 1].value = value;
depth(tokens[tokens.length - 1]);
state.maxDepth += tokens[tokens.length - 1].depth;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
state.slashes = slashes;
state.parts = parts;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return state;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
module.exports = scan;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/***/ 479:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const path = __nccwpck_require__(1017);
const win32 = process.platform === 'win32';
const {
REGEX_BACKSLASH,
REGEX_REMOVE_BACKSLASH,
REGEX_SPECIAL_CHARS,
REGEX_SPECIAL_CHARS_GLOBAL
} = __nccwpck_require__(6099);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
exports.isObject = val => val !== null && typeof val === 'object' && !Array.isArray(val);
exports.hasRegexChars = str => REGEX_SPECIAL_CHARS.test(str);
exports.isRegexChar = str => str.length === 1 && exports.hasRegexChars(str);
exports.escapeRegex = str => str.replace(REGEX_SPECIAL_CHARS_GLOBAL, '\\$1');
exports.toPosixSlashes = str => str.replace(REGEX_BACKSLASH, '/');
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
exports.removeBackslashes = str => {
return str.replace(REGEX_REMOVE_BACKSLASH, match => {
return match === '\\' ? '' : match;
});
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
exports.supportsLookbehinds = () => {
const segs = process.version.slice(1).split('.').map(Number);
if (segs.length === 3 && segs[0] >= 9 || (segs[0] === 8 && segs[1] >= 10)) {
return true;
}
return false;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
exports.isWindows = options => {
if (options && typeof options.windows === 'boolean') {
return options.windows;
}
return win32 === true || path.sep === '\\';
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
exports.escapeLast = (input, char, lastIdx) => {
const idx = input.lastIndexOf(char, lastIdx);
if (idx === -1) return input;
if (input[idx - 1] === '\\') return exports.escapeLast(input, char, idx - 1);
return `${input.slice(0, idx)}\\${input.slice(idx)}`;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
exports.removePrefix = (input, state = {}) => {
let output = input;
if (output.startsWith('./')) {
output = output.slice(2);
state.prefix = './';
}
return output;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
exports.wrapOutput = (input, state = {}, options = {}) => {
const prepend = options.contains ? '' : '^';
const append = options.contains ? '' : '$';
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
let output = `${prepend}(?:${input})${append}`;
if (state.negated === true) {
output = `(?:^(?!${output}).*$)`;
}
return output;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/***/ }),
/***/ 9795:
/***/ ((module) => {
/*! queue-microtask. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */
let promise
module.exports = typeof queueMicrotask === 'function'
? queueMicrotask.bind(typeof window !== 'undefined' ? window : global)
// reuse resolved promise, and allocate it lazily
: cb => (promise || (promise = Promise.resolve()))
.then(cb)
.catch(err => setTimeout(() => { throw err }, 0))
/***/ }),
/***/ 2113:
/***/ ((module) => {
"use strict";
function reusify (Constructor) {
var head = new Constructor()
var tail = head
function get () {
var current = head
if (current.next) {
head = current.next
} else {
head = new Constructor()
tail = head
2021-09-26 15:31:45 -04:00
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
current.next = null
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return current
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function release (obj) {
tail.next = obj
tail = obj
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return {
get: get,
release: release
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
module.exports = reusify
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 5288:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/*! run-parallel. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */
module.exports = runParallel
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const queueMicrotask = __nccwpck_require__(9795)
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function runParallel (tasks, cb) {
let results, pending, keys
let isSync = true
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (Array.isArray(tasks)) {
results = []
pending = tasks.length
} else {
keys = Object.keys(tasks)
results = {}
pending = keys.length
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function done (err) {
function end () {
if (cb) cb(err, results)
cb = null
}
if (isSync) queueMicrotask(end)
else end()
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function each (i, err, result) {
results[i] = result
if (--pending === 0 || err) {
done(err)
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (!pending) {
// empty
done(null)
} else if (keys) {
// object
keys.forEach(function (key) {
tasks[key](function (err, result) { each(key, err, result) })
})
} else {
// array
tasks.forEach(function (task, i) {
task(function (err, result) { each(i, err, result) })
})
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
isSync = false
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/***/ 1861:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
"use strict";
/*!
* to-regex-range <https://github.com/micromatch/to-regex-range>
*
* Copyright (c) 2015-present, Jon Schlinkert.
* Released under the MIT License.
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const isNumber = __nccwpck_require__(5680);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
const toRegexRange = (min, max, options) => {
if (isNumber(min) === false) {
throw new TypeError('toRegexRange: expected the first argument to be a number');
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (max === void 0 || min === max) {
return String(min);
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (isNumber(max) === false) {
throw new TypeError('toRegexRange: expected the second argument to be a number.');
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
let opts = { relaxZeros: true, ...options };
if (typeof opts.strictZeros === 'boolean') {
opts.relaxZeros = opts.strictZeros === false;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
let relax = String(opts.relaxZeros);
let shorthand = String(opts.shorthand);
let capture = String(opts.capture);
let wrap = String(opts.wrap);
let cacheKey = min + ':' + max + '=' + relax + shorthand + capture + wrap;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (toRegexRange.cache.hasOwnProperty(cacheKey)) {
return toRegexRange.cache[cacheKey].result;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
let a = Math.min(min, max);
let b = Math.max(min, max);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (Math.abs(a - b) === 1) {
let result = min + '|' + max;
if (opts.capture) {
return `(${result})`;
}
if (opts.wrap === false) {
return result;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
return `(?:${result})`;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
let isPadded = hasPadding(min) || hasPadding(max);
let state = { min, max, a, b };
let positives = [];
let negatives = [];
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (isPadded) {
state.isPadded = isPadded;
state.maxLen = String(state.max).length;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (a < 0) {
let newMin = b < 0 ? Math.abs(b) : 1;
negatives = splitToPatterns(newMin, Math.abs(a), state, opts);
a = state.a = 0;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (b >= 0) {
positives = splitToPatterns(a, b, state, opts);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
state.negatives = negatives;
state.positives = positives;
state.result = collatePatterns(negatives, positives, opts);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (opts.capture === true) {
state.result = `(${state.result})`;
} else if (opts.wrap !== false && (positives.length + negatives.length) > 1) {
state.result = `(?:${state.result})`;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
toRegexRange.cache[cacheKey] = state;
return state.result;
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function collatePatterns(neg, pos, options) {
let onlyNegative = filterPatterns(neg, pos, '-', false, options) || [];
let onlyPositive = filterPatterns(pos, neg, '', false, options) || [];
let intersected = filterPatterns(neg, pos, '-?', true, options) || [];
let subpatterns = onlyNegative.concat(intersected).concat(onlyPositive);
return subpatterns.join('|');
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function splitToRanges(min, max) {
let nines = 1;
let zeros = 1;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
let stop = countNines(min, nines);
let stops = new Set([max]);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
while (min <= stop && stop <= max) {
stops.add(stop);
nines += 1;
stop = countNines(min, nines);
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
stop = countZeros(max + 1, zeros) - 1;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
while (min < stop && stop <= max) {
stops.add(stop);
zeros += 1;
stop = countZeros(max + 1, zeros) - 1;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
stops = [...stops];
stops.sort(compare);
return stops;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Convert a range to a regex pattern
* @param {Number} `start`
* @param {Number} `stop`
* @return {String}
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function rangeToPattern(start, stop, options) {
if (start === stop) {
return { pattern: start, count: [], digits: 0 };
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
let zipped = zip(start, stop);
let digits = zipped.length;
let pattern = '';
let count = 0;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
for (let i = 0; i < digits; i++) {
let [startDigit, stopDigit] = zipped[i];
if (startDigit === stopDigit) {
pattern += startDigit;
} else if (startDigit !== '0' || stopDigit !== '9') {
pattern += toCharacterClass(startDigit, stopDigit, options);
} else {
count++;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (count) {
pattern += options.shorthand === true ? '\\d' : '[0-9]';
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return { pattern, count: [count], digits };
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function splitToPatterns(min, max, tok, options) {
let ranges = splitToRanges(min, max);
let tokens = [];
let start = min;
let prev;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
for (let i = 0; i < ranges.length; i++) {
let max = ranges[i];
let obj = rangeToPattern(String(start), String(max), options);
let zeros = '';
if (!tok.isPadded && prev && prev.pattern === obj.pattern) {
if (prev.count.length > 1) {
prev.count.pop();
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
prev.count.push(obj.count[0]);
prev.string = prev.pattern + toQuantifier(prev.count);
start = max + 1;
continue;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (tok.isPadded) {
zeros = padZeros(max, tok, options);
2021-09-26 15:31:45 -04:00
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
obj.string = zeros + obj.pattern + toQuantifier(obj.count);
tokens.push(obj);
start = max + 1;
prev = obj;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return tokens;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function filterPatterns(arr, comparison, prefix, intersection, options) {
let result = [];
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
for (let ele of arr) {
let { string } = ele;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
// only push if _both_ are negative...
if (!intersection && !contains(comparison, 'string', string)) {
result.push(prefix + string);
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
// or _both_ are positive
if (intersection && contains(comparison, 'string', string)) {
result.push(prefix + string);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
return result;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Zip strings
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function zip(a, b) {
let arr = [];
for (let i = 0; i < a.length; i++) arr.push([a[i], b[i]]);
return arr;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function compare(a, b) {
return a > b ? 1 : b > a ? -1 : 0;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function contains(arr, key, val) {
return arr.some(ele => ele[key] === val);
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function countNines(min, len) {
return Number(String(min).slice(0, -len) + '9'.repeat(len));
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function countZeros(integer, zeros) {
return integer - (integer % Math.pow(10, zeros));
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function toQuantifier(digits) {
let [start = 0, stop = ''] = digits;
if (stop || start > 1) {
return `{${start + (stop ? ',' + stop : '')}}`;
}
return '';
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function toCharacterClass(a, b, options) {
return `[${a}${(b - a === 1) ? '' : '-'}${b}]`;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function hasPadding(str) {
return /^-?(0+)\d/.test(str);
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function padZeros(value, tok, options) {
if (!tok.isPadded) {
return value;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
let diff = Math.abs(tok.maxLen - String(value).length);
let relax = options.relaxZeros !== false;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
switch (diff) {
case 0:
return '';
case 1:
return relax ? '0?' : '0';
case 2:
return relax ? '0{0,2}' : '00';
default: {
return relax ? `0{0,${diff}}` : `0{${diff}}`;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Cache
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
toRegexRange.cache = {};
toRegexRange.clearCache = () => (toRegexRange.cache = {});
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/**
* Expose `toRegexRange`
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
module.exports = toRegexRange;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/***/ 4920:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
var parser = __nccwpck_require__(5642);
var compiler = __nccwpck_require__(8215);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
module.exports = {
parse: function(input) {
var nodes = parser.parse(input.toString());
return compiler.compile(nodes);
}
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/***/ }),
/***/ 8215:
/***/ ((module) => {
"use strict";
function compile(nodes) {
var assignedPaths = [];
var valueAssignments = [];
var currentPath = "";
var data = Object.create(null);
var context = data;
var arrayMode = false;
return reduce(nodes);
function reduce(nodes) {
var node;
for (var i = 0; i < nodes.length; i++) {
node = nodes[i];
switch (node.type) {
case "Assign":
assign(node);
break;
case "ObjectPath":
setPath(node);
break;
case "ArrayPath":
addTableArray(node);
break;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return data;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function genError(err, line, col) {
var ex = new Error(err);
ex.line = line;
ex.column = col;
throw ex;
}
function assign(node) {
var key = node.key;
var value = node.value;
var line = node.line;
var column = node.column;
var fullPath;
if (currentPath) {
fullPath = currentPath + "." + key;
} else {
fullPath = key;
}
if (typeof context[key] !== "undefined") {
genError("Cannot redefine existing key '" + fullPath + "'.", line, column);
2021-09-26 15:31:45 -04:00
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
context[key] = reduceValueNode(value);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (!pathAssigned(fullPath)) {
assignedPaths.push(fullPath);
valueAssignments.push(fullPath);
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function pathAssigned(path) {
return assignedPaths.indexOf(path) !== -1;
}
function reduceValueNode(node) {
if (node.type === "Array") {
return reduceArrayWithTypeChecking(node.value);
} else if (node.type === "InlineTable") {
return reduceInlineTableNode(node.value);
} else {
return node.value;
}
}
function reduceInlineTableNode(values) {
var obj = Object.create(null);
for (var i = 0; i < values.length; i++) {
var val = values[i];
if (val.value.type === "InlineTable") {
obj[val.key] = reduceInlineTableNode(val.value.value);
} else if (val.type === "InlineTableValue") {
obj[val.key] = reduceValueNode(val.value);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return obj;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function setPath(node) {
var path = node.value;
var quotedPath = path.map(quoteDottedString).join(".");
var line = node.line;
var column = node.column;
if (pathAssigned(quotedPath)) {
genError("Cannot redefine existing key '" + path + "'.", line, column);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
assignedPaths.push(quotedPath);
context = deepRef(data, path, Object.create(null), line, column);
currentPath = path;
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function addTableArray(node) {
var path = node.value;
var quotedPath = path.map(quoteDottedString).join(".");
var line = node.line;
var column = node.column;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (!pathAssigned(quotedPath)) {
assignedPaths.push(quotedPath);
}
assignedPaths = assignedPaths.filter(function(p) {
return p.indexOf(quotedPath) !== 0;
});
assignedPaths.push(quotedPath);
context = deepRef(data, path, [], line, column);
currentPath = quotedPath;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (context instanceof Array) {
var newObj = Object.create(null);
context.push(newObj);
context = newObj;
} else {
genError("Cannot redefine existing key '" + path + "'.", line, column);
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
// Given a path 'a.b.c', create (as necessary) `start.a`,
// `start.a.b`, and `start.a.b.c`, assigning `value` to `start.a.b.c`.
// If `a` or `b` are arrays and have items in them, the last item in the
// array is used as the context for the next sub-path.
function deepRef(start, keys, value, line, column) {
var traversed = [];
var traversedPath = "";
var path = keys.join(".");
var ctx = start;
for (var i = 0; i < keys.length; i++) {
var key = keys[i];
traversed.push(key);
traversedPath = traversed.join(".");
if (typeof ctx[key] === "undefined") {
if (i === keys.length - 1) {
ctx[key] = value;
2021-12-11 08:00:14 -05:00
} else {
2022-05-31 14:18:28 -04:00
ctx[key] = Object.create(null);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
} else if (i !== keys.length - 1 && valueAssignments.indexOf(traversedPath) > -1) {
// already a non-object value at key, can't be used as part of a new path
genError("Cannot redefine existing key '" + traversedPath + "'.", line, column);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
ctx = ctx[key];
if (ctx instanceof Array && ctx.length && i < keys.length - 1) {
ctx = ctx[ctx.length - 1];
}
}
return ctx;
}
function reduceArrayWithTypeChecking(array) {
// Ensure that all items in the array are of the same type
var firstType = null;
for (var i = 0; i < array.length; i++) {
var node = array[i];
if (firstType === null) {
firstType = node.type;
} else {
if (node.type !== firstType) {
genError("Cannot add value of type " + node.type + " to array of type " +
firstType + ".", node.line, node.column);
2021-09-26 15:31:45 -04:00
}
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
// Recursively reduce array of nodes into array of the nodes' values
return array.map(reduceValueNode);
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function quoteDottedString(str) {
if (str.indexOf(".") > -1) {
return "\"" + str + "\"";
} else {
return str;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
module.exports = {
compile: compile
};
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
/***/ 5642:
/***/ ((module) => {
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
module.exports = (function() {
/*
* Generated by PEG.js 0.8.0.
*
* http://pegjs.majda.cz/
*/
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function peg$subclass(child, parent) {
function ctor() { this.constructor = child; }
ctor.prototype = parent.prototype;
child.prototype = new ctor();
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function SyntaxError(message, expected, found, offset, line, column) {
this.message = message;
this.expected = expected;
this.found = found;
this.offset = offset;
this.line = line;
this.column = column;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
this.name = "SyntaxError";
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
peg$subclass(SyntaxError, Error);
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function parse(input) {
var options = arguments.length > 1 ? arguments[1] : {},
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
peg$FAILED = {},
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
peg$startRuleFunctions = { start: peg$parsestart },
peg$startRuleFunction = peg$parsestart,
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
peg$c0 = [],
peg$c1 = function() { return nodes },
peg$c2 = peg$FAILED,
peg$c3 = "#",
peg$c4 = { type: "literal", value: "#", description: "\"#\"" },
peg$c5 = void 0,
peg$c6 = { type: "any", description: "any character" },
peg$c7 = "[",
peg$c8 = { type: "literal", value: "[", description: "\"[\"" },
peg$c9 = "]",
peg$c10 = { type: "literal", value: "]", description: "\"]\"" },
peg$c11 = function(name) { addNode(node('ObjectPath', name, line, column)) },
peg$c12 = function(name) { addNode(node('ArrayPath', name, line, column)) },
peg$c13 = function(parts, name) { return parts.concat(name) },
peg$c14 = function(name) { return [name] },
peg$c15 = function(name) { return name },
peg$c16 = ".",
peg$c17 = { type: "literal", value: ".", description: "\".\"" },
peg$c18 = "=",
peg$c19 = { type: "literal", value: "=", description: "\"=\"" },
peg$c20 = function(key, value) { addNode(node('Assign', value, line, column, key)) },
peg$c21 = function(chars) { return chars.join('') },
peg$c22 = function(node) { return node.value },
peg$c23 = "\"\"\"",
peg$c24 = { type: "literal", value: "\"\"\"", description: "\"\\\"\\\"\\\"\"" },
peg$c25 = null,
peg$c26 = function(chars) { return node('String', chars.join(''), line, column) },
peg$c27 = "\"",
peg$c28 = { type: "literal", value: "\"", description: "\"\\\"\"" },
peg$c29 = "'''",
peg$c30 = { type: "literal", value: "'''", description: "\"'''\"" },
peg$c31 = "'",
peg$c32 = { type: "literal", value: "'", description: "\"'\"" },
peg$c33 = function(char) { return char },
peg$c34 = function(char) { return char},
peg$c35 = "\\",
peg$c36 = { type: "literal", value: "\\", description: "\"\\\\\"" },
peg$c37 = function() { return '' },
peg$c38 = "e",
peg$c39 = { type: "literal", value: "e", description: "\"e\"" },
peg$c40 = "E",
peg$c41 = { type: "literal", value: "E", description: "\"E\"" },
peg$c42 = function(left, right) { return node('Float', parseFloat(left + 'e' + right), line, column) },
peg$c43 = function(text) { return node('Float', parseFloat(text), line, column) },
peg$c44 = "+",
peg$c45 = { type: "literal", value: "+", description: "\"+\"" },
peg$c46 = function(digits) { return digits.join('') },
peg$c47 = "-",
peg$c48 = { type: "literal", value: "-", description: "\"-\"" },
peg$c49 = function(digits) { return '-' + digits.join('') },
peg$c50 = function(text) { return node('Integer', parseInt(text, 10), line, column) },
peg$c51 = "true",
peg$c52 = { type: "literal", value: "true", description: "\"true\"" },
peg$c53 = function() { return node('Boolean', true, line, column) },
peg$c54 = "false",
peg$c55 = { type: "literal", value: "false", description: "\"false\"" },
peg$c56 = function() { return node('Boolean', false, line, column) },
peg$c57 = function() { return node('Array', [], line, column) },
peg$c58 = function(value) { return node('Array', value ? [value] : [], line, column) },
peg$c59 = function(values) { return node('Array', values, line, column) },
peg$c60 = function(values, value) { return node('Array', values.concat(value), line, column) },
peg$c61 = function(value) { return value },
peg$c62 = ",",
peg$c63 = { type: "literal", value: ",", description: "\",\"" },
peg$c64 = "{",
peg$c65 = { type: "literal", value: "{", description: "\"{\"" },
peg$c66 = "}",
peg$c67 = { type: "literal", value: "}", description: "\"}\"" },
peg$c68 = function(values) { return node('InlineTable', values, line, column) },
peg$c69 = function(key, value) { return node('InlineTableValue', value, line, column, key) },
peg$c70 = function(digits) { return "." + digits },
peg$c71 = function(date) { return date.join('') },
peg$c72 = ":",
peg$c73 = { type: "literal", value: ":", description: "\":\"" },
peg$c74 = function(time) { return time.join('') },
peg$c75 = "T",
peg$c76 = { type: "literal", value: "T", description: "\"T\"" },
peg$c77 = "Z",
peg$c78 = { type: "literal", value: "Z", description: "\"Z\"" },
peg$c79 = function(date, time) { return node('Date', new Date(date + "T" + time + "Z"), line, column) },
peg$c80 = function(date, time) { return node('Date', new Date(date + "T" + time), line, column) },
peg$c81 = /^[ \t]/,
peg$c82 = { type: "class", value: "[ \\t]", description: "[ \\t]" },
peg$c83 = "\n",
peg$c84 = { type: "literal", value: "\n", description: "\"\\n\"" },
peg$c85 = "\r",
peg$c86 = { type: "literal", value: "\r", description: "\"\\r\"" },
peg$c87 = /^[0-9a-f]/i,
peg$c88 = { type: "class", value: "[0-9a-f]i", description: "[0-9a-f]i" },
peg$c89 = /^[0-9]/,
peg$c90 = { type: "class", value: "[0-9]", description: "[0-9]" },
peg$c91 = "_",
peg$c92 = { type: "literal", value: "_", description: "\"_\"" },
peg$c93 = function() { return "" },
peg$c94 = /^[A-Za-z0-9_\-]/,
peg$c95 = { type: "class", value: "[A-Za-z0-9_\\-]", description: "[A-Za-z0-9_\\-]" },
peg$c96 = function(d) { return d.join('') },
peg$c97 = "\\\"",
peg$c98 = { type: "literal", value: "\\\"", description: "\"\\\\\\\"\"" },
peg$c99 = function() { return '"' },
peg$c100 = "\\\\",
peg$c101 = { type: "literal", value: "\\\\", description: "\"\\\\\\\\\"" },
peg$c102 = function() { return '\\' },
peg$c103 = "\\b",
peg$c104 = { type: "literal", value: "\\b", description: "\"\\\\b\"" },
peg$c105 = function() { return '\b' },
peg$c106 = "\\t",
peg$c107 = { type: "literal", value: "\\t", description: "\"\\\\t\"" },
peg$c108 = function() { return '\t' },
peg$c109 = "\\n",
peg$c110 = { type: "literal", value: "\\n", description: "\"\\\\n\"" },
peg$c111 = function() { return '\n' },
peg$c112 = "\\f",
peg$c113 = { type: "literal", value: "\\f", description: "\"\\\\f\"" },
peg$c114 = function() { return '\f' },
peg$c115 = "\\r",
peg$c116 = { type: "literal", value: "\\r", description: "\"\\\\r\"" },
peg$c117 = function() { return '\r' },
peg$c118 = "\\U",
peg$c119 = { type: "literal", value: "\\U", description: "\"\\\\U\"" },
peg$c120 = function(digits) { return convertCodePoint(digits.join('')) },
peg$c121 = "\\u",
peg$c122 = { type: "literal", value: "\\u", description: "\"\\\\u\"" },
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
peg$currPos = 0,
peg$reportedPos = 0,
peg$cachedPos = 0,
peg$cachedPosDetails = { line: 1, column: 1, seenCR: false },
peg$maxFailPos = 0,
peg$maxFailExpected = [],
peg$silentFails = 0,
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
peg$cache = {},
peg$result;
if ("startRule" in options) {
if (!(options.startRule in peg$startRuleFunctions)) {
throw new Error("Can't start parsing from rule \"" + options.startRule + "\".");
}
peg$startRuleFunction = peg$startRuleFunctions[options.startRule];
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function text() {
return input.substring(peg$reportedPos, peg$currPos);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function offset() {
return peg$reportedPos;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function line() {
return peg$computePosDetails(peg$reportedPos).line;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function column() {
return peg$computePosDetails(peg$reportedPos).column;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function expected(description) {
throw peg$buildException(
null,
[{ type: "other", description: description }],
peg$reportedPos
);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function error(message) {
throw peg$buildException(message, null, peg$reportedPos);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function peg$computePosDetails(pos) {
function advance(details, startPos, endPos) {
var p, ch;
for (p = startPos; p < endPos; p++) {
ch = input.charAt(p);
if (ch === "\n") {
if (!details.seenCR) { details.line++; }
details.column = 1;
details.seenCR = false;
} else if (ch === "\r" || ch === "\u2028" || ch === "\u2029") {
details.line++;
details.column = 1;
details.seenCR = true;
} else {
details.column++;
details.seenCR = false;
}
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
if (peg$cachedPos !== pos) {
if (peg$cachedPos > pos) {
peg$cachedPos = 0;
peg$cachedPosDetails = { line: 1, column: 1, seenCR: false };
}
advance(peg$cachedPosDetails, peg$cachedPos, pos);
peg$cachedPos = pos;
}
return peg$cachedPosDetails;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function peg$fail(expected) {
if (peg$currPos < peg$maxFailPos) { return; }
if (peg$currPos > peg$maxFailPos) {
peg$maxFailPos = peg$currPos;
peg$maxFailExpected = [];
}
peg$maxFailExpected.push(expected);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function peg$buildException(message, expected, pos) {
function cleanupExpected(expected) {
var i = 1;
expected.sort(function(a, b) {
if (a.description < b.description) {
return -1;
} else if (a.description > b.description) {
return 1;
} else {
return 0;
}
2021-12-11 08:00:14 -05:00
});
2022-05-31 14:18:28 -04:00
while (i < expected.length) {
if (expected[i - 1] === expected[i]) {
expected.splice(i, 1);
} else {
i++;
}
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
function buildMessage(expected, found) {
function stringEscape(s) {
function hex(ch) { return ch.charCodeAt(0).toString(16).toUpperCase(); }
return s
.replace(/\\/g, '\\\\')
.replace(/"/g, '\\"')
.replace(/\x08/g, '\\b')
.replace(/\t/g, '\\t')
.replace(/\n/g, '\\n')
.replace(/\f/g, '\\f')
.replace(/\r/g, '\\r')
.replace(/[\x00-\x07\x0B\x0E\x0F]/g, function(ch) { return '\\x0' + hex(ch); })
.replace(/[\x10-\x1F\x80-\xFF]/g, function(ch) { return '\\x' + hex(ch); })
.replace(/[\u0180-\u0FFF]/g, function(ch) { return '\\u0' + hex(ch); })
.replace(/[\u1080-\uFFFF]/g, function(ch) { return '\\u' + hex(ch); });
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
var expectedDescs = new Array(expected.length),
expectedDesc, foundDesc, i;
for (i = 0; i < expected.length; i++) {
expectedDescs[i] = expected[i].description;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
expectedDesc = expected.length > 1
? expectedDescs.slice(0, -1).join(", ")
+ " or "
+ expectedDescs[expected.length - 1]
: expectedDescs[0];
foundDesc = found ? "\"" + stringEscape(found) + "\"" : "end of input";
return "Expected " + expectedDesc + " but " + foundDesc + " found.";
}
var posDetails = peg$computePosDetails(pos),
found = pos < input.length ? input.charAt(pos) : null;
if (expected !== null) {
cleanupExpected(expected);
}
return new SyntaxError(
message !== null ? message : buildMessage(expected, found),
expected,
found,
pos,
posDetails.line,
posDetails.column
);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function peg$parsestart() {
var s0, s1, s2;
var key = peg$currPos * 49 + 0,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
s1 = [];
s2 = peg$parseline();
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parseline();
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c1();
}
s0 = s1;
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return s0;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function peg$parseline() {
var s0, s1, s2, s3, s4, s5, s6;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 1,
cached = peg$cache[key];
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
s1 = [];
s2 = peg$parseS();
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parseS();
}
if (s1 !== peg$FAILED) {
s2 = peg$parseexpression();
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parseS();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parseS();
}
if (s3 !== peg$FAILED) {
s4 = [];
s5 = peg$parsecomment();
while (s5 !== peg$FAILED) {
s4.push(s5);
s5 = peg$parsecomment();
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s4 !== peg$FAILED) {
s5 = [];
s6 = peg$parseNL();
if (s6 !== peg$FAILED) {
while (s6 !== peg$FAILED) {
s5.push(s6);
s6 = peg$parseNL();
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
s5 = peg$c2;
}
if (s5 === peg$FAILED) {
s5 = peg$parseEOF();
}
if (s5 !== peg$FAILED) {
s1 = [s1, s2, s3, s4, s5];
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
s1 = [];
s2 = peg$parseS();
if (s2 !== peg$FAILED) {
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parseS();
}
} else {
s1 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$parseNL();
if (s3 !== peg$FAILED) {
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$parseNL();
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
s2 = peg$c2;
}
if (s2 === peg$FAILED) {
s2 = peg$parseEOF();
}
if (s2 !== peg$FAILED) {
s1 = [s1, s2];
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s0 === peg$FAILED) {
s0 = peg$parseNL();
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function peg$parseexpression() {
var s0;
var key = peg$currPos * 49 + 2,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$parsecomment();
if (s0 === peg$FAILED) {
s0 = peg$parsepath();
if (s0 === peg$FAILED) {
s0 = peg$parsetablearray();
if (s0 === peg$FAILED) {
s0 = peg$parseassignment();
}
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function peg$parsecomment() {
var s0, s1, s2, s3, s4, s5;
var key = peg$currPos * 49 + 3,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 35) {
s1 = peg$c3;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c4); }
}
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$currPos;
s4 = peg$currPos;
peg$silentFails++;
s5 = peg$parseNL();
if (s5 === peg$FAILED) {
s5 = peg$parseEOF();
}
peg$silentFails--;
if (s5 === peg$FAILED) {
s4 = peg$c5;
} else {
peg$currPos = s4;
s4 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s4 !== peg$FAILED) {
if (input.length > peg$currPos) {
s5 = input.charAt(peg$currPos);
peg$currPos++;
} else {
s5 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c6); }
}
if (s5 !== peg$FAILED) {
s4 = [s4, s5];
s3 = s4;
} else {
peg$currPos = s3;
s3 = peg$c2;
}
} else {
peg$currPos = s3;
s3 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$currPos;
s4 = peg$currPos;
peg$silentFails++;
s5 = peg$parseNL();
if (s5 === peg$FAILED) {
s5 = peg$parseEOF();
}
peg$silentFails--;
if (s5 === peg$FAILED) {
s4 = peg$c5;
} else {
peg$currPos = s4;
s4 = peg$c2;
}
if (s4 !== peg$FAILED) {
if (input.length > peg$currPos) {
s5 = input.charAt(peg$currPos);
peg$currPos++;
} else {
s5 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c6); }
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s5 !== peg$FAILED) {
s4 = [s4, s5];
s3 = s4;
} else {
peg$currPos = s3;
s3 = peg$c2;
}
} else {
peg$currPos = s3;
s3 = peg$c2;
}
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s2 !== peg$FAILED) {
s1 = [s1, s2];
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-12-11 08:00:14 -05:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsepath() {
var s0, s1, s2, s3, s4, s5;
var key = peg$currPos * 49 + 4,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 91) {
s1 = peg$c7;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c8); }
}
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$parseS();
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$parseS();
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s2 !== peg$FAILED) {
s3 = peg$parsetable_key();
if (s3 !== peg$FAILED) {
s4 = [];
s5 = peg$parseS();
while (s5 !== peg$FAILED) {
s4.push(s5);
s5 = peg$parseS();
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s4 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 93) {
s5 = peg$c9;
peg$currPos++;
} else {
s5 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c10); }
}
if (s5 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c11(s3);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function peg$parsetablearray() {
var s0, s1, s2, s3, s4, s5, s6, s7;
var key = peg$currPos * 49 + 5,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 91) {
s1 = peg$c7;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c8); }
}
if (s1 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 91) {
s2 = peg$c7;
peg$currPos++;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c8); }
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parseS();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parseS();
}
if (s3 !== peg$FAILED) {
s4 = peg$parsetable_key();
if (s4 !== peg$FAILED) {
s5 = [];
s6 = peg$parseS();
while (s6 !== peg$FAILED) {
s5.push(s6);
s6 = peg$parseS();
}
if (s5 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 93) {
s6 = peg$c9;
peg$currPos++;
} else {
s6 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c10); }
}
if (s6 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 93) {
s7 = peg$c9;
peg$currPos++;
} else {
s7 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c10); }
}
if (s7 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c12(s4);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function peg$parsetable_key() {
var s0, s1, s2;
var key = peg$currPos * 49 + 6,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
s1 = [];
s2 = peg$parsedot_ended_table_key_part();
if (s2 !== peg$FAILED) {
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parsedot_ended_table_key_part();
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
s1 = peg$c2;
}
if (s1 !== peg$FAILED) {
s2 = peg$parsetable_key_part();
if (s2 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c13(s1, s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
s1 = peg$parsetable_key_part();
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c14(s1);
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
s0 = s1;
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function peg$parsetable_key_part() {
var s0, s1, s2, s3, s4;
var key = peg$currPos * 49 + 7,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
s1 = [];
s2 = peg$parseS();
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parseS();
}
if (s1 !== peg$FAILED) {
s2 = peg$parsekey();
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parseS();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parseS();
}
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c15(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
s1 = [];
s2 = peg$parseS();
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parseS();
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s1 !== peg$FAILED) {
s2 = peg$parsequoted_key();
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parseS();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parseS();
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c15(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function peg$parsedot_ended_table_key_part() {
var s0, s1, s2, s3, s4, s5, s6;
var key = peg$currPos * 49 + 8,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
s1 = [];
s2 = peg$parseS();
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parseS();
}
if (s1 !== peg$FAILED) {
s2 = peg$parsekey();
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parseS();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parseS();
}
if (s3 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 46) {
s4 = peg$c16;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c17); }
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s4 !== peg$FAILED) {
s5 = [];
s6 = peg$parseS();
while (s6 !== peg$FAILED) {
s5.push(s6);
s6 = peg$parseS();
}
if (s5 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c15(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
s1 = [];
s2 = peg$parseS();
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parseS();
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s1 !== peg$FAILED) {
s2 = peg$parsequoted_key();
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parseS();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parseS();
}
if (s3 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 46) {
s4 = peg$c16;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c17); }
}
if (s4 !== peg$FAILED) {
s5 = [];
s6 = peg$parseS();
while (s6 !== peg$FAILED) {
s5.push(s6);
s6 = peg$parseS();
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
if (s5 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c15(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
return s0;
2021-12-11 08:00:14 -05:00
}
2022-05-31 14:18:28 -04:00
function peg$parseassignment() {
var s0, s1, s2, s3, s4, s5;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 9,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
s1 = peg$parsekey();
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$parseS();
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$parseS();
}
if (s2 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 61) {
s3 = peg$c18;
peg$currPos++;
} else {
s3 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c19); }
}
if (s3 !== peg$FAILED) {
s4 = [];
s5 = peg$parseS();
while (s5 !== peg$FAILED) {
s4.push(s5);
s5 = peg$parseS();
}
if (s4 !== peg$FAILED) {
s5 = peg$parsevalue();
if (s5 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c20(s1, s5);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
s1 = peg$parsequoted_key();
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$parseS();
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$parseS();
}
if (s2 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 61) {
s3 = peg$c18;
peg$currPos++;
} else {
s3 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c19); }
}
if (s3 !== peg$FAILED) {
s4 = [];
s5 = peg$parseS();
while (s5 !== peg$FAILED) {
s4.push(s5);
s5 = peg$parseS();
}
if (s4 !== peg$FAILED) {
s5 = peg$parsevalue();
if (s5 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c20(s1, s5);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-09-26 15:31:45 -04:00
}
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
function peg$parsekey() {
var s0, s1, s2;
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 10,
cached = peg$cache[key];
2021-12-11 08:00:14 -05:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
s1 = [];
s2 = peg$parseASCII_BASIC();
if (s2 !== peg$FAILED) {
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parseASCII_BASIC();
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
} else {
s1 = peg$c2;
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c21(s1);
}
s0 = s1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-10-01 09:38:36 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-10-01 09:38:36 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsequoted_key() {
var s0, s1;
2021-10-01 09:38:36 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 11,
cached = peg$cache[key];
2021-10-01 09:38:36 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-10-01 09:38:36 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
s1 = peg$parsedouble_quoted_single_line_string();
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c22(s1);
}
s0 = s1;
if (s0 === peg$FAILED) {
s0 = peg$currPos;
s1 = peg$parsesingle_quoted_single_line_string();
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c22(s1);
2021-10-01 09:38:36 -04:00
}
2022-05-31 14:18:28 -04:00
s0 = s1;
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-10-01 09:38:36 -04:00
}
2022-05-31 14:18:28 -04:00
function peg$parsevalue() {
var s0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 12,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$parsestring();
if (s0 === peg$FAILED) {
s0 = peg$parsedatetime();
if (s0 === peg$FAILED) {
s0 = peg$parsefloat();
if (s0 === peg$FAILED) {
s0 = peg$parseinteger();
if (s0 === peg$FAILED) {
s0 = peg$parseboolean();
if (s0 === peg$FAILED) {
s0 = peg$parsearray();
if (s0 === peg$FAILED) {
s0 = peg$parseinline_table();
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsestring() {
var s0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 13,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$parsedouble_quoted_multiline_string();
if (s0 === peg$FAILED) {
s0 = peg$parsedouble_quoted_single_line_string();
if (s0 === peg$FAILED) {
s0 = peg$parsesingle_quoted_multiline_string();
if (s0 === peg$FAILED) {
s0 = peg$parsesingle_quoted_single_line_string();
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function peg$parsedouble_quoted_multiline_string() {
var s0, s1, s2, s3, s4;
var key = peg$currPos * 49 + 14,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
if (input.substr(peg$currPos, 3) === peg$c23) {
s1 = peg$c23;
peg$currPos += 3;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c24); }
}
if (s1 !== peg$FAILED) {
s2 = peg$parseNL();
if (s2 === peg$FAILED) {
s2 = peg$c25;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parsemultiline_string_char();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parsemultiline_string_char();
}
if (s3 !== peg$FAILED) {
if (input.substr(peg$currPos, 3) === peg$c23) {
s4 = peg$c23;
peg$currPos += 3;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c24); }
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (s4 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c26(s3);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function peg$parsedouble_quoted_single_line_string() {
var s0, s1, s2, s3;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 15,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 34) {
s1 = peg$c27;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c28); }
}
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$parsestring_char();
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$parsestring_char();
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (s2 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 34) {
s3 = peg$c27;
peg$currPos++;
} else {
s3 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c28); }
}
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c26(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function peg$parsesingle_quoted_multiline_string() {
var s0, s1, s2, s3, s4;
var key = peg$currPos * 49 + 16,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
if (input.substr(peg$currPos, 3) === peg$c29) {
s1 = peg$c29;
peg$currPos += 3;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c30); }
}
if (s1 !== peg$FAILED) {
s2 = peg$parseNL();
if (s2 === peg$FAILED) {
s2 = peg$c25;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parsemultiline_literal_char();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parsemultiline_literal_char();
}
if (s3 !== peg$FAILED) {
if (input.substr(peg$currPos, 3) === peg$c29) {
s4 = peg$c29;
peg$currPos += 3;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c30); }
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (s4 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c26(s3);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function peg$parsesingle_quoted_single_line_string() {
var s0, s1, s2, s3;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 17,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 39) {
s1 = peg$c31;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c32); }
}
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$parseliteral_char();
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$parseliteral_char();
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (s2 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 39) {
s3 = peg$c31;
peg$currPos++;
} else {
s3 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c32); }
}
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c26(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function peg$parsestring_char() {
var s0, s1, s2;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 18,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$parseESCAPED();
if (s0 === peg$FAILED) {
s0 = peg$currPos;
s1 = peg$currPos;
peg$silentFails++;
if (input.charCodeAt(peg$currPos) === 34) {
s2 = peg$c27;
peg$currPos++;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c28); }
}
peg$silentFails--;
if (s2 === peg$FAILED) {
s1 = peg$c5;
} else {
peg$currPos = s1;
s1 = peg$c2;
}
if (s1 !== peg$FAILED) {
if (input.length > peg$currPos) {
s2 = input.charAt(peg$currPos);
peg$currPos++;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c6); }
}
if (s2 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c33(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseliteral_char() {
var s0, s1, s2;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 19,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
s1 = peg$currPos;
peg$silentFails++;
if (input.charCodeAt(peg$currPos) === 39) {
s2 = peg$c31;
peg$currPos++;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c32); }
}
peg$silentFails--;
if (s2 === peg$FAILED) {
s1 = peg$c5;
} else {
peg$currPos = s1;
s1 = peg$c2;
}
if (s1 !== peg$FAILED) {
if (input.length > peg$currPos) {
s2 = input.charAt(peg$currPos);
peg$currPos++;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c6); }
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (s2 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c33(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function peg$parsemultiline_string_char() {
var s0, s1, s2;
var key = peg$currPos * 49 + 20,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$parseESCAPED();
if (s0 === peg$FAILED) {
s0 = peg$parsemultiline_string_delim();
if (s0 === peg$FAILED) {
s0 = peg$currPos;
s1 = peg$currPos;
peg$silentFails++;
if (input.substr(peg$currPos, 3) === peg$c23) {
s2 = peg$c23;
peg$currPos += 3;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c24); }
}
peg$silentFails--;
if (s2 === peg$FAILED) {
s1 = peg$c5;
} else {
peg$currPos = s1;
s1 = peg$c2;
}
if (s1 !== peg$FAILED) {
if (input.length > peg$currPos) {
s2 = input.charAt(peg$currPos);
peg$currPos++;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c6); }
}
if (s2 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c34(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function peg$parsemultiline_string_delim() {
var s0, s1, s2, s3, s4;
var key = peg$currPos * 49 + 21,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 92) {
s1 = peg$c35;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c36); }
}
if (s1 !== peg$FAILED) {
s2 = peg$parseNL();
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parseNLS();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parseNLS();
}
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c37();
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
function peg$parsemultiline_literal_char() {
var s0, s1, s2;
var key = peg$currPos * 49 + 22,
cached = peg$cache[key];
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
s1 = peg$currPos;
peg$silentFails++;
if (input.substr(peg$currPos, 3) === peg$c29) {
s2 = peg$c29;
peg$currPos += 3;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c30); }
}
peg$silentFails--;
if (s2 === peg$FAILED) {
s1 = peg$c5;
} else {
peg$currPos = s1;
s1 = peg$c2;
}
if (s1 !== peg$FAILED) {
if (input.length > peg$currPos) {
s2 = input.charAt(peg$currPos);
peg$currPos++;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c6); }
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (s2 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c33(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
} else {
peg$currPos = s0;
s0 = peg$c2;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsefloat() {
var s0, s1, s2, s3;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 23,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
s1 = peg$parsefloat_text();
if (s1 === peg$FAILED) {
s1 = peg$parseinteger_text();
}
if (s1 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 101) {
s2 = peg$c38;
peg$currPos++;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c39); }
}
if (s2 === peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 69) {
s2 = peg$c40;
peg$currPos++;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c41); }
}
}
if (s2 !== peg$FAILED) {
s3 = peg$parseinteger_text();
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c42(s1, s3);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
s1 = peg$parsefloat_text();
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c43(s1);
}
s0 = s1;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsefloat_text() {
var s0, s1, s2, s3, s4, s5;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 24,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 43) {
s1 = peg$c44;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c45); }
}
if (s1 === peg$FAILED) {
s1 = peg$c25;
}
if (s1 !== peg$FAILED) {
s2 = peg$currPos;
s3 = peg$parseDIGITS();
if (s3 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 46) {
s4 = peg$c16;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c17); }
}
if (s4 !== peg$FAILED) {
s5 = peg$parseDIGITS();
if (s5 !== peg$FAILED) {
s3 = [s3, s4, s5];
s2 = s3;
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
if (s2 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c46(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 45) {
s1 = peg$c47;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c48); }
}
if (s1 !== peg$FAILED) {
s2 = peg$currPos;
s3 = peg$parseDIGITS();
if (s3 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 46) {
s4 = peg$c16;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c17); }
}
if (s4 !== peg$FAILED) {
s5 = peg$parseDIGITS();
if (s5 !== peg$FAILED) {
s3 = [s3, s4, s5];
s2 = s3;
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
if (s2 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c49(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseinteger() {
var s0, s1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 25,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
s1 = peg$parseinteger_text();
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c50(s1);
}
s0 = s1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseinteger_text() {
var s0, s1, s2, s3, s4;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 26,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 43) {
s1 = peg$c44;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c45); }
}
if (s1 === peg$FAILED) {
s1 = peg$c25;
}
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$parseDIGIT_OR_UNDER();
if (s3 !== peg$FAILED) {
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$parseDIGIT_OR_UNDER();
}
} else {
s2 = peg$c2;
}
if (s2 !== peg$FAILED) {
s3 = peg$currPos;
peg$silentFails++;
if (input.charCodeAt(peg$currPos) === 46) {
s4 = peg$c16;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c17); }
}
peg$silentFails--;
if (s4 === peg$FAILED) {
s3 = peg$c5;
} else {
peg$currPos = s3;
s3 = peg$c2;
}
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c46(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 45) {
s1 = peg$c47;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c48); }
}
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$parseDIGIT_OR_UNDER();
if (s3 !== peg$FAILED) {
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$parseDIGIT_OR_UNDER();
}
} else {
s2 = peg$c2;
}
if (s2 !== peg$FAILED) {
s3 = peg$currPos;
peg$silentFails++;
if (input.charCodeAt(peg$currPos) === 46) {
s4 = peg$c16;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c17); }
}
peg$silentFails--;
if (s4 === peg$FAILED) {
s3 = peg$c5;
} else {
peg$currPos = s3;
s3 = peg$c2;
}
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c49(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseboolean() {
var s0, s1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 27,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
if (input.substr(peg$currPos, 4) === peg$c51) {
s1 = peg$c51;
peg$currPos += 4;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c52); }
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c53();
}
s0 = s1;
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.substr(peg$currPos, 5) === peg$c54) {
s1 = peg$c54;
peg$currPos += 5;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c55); }
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c56();
}
s0 = s1;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsearray() {
var s0, s1, s2, s3, s4;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 28,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 91) {
s1 = peg$c7;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c8); }
}
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$parsearray_sep();
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$parsearray_sep();
}
if (s2 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 93) {
s3 = peg$c9;
peg$currPos++;
} else {
s3 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c10); }
}
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c57();
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 91) {
s1 = peg$c7;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c8); }
}
if (s1 !== peg$FAILED) {
s2 = peg$parsearray_value();
if (s2 === peg$FAILED) {
s2 = peg$c25;
}
if (s2 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 93) {
s3 = peg$c9;
peg$currPos++;
} else {
s3 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c10); }
}
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c58(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 91) {
s1 = peg$c7;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c8); }
}
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$parsearray_value_list();
if (s3 !== peg$FAILED) {
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$parsearray_value_list();
}
} else {
s2 = peg$c2;
}
if (s2 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 93) {
s3 = peg$c9;
peg$currPos++;
} else {
s3 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c10); }
}
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c59(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 91) {
s1 = peg$c7;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c8); }
}
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$parsearray_value_list();
if (s3 !== peg$FAILED) {
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$parsearray_value_list();
}
} else {
s2 = peg$c2;
}
if (s2 !== peg$FAILED) {
s3 = peg$parsearray_value();
if (s3 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 93) {
s4 = peg$c9;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c10); }
}
if (s4 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c60(s2, s3);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
}
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsearray_value() {
var s0, s1, s2, s3, s4;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 29,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
s1 = [];
s2 = peg$parsearray_sep();
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parsearray_sep();
}
if (s1 !== peg$FAILED) {
s2 = peg$parsevalue();
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parsearray_sep();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parsearray_sep();
}
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c61(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsearray_value_list() {
var s0, s1, s2, s3, s4, s5, s6;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 30,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
s1 = [];
s2 = peg$parsearray_sep();
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parsearray_sep();
}
if (s1 !== peg$FAILED) {
s2 = peg$parsevalue();
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parsearray_sep();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parsearray_sep();
}
if (s3 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 44) {
s4 = peg$c62;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c63); }
}
if (s4 !== peg$FAILED) {
s5 = [];
s6 = peg$parsearray_sep();
while (s6 !== peg$FAILED) {
s5.push(s6);
s6 = peg$parsearray_sep();
}
if (s5 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c61(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsearray_sep() {
var s0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 31,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$parseS();
if (s0 === peg$FAILED) {
s0 = peg$parseNL();
if (s0 === peg$FAILED) {
s0 = peg$parsecomment();
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseinline_table() {
var s0, s1, s2, s3, s4, s5;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 32,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 123) {
s1 = peg$c64;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c65); }
}
if (s1 !== peg$FAILED) {
s2 = [];
s3 = peg$parseS();
while (s3 !== peg$FAILED) {
s2.push(s3);
s3 = peg$parseS();
}
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parseinline_table_assignment();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parseinline_table_assignment();
}
if (s3 !== peg$FAILED) {
s4 = [];
s5 = peg$parseS();
while (s5 !== peg$FAILED) {
s4.push(s5);
s5 = peg$parseS();
}
if (s4 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 125) {
s5 = peg$c66;
peg$currPos++;
} else {
s5 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c67); }
}
if (s5 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c68(s3);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseinline_table_assignment() {
var s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, s10;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 33,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
s0 = peg$currPos;
s1 = [];
s2 = peg$parseS();
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parseS();
}
if (s1 !== peg$FAILED) {
s2 = peg$parsekey();
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parseS();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parseS();
}
if (s3 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 61) {
s4 = peg$c18;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c19); }
}
if (s4 !== peg$FAILED) {
s5 = [];
s6 = peg$parseS();
while (s6 !== peg$FAILED) {
s5.push(s6);
s6 = peg$parseS();
}
if (s5 !== peg$FAILED) {
s6 = peg$parsevalue();
if (s6 !== peg$FAILED) {
s7 = [];
s8 = peg$parseS();
while (s8 !== peg$FAILED) {
s7.push(s8);
s8 = peg$parseS();
}
if (s7 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 44) {
s8 = peg$c62;
peg$currPos++;
} else {
s8 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c63); }
}
if (s8 !== peg$FAILED) {
s9 = [];
s10 = peg$parseS();
while (s10 !== peg$FAILED) {
s9.push(s10);
s10 = peg$parseS();
}
if (s9 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c69(s2, s6);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
s1 = [];
s2 = peg$parseS();
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parseS();
}
if (s1 !== peg$FAILED) {
s2 = peg$parsekey();
if (s2 !== peg$FAILED) {
s3 = [];
s4 = peg$parseS();
while (s4 !== peg$FAILED) {
s3.push(s4);
s4 = peg$parseS();
}
if (s3 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 61) {
s4 = peg$c18;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c19); }
}
if (s4 !== peg$FAILED) {
s5 = [];
s6 = peg$parseS();
while (s6 !== peg$FAILED) {
s5.push(s6);
s6 = peg$parseS();
}
if (s5 !== peg$FAILED) {
s6 = peg$parsevalue();
if (s6 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c69(s2, s6);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsesecfragment() {
var s0, s1, s2;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 34,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 46) {
s1 = peg$c16;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c17); }
}
if (s1 !== peg$FAILED) {
s2 = peg$parseDIGITS();
if (s2 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c70(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsedate() {
var s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, s10, s11;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 35,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
s1 = peg$currPos;
s2 = peg$parseDIGIT_OR_UNDER();
if (s2 !== peg$FAILED) {
s3 = peg$parseDIGIT_OR_UNDER();
if (s3 !== peg$FAILED) {
s4 = peg$parseDIGIT_OR_UNDER();
if (s4 !== peg$FAILED) {
s5 = peg$parseDIGIT_OR_UNDER();
if (s5 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 45) {
s6 = peg$c47;
peg$currPos++;
} else {
s6 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c48); }
}
if (s6 !== peg$FAILED) {
s7 = peg$parseDIGIT_OR_UNDER();
if (s7 !== peg$FAILED) {
s8 = peg$parseDIGIT_OR_UNDER();
if (s8 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 45) {
s9 = peg$c47;
peg$currPos++;
} else {
s9 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c48); }
}
if (s9 !== peg$FAILED) {
s10 = peg$parseDIGIT_OR_UNDER();
if (s10 !== peg$FAILED) {
s11 = peg$parseDIGIT_OR_UNDER();
if (s11 !== peg$FAILED) {
s2 = [s2, s3, s4, s5, s6, s7, s8, s9, s10, s11];
s1 = s2;
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c71(s1);
}
s0 = s1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsetime() {
var s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, s10;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 36,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
s1 = peg$currPos;
s2 = peg$parseDIGIT_OR_UNDER();
if (s2 !== peg$FAILED) {
s3 = peg$parseDIGIT_OR_UNDER();
if (s3 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 58) {
s4 = peg$c72;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c73); }
}
if (s4 !== peg$FAILED) {
s5 = peg$parseDIGIT_OR_UNDER();
if (s5 !== peg$FAILED) {
s6 = peg$parseDIGIT_OR_UNDER();
if (s6 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 58) {
s7 = peg$c72;
peg$currPos++;
} else {
s7 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c73); }
}
if (s7 !== peg$FAILED) {
s8 = peg$parseDIGIT_OR_UNDER();
if (s8 !== peg$FAILED) {
s9 = peg$parseDIGIT_OR_UNDER();
if (s9 !== peg$FAILED) {
s10 = peg$parsesecfragment();
if (s10 === peg$FAILED) {
s10 = peg$c25;
}
if (s10 !== peg$FAILED) {
s2 = [s2, s3, s4, s5, s6, s7, s8, s9, s10];
s1 = s2;
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c74(s1);
}
s0 = s1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsetime_with_offset() {
var s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, s10, s11, s12, s13, s14, s15, s16;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 37,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
s1 = peg$currPos;
s2 = peg$parseDIGIT_OR_UNDER();
if (s2 !== peg$FAILED) {
s3 = peg$parseDIGIT_OR_UNDER();
if (s3 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 58) {
s4 = peg$c72;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c73); }
}
if (s4 !== peg$FAILED) {
s5 = peg$parseDIGIT_OR_UNDER();
if (s5 !== peg$FAILED) {
s6 = peg$parseDIGIT_OR_UNDER();
if (s6 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 58) {
s7 = peg$c72;
peg$currPos++;
} else {
s7 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c73); }
}
if (s7 !== peg$FAILED) {
s8 = peg$parseDIGIT_OR_UNDER();
if (s8 !== peg$FAILED) {
s9 = peg$parseDIGIT_OR_UNDER();
if (s9 !== peg$FAILED) {
s10 = peg$parsesecfragment();
if (s10 === peg$FAILED) {
s10 = peg$c25;
}
if (s10 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 45) {
s11 = peg$c47;
peg$currPos++;
} else {
s11 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c48); }
}
if (s11 === peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 43) {
s11 = peg$c44;
peg$currPos++;
} else {
s11 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c45); }
}
}
if (s11 !== peg$FAILED) {
s12 = peg$parseDIGIT_OR_UNDER();
if (s12 !== peg$FAILED) {
s13 = peg$parseDIGIT_OR_UNDER();
if (s13 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 58) {
s14 = peg$c72;
peg$currPos++;
} else {
s14 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c73); }
}
if (s14 !== peg$FAILED) {
s15 = peg$parseDIGIT_OR_UNDER();
if (s15 !== peg$FAILED) {
s16 = peg$parseDIGIT_OR_UNDER();
if (s16 !== peg$FAILED) {
s2 = [s2, s3, s4, s5, s6, s7, s8, s9, s10, s11, s12, s13, s14, s15, s16];
s1 = s2;
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
} else {
peg$currPos = s1;
s1 = peg$c2;
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c74(s1);
}
s0 = s1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parsedatetime() {
var s0, s1, s2, s3, s4;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 38,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
s1 = peg$parsedate();
if (s1 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 84) {
s2 = peg$c75;
peg$currPos++;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c76); }
}
if (s2 !== peg$FAILED) {
s3 = peg$parsetime();
if (s3 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 90) {
s4 = peg$c77;
peg$currPos++;
} else {
s4 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c78); }
}
if (s4 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c79(s1, s3);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
s1 = peg$parsedate();
if (s1 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 84) {
s2 = peg$c75;
peg$currPos++;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c76); }
}
if (s2 !== peg$FAILED) {
s3 = peg$parsetime_with_offset();
if (s3 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c80(s1, s3);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseS() {
var s0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 39,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (peg$c81.test(input.charAt(peg$currPos))) {
s0 = input.charAt(peg$currPos);
peg$currPos++;
} else {
s0 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c82); }
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseNL() {
var s0, s1, s2;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 40,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (input.charCodeAt(peg$currPos) === 10) {
s0 = peg$c83;
peg$currPos++;
} else {
s0 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c84); }
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 13) {
s1 = peg$c85;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c86); }
}
if (s1 !== peg$FAILED) {
if (input.charCodeAt(peg$currPos) === 10) {
s2 = peg$c83;
peg$currPos++;
} else {
s2 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c84); }
}
if (s2 !== peg$FAILED) {
s1 = [s1, s2];
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseNLS() {
var s0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 41,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$parseNL();
if (s0 === peg$FAILED) {
s0 = peg$parseS();
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseEOF() {
var s0, s1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 42,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
peg$silentFails++;
if (input.length > peg$currPos) {
s1 = input.charAt(peg$currPos);
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c6); }
}
peg$silentFails--;
if (s1 === peg$FAILED) {
s0 = peg$c5;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseHEX() {
var s0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 43,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (peg$c87.test(input.charAt(peg$currPos))) {
s0 = input.charAt(peg$currPos);
peg$currPos++;
} else {
s0 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c88); }
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseDIGIT_OR_UNDER() {
var s0, s1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 44,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (peg$c89.test(input.charAt(peg$currPos))) {
s0 = input.charAt(peg$currPos);
peg$currPos++;
} else {
s0 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c90); }
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.charCodeAt(peg$currPos) === 95) {
s1 = peg$c91;
peg$currPos++;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c92); }
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c93();
}
s0 = s1;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseASCII_BASIC() {
var s0;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 45,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (peg$c94.test(input.charAt(peg$currPos))) {
s0 = input.charAt(peg$currPos);
peg$currPos++;
} else {
s0 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c95); }
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseDIGITS() {
var s0, s1, s2;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 46,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
s1 = [];
s2 = peg$parseDIGIT_OR_UNDER();
if (s2 !== peg$FAILED) {
while (s2 !== peg$FAILED) {
s1.push(s2);
s2 = peg$parseDIGIT_OR_UNDER();
}
} else {
s1 = peg$c2;
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c96(s1);
}
s0 = s1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseESCAPED() {
var s0, s1;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 47,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
if (input.substr(peg$currPos, 2) === peg$c97) {
s1 = peg$c97;
peg$currPos += 2;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c98); }
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c99();
}
s0 = s1;
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.substr(peg$currPos, 2) === peg$c100) {
s1 = peg$c100;
peg$currPos += 2;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c101); }
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c102();
}
s0 = s1;
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.substr(peg$currPos, 2) === peg$c103) {
s1 = peg$c103;
peg$currPos += 2;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c104); }
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c105();
}
s0 = s1;
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.substr(peg$currPos, 2) === peg$c106) {
s1 = peg$c106;
peg$currPos += 2;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c107); }
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c108();
}
s0 = s1;
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.substr(peg$currPos, 2) === peg$c109) {
s1 = peg$c109;
peg$currPos += 2;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c110); }
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c111();
}
s0 = s1;
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.substr(peg$currPos, 2) === peg$c112) {
s1 = peg$c112;
peg$currPos += 2;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c113); }
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c114();
}
s0 = s1;
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.substr(peg$currPos, 2) === peg$c115) {
s1 = peg$c115;
peg$currPos += 2;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c116); }
}
if (s1 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c117();
}
s0 = s1;
if (s0 === peg$FAILED) {
s0 = peg$parseESCAPED_UNICODE();
}
}
}
}
}
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function peg$parseESCAPED_UNICODE() {
var s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, s10;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var key = peg$currPos * 49 + 48,
cached = peg$cache[key];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (cached) {
peg$currPos = cached.nextPos;
return cached.result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
s0 = peg$currPos;
if (input.substr(peg$currPos, 2) === peg$c118) {
s1 = peg$c118;
peg$currPos += 2;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c119); }
}
if (s1 !== peg$FAILED) {
s2 = peg$currPos;
s3 = peg$parseHEX();
if (s3 !== peg$FAILED) {
s4 = peg$parseHEX();
if (s4 !== peg$FAILED) {
s5 = peg$parseHEX();
if (s5 !== peg$FAILED) {
s6 = peg$parseHEX();
if (s6 !== peg$FAILED) {
s7 = peg$parseHEX();
if (s7 !== peg$FAILED) {
s8 = peg$parseHEX();
if (s8 !== peg$FAILED) {
s9 = peg$parseHEX();
if (s9 !== peg$FAILED) {
s10 = peg$parseHEX();
if (s10 !== peg$FAILED) {
s3 = [s3, s4, s5, s6, s7, s8, s9, s10];
s2 = s3;
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
if (s2 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c120(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
if (s0 === peg$FAILED) {
s0 = peg$currPos;
if (input.substr(peg$currPos, 2) === peg$c121) {
s1 = peg$c121;
peg$currPos += 2;
} else {
s1 = peg$FAILED;
if (peg$silentFails === 0) { peg$fail(peg$c122); }
}
if (s1 !== peg$FAILED) {
s2 = peg$currPos;
s3 = peg$parseHEX();
if (s3 !== peg$FAILED) {
s4 = peg$parseHEX();
if (s4 !== peg$FAILED) {
s5 = peg$parseHEX();
if (s5 !== peg$FAILED) {
s6 = peg$parseHEX();
if (s6 !== peg$FAILED) {
s3 = [s3, s4, s5, s6];
s2 = s3;
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
} else {
peg$currPos = s2;
s2 = peg$c2;
}
if (s2 !== peg$FAILED) {
peg$reportedPos = s0;
s1 = peg$c120(s2);
s0 = s1;
} else {
peg$currPos = s0;
s0 = peg$c2;
}
} else {
peg$currPos = s0;
s0 = peg$c2;
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$cache[key] = { nextPos: peg$currPos, result: s0 };
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return s0;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var nodes = [];
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function genError(err, line, col) {
var ex = new Error(err);
ex.line = line;
ex.column = col;
throw ex;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function addNode(node) {
nodes.push(node);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function node(type, value, line, column, key) {
var obj = { type: type, value: value, line: line(), column: column() };
if (key) obj.key = key;
return obj;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function convertCodePoint(str, line, col) {
var num = parseInt("0x" + str);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (
!isFinite(num) ||
Math.floor(num) != num ||
num < 0 ||
num > 0x10FFFF ||
(num > 0xD7FF && num < 0xE000)
) {
genError("Invalid Unicode escape code: " + str, line, col);
} else {
return fromCodePoint(num);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function fromCodePoint() {
var MAX_SIZE = 0x4000;
var codeUnits = [];
var highSurrogate;
var lowSurrogate;
var index = -1;
var length = arguments.length;
if (!length) {
return '';
}
var result = '';
while (++index < length) {
var codePoint = Number(arguments[index]);
if (codePoint <= 0xFFFF) { // BMP code point
codeUnits.push(codePoint);
} else { // Astral code point; split in surrogate halves
// http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae
codePoint -= 0x10000;
highSurrogate = (codePoint >> 10) + 0xD800;
lowSurrogate = (codePoint % 0x400) + 0xDC00;
codeUnits.push(highSurrogate, lowSurrogate);
}
if (index + 1 == length || codeUnits.length > MAX_SIZE) {
result += String.fromCharCode.apply(null, codeUnits);
codeUnits.length = 0;
}
}
return result;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
peg$result = peg$startRuleFunction();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (peg$result !== peg$FAILED && peg$currPos === input.length) {
return peg$result;
} else {
if (peg$result !== peg$FAILED && peg$currPos < input.length) {
peg$fail({ type: "end", description: "end of input" });
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
throw peg$buildException(null, peg$maxFailExpected, peg$maxFailPos);
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return {
SyntaxError: SyntaxError,
parse: parse
};
})();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 4294:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
module.exports = __nccwpck_require__(4219);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 4219:
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var net = __nccwpck_require__(1808);
var tls = __nccwpck_require__(4404);
var http = __nccwpck_require__(3685);
var https = __nccwpck_require__(5687);
var events = __nccwpck_require__(2361);
var assert = __nccwpck_require__(9491);
var util = __nccwpck_require__(3837);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
exports.httpOverHttp = httpOverHttp;
exports.httpsOverHttp = httpsOverHttp;
exports.httpOverHttps = httpOverHttps;
exports.httpsOverHttps = httpsOverHttps;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function httpOverHttp(options) {
var agent = new TunnelingAgent(options);
agent.request = http.request;
return agent;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function httpsOverHttp(options) {
var agent = new TunnelingAgent(options);
agent.request = http.request;
agent.createSocket = createSecureSocket;
agent.defaultPort = 443;
return agent;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function httpOverHttps(options) {
var agent = new TunnelingAgent(options);
agent.request = https.request;
return agent;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function httpsOverHttps(options) {
var agent = new TunnelingAgent(options);
agent.request = https.request;
agent.createSocket = createSecureSocket;
agent.defaultPort = 443;
return agent;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04: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 = [];
self.on('free', function onFree(socket, host, port, localAddress) {
var options = toOptions(host, port, localAddress);
for (var i = 0, len = self.requests.length; i < len; ++i) {
var pending = self.requests[i];
if (pending.host === options.host && pending.port === options.port) {
// Detect the request to connect same origin server,
// reuse the connection.
self.requests.splice(i, 1);
pending.request.onSocket(socket);
return;
}
}
socket.destroy();
self.removeSocket(socket);
});
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
util.inherits(TunnelingAgent, events.EventEmitter);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
TunnelingAgent.prototype.addRequest = function addRequest(req, host, port, localAddress) {
var self = this;
var options = mergeOptions({request: req}, self.options, toOptions(host, port, localAddress));
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (self.sockets.length >= this.maxSockets) {
// We are over limit so we'll add it to the queue.
self.requests.push(options);
return;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04: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);
function onFree() {
self.emit('free', socket, options);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function onCloseOrRemove(err) {
self.removeSocket(socket);
socket.removeListener('free', onFree);
socket.removeListener('close', onCloseOrRemove);
socket.removeListener('agentRemove', onCloseOrRemove);
}
});
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
TunnelingAgent.prototype.createSocket = function createSocket(options, cb) {
var self = this;
var placeholder = {};
self.sockets.push(placeholder);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
var connectOptions = mergeOptions({}, self.proxyOptions, {
method: 'CONNECT',
path: options.host + ':' + options.port,
agent: false,
headers: {
host: options.host + ':' + options.port
}
});
if (options.localAddress) {
connectOptions.localAddress = options.localAddress;
}
if (connectOptions.proxyAuth) {
connectOptions.headers = connectOptions.headers || {};
connectOptions.headers['Proxy-Authorization'] = 'Basic ' +
Buffer.from(connectOptions.proxyAuth).toString('base64');
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04: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();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function onResponse(res) {
// Very hacky. This is necessary to avoid http-parser leaks.
res.upgrade = true;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function onUpgrade(res, socket, head) {
// Hacky.
process.nextTick(function() {
onConnect(res, socket, head);
});
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function onConnect(res, socket, head) {
connectReq.removeAllListeners();
socket.removeAllListeners();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04: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);
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function onError(cause) {
connectReq.removeAllListeners();
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04: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);
}
2021-09-26 15:31:45 -04:00
};
2022-05-31 14:18:28 -04:00
TunnelingAgent.prototype.removeSocket = function removeSocket(socket) {
var pos = this.sockets.indexOf(socket)
if (pos === -1) {
return;
}
this.sockets.splice(pos, 1);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04: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);
});
}
};
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04: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
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// 0 is dummy port for v0.6
var secureSocket = tls.connect(0, tlsOptions);
self.sockets[self.sockets.indexOf(socket)] = secureSocket;
cb(secureSocket);
});
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04: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
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04: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];
}
}
}
}
return target;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04: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() {};
}
exports.debug = debug; // for test
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 5030:
/***/ ((__unused_webpack_module, exports) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.defineProperty(exports, "__esModule", ({ value: true }));
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function getUserAgent() {
if (typeof navigator === "object" && "userAgent" in navigator) {
return navigator.userAgent;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (typeof process === "object" && "version" in process) {
return `Node.js/${process.version.substr(1)} (${process.platform}; ${process.arch})`;
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return "<environment undetectable>";
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
exports.getUserAgent = getUserAgent;
//# sourceMappingURL=index.js.map
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 2940:
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// Returns a wrapper function that returns a wrapped callback
// The wrapper function should do some stuff, and return a
// presumably different callback function.
// This makes sure that own properties are retained, so that
// decorations and such are not lost along the way.
module.exports = wrappy
function wrappy (fn, cb) {
if (fn && cb) return wrappy(fn)(cb)
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
if (typeof fn !== 'function')
throw new TypeError('need wrapper function')
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
Object.keys(fn).forEach(function (k) {
wrapper[k] = fn[k]
})
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
return wrapper
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function wrapper() {
var args = new Array(arguments.length)
for (var i = 0; i < args.length; i++) {
args[i] = arguments[i]
}
var ret = fn.apply(this, args)
var cb = args[args.length-1]
if (typeof ret === 'function' && ret !== cb) {
Object.keys(cb).forEach(function (k) {
ret[k] = cb[k]
})
}
return ret
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 8047:
/***/ ((__unused_webpack_module, __webpack_exports__, __nccwpck_require__) => {
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
"use strict";
// ESM COMPAT FLAG
__nccwpck_require__.r(__webpack_exports__);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// EXTERNAL MODULE: ./node_modules/fast-glob/out/index.js
var out = __nccwpck_require__(3664);
var out_default = /*#__PURE__*/__nccwpck_require__.n(out);
// EXTERNAL MODULE: external "fs"
var external_fs_ = __nccwpck_require__(7147);
var external_fs_default = /*#__PURE__*/__nccwpck_require__.n(external_fs_);
// EXTERNAL MODULE: external "path"
var external_path_ = __nccwpck_require__(1017);
var external_path_default = /*#__PURE__*/__nccwpck_require__.n(external_path_);
;// CONCATENATED MODULE: ./src/utils/file.ts
var __awaiter = (undefined && undefined.__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-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class File {
constructor(filePath) {
this.name = external_path_default().basename(filePath);
this.path = filePath;
Object.freeze(this);
}
getBuffer() {
return __awaiter(this, void 0, void 0, function* () {
return new Promise((resolve, reject) => {
external_fs_default().readFile(this.path, (error, data) => {
if (error) {
reject(error);
}
else {
resolve(data);
}
});
});
});
}
equals(file) {
return file instanceof File && file.path === this.path;
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
;// CONCATENATED MODULE: ./src/utils/file-utils.ts
var file_utils_awaiter = (undefined && undefined.__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-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const gradleOutputSelector = {
primary: "build/libs/!(*-@(dev|sources)).jar",
secondary: "build/libs/*-@(dev|sources).jar"
};
function getRequiredFiles(files) {
return file_utils_awaiter(this, void 0, void 0, function* () {
const foundFiles = yield getFiles(files);
if (foundFiles && foundFiles.length) {
return foundFiles;
}
throw new Error(`Specified files ('${typeof files === "string" ? files : [files.primary, files.secondary].filter(x => x).join(", ")}') were not found`);
});
}
function getFiles(files) {
return file_utils_awaiter(this, void 0, void 0, function* () {
if (!files || typeof files !== "string" && !files.primary && !files.secondary) {
return [];
}
if (typeof files === "string") {
return (yield out_default()(files)).map(x => new File(x));
}
let results = [];
if (files.primary) {
results = (yield out_default()(files.primary)).map(x => new File(x));
}
if (files.secondary) {
results = results.concat((yield out_default()(files.secondary)).map(x => new File(x)));
}
return results.filter((x, i, self) => self.findIndex(y => x.equals(y)) === i);
});
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
;// CONCATENATED MODULE: ./src/publishing/publisher-target.ts
var PublisherTarget;
(function (PublisherTarget) {
PublisherTarget[PublisherTarget["GitHub"] = 0] = "GitHub";
PublisherTarget[PublisherTarget["Modrinth"] = 1] = "Modrinth";
PublisherTarget[PublisherTarget["CurseForge"] = 2] = "CurseForge";
})(PublisherTarget || (PublisherTarget = {}));
(function (PublisherTarget) {
function getValues() {
return Object.values(PublisherTarget).filter(x => !isNaN(+x));
}
PublisherTarget.getValues = getValues;
function toString(target) {
return PublisherTarget[target] || target.toString();
}
PublisherTarget.toString = toString;
})(PublisherTarget || (PublisherTarget = {}));
/* harmony default export */ const publisher_target = (PublisherTarget);
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// EXTERNAL MODULE: ./node_modules/@actions/core/lib/core.js
var core = __nccwpck_require__(2186);
;// CONCATENATED MODULE: external "console"
const external_console_namespaceObject = require("console");
;// CONCATENATED MODULE: ./src/utils/logger-utils.ts
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
function getDefaultLogger() {
return {
fatal: core.setFailed,
error: core.warning,
warn: core.warning,
info: core.info,
debug: core.debug
};
}
function getConsoleLogger() {
return {
fatal: console.error,
error: console.error,
warn: console.warn,
info: console.info,
debug: console.debug
};
}
function getEmptyLogger() {
return {
fatal: () => { },
error: () => { },
warn: () => { },
info: () => { },
debug: () => { }
};
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
;// CONCATENATED MODULE: ./src/publishing/publisher.ts
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class Publisher {
constructor(logger) {
this.logger = logger || getEmptyLogger();
}
validateOptions(options) {
if (!options || typeof options !== "object") {
throw new Error(`Expected options to be an object, got ${options ? typeof options : options}`);
}
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// EXTERNAL MODULE: ./node_modules/@actions/github/lib/github.js
var github = __nccwpck_require__(5438);
;// CONCATENATED MODULE: ./src/publishing/github/github-publisher.ts
var github_publisher_awaiter = (undefined && undefined.__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-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class GitHubPublisher extends Publisher {
get target() {
return publisher_target.GitHub;
}
publish(files, options) {
var _a;
return github_publisher_awaiter(this, void 0, void 0, function* () {
this.validateOptions(options);
let releaseId = 0;
const repo = github.context.repo;
const octokit = github.getOctokit(options.token);
if (options.tag) {
const response = yield octokit.rest.repos.getReleaseByTag(Object.assign(Object.assign({}, repo), { tag: options.tag }));
if (response.status >= 200 && response.status < 300) {
releaseId = response.data.id;
}
}
else {
releaseId = (_a = github.context.payload.release) === null || _a === void 0 ? void 0 : _a.id;
}
if (!releaseId) {
throw new Error(`Couldn't find release #${options.tag || releaseId}`);
}
const existingAssets = (yield octokit.rest.repos.listReleaseAssets(Object.assign(Object.assign({}, repo), { release_id: releaseId }))).data;
for (const file of files) {
const existingAsset = existingAssets.find(x => x.name === file.name || x.name === file.path);
if (existingAsset) {
yield octokit.rest.repos.deleteReleaseAsset(Object.assign(Object.assign({}, repo), { asset_id: existingAsset.id }));
}
yield octokit.rest.repos.uploadReleaseAsset({
owner: repo.owner,
repo: repo.repo,
release_id: releaseId,
name: file.name,
data: yield file.getBuffer()
});
}
});
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// EXTERNAL MODULE: external "util"
var external_util_ = __nccwpck_require__(3837);
;// CONCATENATED MODULE: ./node_modules/web-streams-polyfill/dist/ponyfill.mjs
2021-09-26 15:31:45 -04:00
/**
2022-05-31 14:18:28 -04:00
* @license
* web-streams-polyfill v4.0.0-beta.1
* Copyright 2021 Mattias Buelens, Diwank Singh Tomer and other contributors.
* This code is released under the MIT license.
* SPDX-License-Identifier: MIT
2021-09-26 15:31:45 -04:00
*/
2022-05-31 14:18:28 -04:00
const e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?Symbol:e=>`Symbol(${e})`;function t(){}function r(e){return"object"==typeof e&&null!==e||"function"==typeof e}const o=t,n=Promise,a=Promise.prototype.then,i=Promise.resolve.bind(n),l=Promise.reject.bind(n);function s(e){return new n(e)}function u(e){return i(e)}function c(e){return l(e)}function d(e,t,r){return a.call(e,t,r)}function f(e,t,r){d(d(e,t,r),void 0,o)}function b(e,t){f(e,t)}function _(e,t){f(e,void 0,t)}function h(e,t,r){return d(e,t,r)}function m(e){d(e,void 0,o)}let p=e=>{if("function"==typeof queueMicrotask)p=queueMicrotask;else{const e=u(void 0);p=t=>d(e,t)}return p(e)};function y(e,t,r){if("function"!=typeof e)throw new TypeError("Argument is not a function");return Function.prototype.apply.call(e,t,r)}function g(e,t,r){try{return u(y(e,t,r))}catch(e){return c(e)}}class S{constructor(){this._cursor=0,this._size=0,this._front={_elements:[],_next:void 0},this._back=this._front,this._cursor=0,this._size=0}get length(){return this._size}push(e){const t=this._back;let r=t;16383===t._elements.length&&(r={_elements:[],_next:void 0}),t._elements.push(e),r!==t&&(this._back=r,t._next=r),++this._size}shift(){const e=this._front;let t=e;const r=this._cursor;let o=r+1;const n=e._elements,a=n[r];return 16384===o&&(t=e._next,o=0),--this._size,this._cursor=o,e!==t&&(this._front=t),n[r]=void 0,a}forEach(e){let t=this._cursor,r=this._front,o=r._elements;for(;!(t===o.length&&void 0===r._next||t===o.length&&(r=r._next,o=r._elements,t=0,0===o.length));)e(o[t]),++t}peek(){const e=this._front,t=this._cursor;return e._elements[t]}}function v(e,t){e._ownerReadableStream=t,t._reader=e,"readable"===t._state?C(e):"closed"===t._state?function(e){C(e),E(e)}(e):q(e,t._storedError)}function w(e,t){return cr(e._ownerReadableStream,t)}function R(e){"readable"===e._ownerReadableStream._state?P(e,new TypeError("Reader was released and can no longer be used to monitor the stream's closedness")):function(e,t){q(e,t)}(e,new TypeError("Reader was released and can no longer be used to monitor the stream's closedness")),e._ownerReadableStream._reader=void 0,e._ownerReadableStream=void 0}function T(e){return new TypeError("Cannot "+e+" a stream using a released reader")}function C(e){e._closedPromise=s(((t,r)=>{e._closedPromise_resolve=t,e._closedPromise_reject=r}))}function q(e,t){C(e),P(e,t)}function P(e,t){void 0!==e._closedPromise_reject&&(m(e._closedPromise),e._closedPromise_reject(t),e._closedPromise_resolve=void 0,e._closedPromise_reject=void 0)}function E(e){void 0!==e._closedPromise_resolve&&(e._closedPromise_resolve(void 0),e._closedPromise_resolve=void 0,e._closedPromise_reject=void 0)}const W=e("[[AbortSteps]]"),O=e("[[ErrorSteps]]"),k=e("[[CancelSteps]]"),B=e("[[PullSteps]]"),j=Number.isFinite||function(e){return"number"==typeof e&&isFinite(e)},A=Math.trunc||function(e){return e<0?Math.ceil(e):Math.floor(e)};function z(e,t){if(void 0!==e&&("object"!=typeof(r=e)&&"function"!=typeof r))throw new TypeError(`${t} is not an object.`);var r}function F(e,t){if("function"!=typeof e)throw new TypeError(`${t} is not a function.`)}function I(e,t){if(!function(e){return"object"==typeof e&&null!==e||"function"==typeof e}(e))throw new TypeError(`${t} is not an object.`)}function L(e,t,r){if(void 0===e)throw new TypeError(`Parameter ${t} is required in '${r}'.`)}function $(e,t,r){if(void 0===e)throw new TypeError(`${t} is required in '${r}'.`)}function D(e){return Number(e)}function M(e){return 0===e?0:e}function Q(e,t){const r=Number.MAX_SAFE_INTEGER;let o=Number(e);if(o=M(o),!j(o))throw new TypeError(`${t} is not a finite number`);if(o=function(e){return M(A(e))}(o),o<0||o>r)throw new TypeError(`${t} is outside the accepted range of 0 to ${r}, inclusive`);return j(o)&&0!==o?o:0}function Y(e,t){if(!sr(e))throw new TypeError(`${t} is not a ReadableStream.`)}function x(e){return new ReadableStreamDefaultReader(e)}function N(e,t){e._reader._readRequests.push(t)}function H(e,t,r){const o=e._reader._readRequests.shift();r?o._closeSteps():o._chunkSteps(t)}function V(e){return e._reader
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
;// CONCATENATED MODULE: ./node_modules/formdata-node/lib/esm/isFunction.js
const isFunction = (value) => (typeof value === "function");
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
;// CONCATENATED MODULE: ./node_modules/formdata-node/lib/esm/blobHelpers.js
/*! Based on fetch-blob. MIT License. Jimmy Wärting <https://jimmy.warting.se/opensource> & David Frank */
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const CHUNK_SIZE = 65536;
async function* clonePart(part) {
const end = part.byteOffset + part.byteLength;
let position = part.byteOffset;
while (position !== end) {
const size = Math.min(end - position, CHUNK_SIZE);
const chunk = part.buffer.slice(position, position + size);
position += chunk.byteLength;
yield new Uint8Array(chunk);
}
}
async function* consumeNodeBlob(blob) {
let position = 0;
while (position !== blob.size) {
const chunk = blob.slice(position, Math.min(blob.size, position + CHUNK_SIZE));
const buffer = await chunk.arrayBuffer();
position += buffer.byteLength;
yield new Uint8Array(buffer);
}
}
async function* consumeBlobParts(parts, clone = false) {
for (const part of parts) {
if (ArrayBuffer.isView(part)) {
if (clone) {
yield* clonePart(part);
}
else {
yield part;
}
}
else if (isFunction(part.stream)) {
yield* part.stream();
}
else {
yield* consumeNodeBlob(part);
}
}
}
function* sliceBlob(blobParts, blobSize, start = 0, end) {
end !== null && end !== void 0 ? end : (end = blobSize);
let relativeStart = start < 0
? Math.max(blobSize + start, 0)
: Math.min(start, blobSize);
let relativeEnd = end < 0
? Math.max(blobSize + end, 0)
: Math.min(end, blobSize);
const span = Math.max(relativeEnd - relativeStart, 0);
let added = 0;
for (const part of blobParts) {
if (added >= span) {
break;
}
const partSize = ArrayBuffer.isView(part) ? part.byteLength : part.size;
if (relativeStart && partSize <= relativeStart) {
relativeStart -= partSize;
relativeEnd -= partSize;
}
else {
let chunk;
if (ArrayBuffer.isView(part)) {
chunk = part.subarray(relativeStart, Math.min(partSize, relativeEnd));
added += chunk.byteLength;
}
else {
chunk = part.slice(relativeStart, Math.min(partSize, relativeEnd));
added += chunk.size;
}
relativeEnd -= partSize;
relativeStart = 0;
yield chunk;
}
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
;// CONCATENATED MODULE: ./node_modules/formdata-node/lib/esm/Blob.js
/*! Based on fetch-blob. MIT License. Jimmy Wärting <https://jimmy.warting.se/opensource> & David Frank */
var __classPrivateFieldGet = (undefined && undefined.__classPrivateFieldGet) || function (receiver, state, kind, f) {
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
};
var __classPrivateFieldSet = (undefined && undefined.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
if (kind === "m") throw new TypeError("Private method is not writable");
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
};
var _Blob_parts, _Blob_type, _Blob_size;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class Blob {
constructor(blobParts = [], options = {}) {
_Blob_parts.set(this, []);
_Blob_type.set(this, "");
_Blob_size.set(this, 0);
options !== null && options !== void 0 ? options : (options = {});
if (typeof blobParts !== "object" || blobParts === null) {
throw new TypeError("Failed to construct 'Blob': "
+ "The provided value cannot be converted to a sequence.");
}
if (!isFunction(blobParts[Symbol.iterator])) {
throw new TypeError("Failed to construct 'Blob': "
+ "The object must have a callable @@iterator property.");
}
if (typeof options !== "object" && !isFunction(options)) {
throw new TypeError("Failed to construct 'Blob': parameter 2 cannot convert to dictionary.");
}
const encoder = new TextEncoder();
for (const raw of blobParts) {
let part;
if (ArrayBuffer.isView(raw)) {
part = new Uint8Array(raw.buffer.slice(raw.byteOffset, raw.byteOffset + raw.byteLength));
}
else if (raw instanceof ArrayBuffer) {
part = new Uint8Array(raw.slice(0));
}
else if (raw instanceof Blob) {
part = raw;
}
else {
part = encoder.encode(String(raw));
}
__classPrivateFieldSet(this, _Blob_size, __classPrivateFieldGet(this, _Blob_size, "f") + (ArrayBuffer.isView(part) ? part.byteLength : part.size), "f");
__classPrivateFieldGet(this, _Blob_parts, "f").push(part);
}
const type = options.type === undefined ? "" : String(options.type);
__classPrivateFieldSet(this, _Blob_type, /^[\x20-\x7E]*$/.test(type) ? type : "", "f");
}
static [(_Blob_parts = new WeakMap(), _Blob_type = new WeakMap(), _Blob_size = new WeakMap(), Symbol.hasInstance)](value) {
return Boolean(value
&& typeof value === "object"
&& isFunction(value.constructor)
&& (isFunction(value.stream)
|| isFunction(value.arrayBuffer))
&& /^(Blob|File)$/.test(value[Symbol.toStringTag]));
}
get type() {
return __classPrivateFieldGet(this, _Blob_type, "f");
}
get size() {
return __classPrivateFieldGet(this, _Blob_size, "f");
}
slice(start, end, contentType) {
return new Blob(sliceBlob(__classPrivateFieldGet(this, _Blob_parts, "f"), this.size, start, end), {
type: contentType
});
}
async text() {
const decoder = new TextDecoder();
let result = "";
for await (const chunk of consumeBlobParts(__classPrivateFieldGet(this, _Blob_parts, "f"))) {
result += decoder.decode(chunk, { stream: true });
}
result += decoder.decode();
return result;
}
async arrayBuffer() {
const view = new Uint8Array(this.size);
let offset = 0;
for await (const chunk of consumeBlobParts(__classPrivateFieldGet(this, _Blob_parts, "f"))) {
view.set(chunk, offset);
offset += chunk.length;
}
return view.buffer;
}
stream() {
const iterator = consumeBlobParts(__classPrivateFieldGet(this, _Blob_parts, "f"), true);
return new ReadableStream({
async pull(controller) {
const { value, done } = await iterator.next();
if (done) {
return queueMicrotask(() => controller.close());
}
controller.enqueue(value);
},
async cancel() {
await iterator.return();
}
});
}
get [Symbol.toStringTag]() {
return "Blob";
}
}
Object.defineProperties(Blob.prototype, {
type: { enumerable: true },
size: { enumerable: true },
slice: { enumerable: true },
stream: { enumerable: true },
text: { enumerable: true },
arrayBuffer: { enumerable: true }
});
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
;// CONCATENATED MODULE: ./node_modules/formdata-node/lib/esm/File.js
var File_classPrivateFieldSet = (undefined && undefined.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
if (kind === "m") throw new TypeError("Private method is not writable");
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
};
var File_classPrivateFieldGet = (undefined && undefined.__classPrivateFieldGet) || function (receiver, state, kind, f) {
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
};
var _File_name, _File_lastModified;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class File_File extends Blob {
constructor(fileBits, name, options = {}) {
super(fileBits, options);
_File_name.set(this, void 0);
_File_lastModified.set(this, 0);
if (arguments.length < 2) {
throw new TypeError("Failed to construct 'File': 2 arguments required, "
+ `but only ${arguments.length} present.`);
}
File_classPrivateFieldSet(this, _File_name, String(name), "f");
const lastModified = options.lastModified === undefined
? Date.now()
: Number(options.lastModified);
if (!Number.isNaN(lastModified)) {
File_classPrivateFieldSet(this, _File_lastModified, lastModified, "f");
}
}
get name() {
return File_classPrivateFieldGet(this, _File_name, "f");
}
get lastModified() {
return File_classPrivateFieldGet(this, _File_lastModified, "f");
}
get [(_File_name = new WeakMap(), _File_lastModified = new WeakMap(), Symbol.toStringTag)]() {
return "File";
}
}
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
;// CONCATENATED MODULE: ./node_modules/formdata-node/lib/esm/isFile.js
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const isFile = (value) => value instanceof File_File;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
;// CONCATENATED MODULE: ./node_modules/formdata-node/lib/esm/deprecateConstructorEntries.js
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const deprecateConstructorEntries = (0,external_util_.deprecate)(() => { }, "Constructor \"entries\" argument is not spec-compliant "
+ "and will be removed in next major release.");
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
;// CONCATENATED MODULE: ./node_modules/formdata-node/lib/esm/FormData.js
var FormData_classPrivateFieldGet = (undefined && undefined.__classPrivateFieldGet) || function (receiver, state, kind, f) {
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
};
var _FormData_instances, _FormData_entries, _FormData_setEntry;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
class FormData {
constructor(entries) {
_FormData_instances.add(this);
_FormData_entries.set(this, new Map());
if (entries) {
deprecateConstructorEntries();
entries.forEach(({ name, value, fileName }) => this.append(name, value, fileName));
}
}
static [(_FormData_entries = new WeakMap(), _FormData_instances = new WeakSet(), Symbol.hasInstance)](value) {
return Boolean(value
&& isFunction(value.constructor)
&& value[Symbol.toStringTag] === "FormData"
&& isFunction(value.append)
&& isFunction(value.set)
&& isFunction(value.get)
&& isFunction(value.getAll)
&& isFunction(value.has)
&& isFunction(value.delete)
&& isFunction(value.entries)
&& isFunction(value.values)
&& isFunction(value.keys)
&& isFunction(value[Symbol.iterator])
&& isFunction(value.forEach));
}
append(name, value, fileName) {
FormData_classPrivateFieldGet(this, _FormData_instances, "m", _FormData_setEntry).call(this, {
name,
fileName,
append: true,
rawValue: value,
argsLength: arguments.length
});
}
set(name, value, fileName) {
FormData_classPrivateFieldGet(this, _FormData_instances, "m", _FormData_setEntry).call(this, {
name,
fileName,
append: false,
rawValue: value,
argsLength: arguments.length
});
}
get(name) {
const field = FormData_classPrivateFieldGet(this, _FormData_entries, "f").get(String(name));
if (!field) {
return null;
}
return field[0];
}
getAll(name) {
const field = FormData_classPrivateFieldGet(this, _FormData_entries, "f").get(String(name));
if (!field) {
return [];
}
return field.slice();
}
has(name) {
return FormData_classPrivateFieldGet(this, _FormData_entries, "f").has(String(name));
}
delete(name) {
FormData_classPrivateFieldGet(this, _FormData_entries, "f").delete(String(name));
}
*keys() {
for (const key of FormData_classPrivateFieldGet(this, _FormData_entries, "f").keys()) {
yield key;
}
}
*entries() {
for (const name of this.keys()) {
const values = this.getAll(name);
for (const value of values) {
yield [name, value];
}
}
}
*values() {
for (const [, value] of this) {
yield value;
}
}
[(_FormData_setEntry = function _FormData_setEntry({ name, rawValue, append, fileName, argsLength }) {
const methodName = append ? "append" : "set";
if (argsLength < 2) {
throw new TypeError(`Failed to execute '${methodName}' on 'FormData': `
+ `2 arguments required, but only ${argsLength} present.`);
}
name = String(name);
let value;
if (isFile(rawValue)) {
if (fileName === undefined) {
fileName = rawValue.name === undefined ? "blob" : rawValue.name;
}
value = new File_File([rawValue], String(fileName), {
type: rawValue.type,
lastModified: rawValue.lastModified
});
}
else if (fileName) {
throw new TypeError(`Failed to execute '${methodName}' on 'FormData': `
+ "parameter 2 is not of type 'Blob'.");
}
else {
value = String(rawValue);
}
const values = FormData_classPrivateFieldGet(this, _FormData_entries, "f").get(name);
if (!values) {
return void FormData_classPrivateFieldGet(this, _FormData_entries, "f").set(name, [value]);
}
if (!append) {
return void FormData_classPrivateFieldGet(this, _FormData_entries, "f").set(name, [value]);
}
values.push(value);
}, Symbol.iterator)]() {
return this.entries();
}
forEach(callback, thisArg) {
for (const [name, value] of this) {
callback.call(thisArg, value, name, this);
}
}
get [Symbol.toStringTag]() {
return "FormData";
}
[external_util_.inspect.custom]() {
return this[Symbol.toStringTag];
}
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
;// CONCATENATED MODULE: ./node_modules/formdata-node/lib/esm/index.js
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
// EXTERNAL MODULE: ./node_modules/node-domexception/index.js
var node_domexception = __nccwpck_require__(7760);
;// CONCATENATED MODULE: ./node_modules/formdata-node/lib/esm/isPlainObject.js
const getType = (value) => (Object.prototype.toString.call(value).slice(8, -1).toLowerCase());
function isPlainObject(value) {
if (getType(value) !== "object") {
return false;
}
const pp = Object.getPrototypeOf(value);
if (pp === null || pp === undefined) {
return true;
}
const Ctor = pp.constructor && pp.constructor.toString();
return Ctor === Object.toString();
}
/* harmony default export */ const esm_isPlainObject = (isPlainObject);
;// CONCATENATED MODULE: ./node_modules/formdata-node/lib/esm/fileFromPath.js
var fileFromPath_classPrivateFieldSet = (undefined && undefined.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
if (kind === "m") throw new TypeError("Private method is not writable");
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
};
var fileFromPath_classPrivateFieldGet = (undefined && undefined.__classPrivateFieldGet) || function (receiver, state, kind, f) {
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
};
var _FileFromPath_path, _FileFromPath_start;
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
const MESSAGE = "The requested file could not be read, "
+ "typically due to permission problems that have occurred after a reference "
+ "to a file was acquired.";
class FileFromPath {
constructor(input) {
_FileFromPath_path.set(this, void 0);
_FileFromPath_start.set(this, void 0);
fileFromPath_classPrivateFieldSet(this, _FileFromPath_path, input.path, "f");
fileFromPath_classPrivateFieldSet(this, _FileFromPath_start, input.start || 0, "f");
this.name = (0,external_path_.basename)(fileFromPath_classPrivateFieldGet(this, _FileFromPath_path, "f"));
this.size = input.size;
this.lastModified = input.lastModified;
}
slice(start, end) {
return new FileFromPath({
path: fileFromPath_classPrivateFieldGet(this, _FileFromPath_path, "f"),
lastModified: this.lastModified,
size: end - start,
start
});
}
async *stream() {
const { mtimeMs } = await external_fs_.promises.stat(fileFromPath_classPrivateFieldGet(this, _FileFromPath_path, "f"));
if (mtimeMs > this.lastModified) {
throw new node_domexception(MESSAGE, "NotReadableError");
}
if (this.size) {
yield* (0,external_fs_.createReadStream)(fileFromPath_classPrivateFieldGet(this, _FileFromPath_path, "f"), {
start: fileFromPath_classPrivateFieldGet(this, _FileFromPath_start, "f"),
end: fileFromPath_classPrivateFieldGet(this, _FileFromPath_start, "f") + this.size - 1
});
}
}
get [(_FileFromPath_path = new WeakMap(), _FileFromPath_start = new WeakMap(), Symbol.toStringTag)]() {
return "File";
}
}
function createFileFromPath(path, { mtimeMs, size }, filenameOrOptions, options = {}) {
let filename;
if (esm_isPlainObject(filenameOrOptions)) {
[options, filename] = [filenameOrOptions, undefined];
}
else {
filename = filenameOrOptions;
}
const file = new FileFromPath({ path, size, lastModified: mtimeMs });
if (!filename) {
filename = file.name;
}
return new File_File([file], filename, {
...options, lastModified: file.lastModified
});
}
function fileFromPathSync(path, filenameOrOptions, options = {}) {
const stats = statSync(path);
return createFileFromPath(path, stats, filenameOrOptions, options);
}
async function fileFromPath(path, filenameOrOptions, options) {
const stats = await external_fs_.promises.stat(path);
return createFileFromPath(path, stats, filenameOrOptions, options);
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
// EXTERNAL MODULE: ./node_modules/node-fetch/lib/index.js
var lib = __nccwpck_require__(467);
var lib_default = /*#__PURE__*/__nccwpck_require__.n(lib);
;// CONCATENATED MODULE: external "crypto"
const external_crypto_namespaceObject = require("crypto");
var external_crypto_default = /*#__PURE__*/__nccwpck_require__.n(external_crypto_namespaceObject);
2022-01-12 10:27:38 -05:00
;// CONCATENATED MODULE: ./src/utils/hash-utils.ts
function computeHash(path, algorithm) {
const hash = external_crypto_default().createHash(algorithm);
return new Promise(resolve => external_fs_default().createReadStream(path).on("data", data => hash.update(data)).on("end", () => resolve(hash)));
}
;// CONCATENATED MODULE: ./src/utils/soft-error.ts
class SoftError extends Error {
constructor(soft, message) {
super(message);
this.soft = soft;
}
}
2021-09-26 15:31:45 -04:00
;// CONCATENATED MODULE: ./src/utils/modrinth-utils.ts
var modrinth_utils_awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
2022-01-12 10:27:38 -05:00
function createVersion(modId, data, files, token) {
2021-09-26 15:31:45 -04:00
return modrinth_utils_awaiter(this, void 0, void 0, function* () {
2022-01-12 10:27:38 -05:00
data = Object.assign(Object.assign({ dependencies: [] }, data), { mod_id: modId, file_parts: files.map((_, i) => i.toString()) });
2021-09-26 15:31:45 -04:00
const form = new FormData();
form.append("data", JSON.stringify(data));
for (let i = 0; i < files.length; ++i) {
const file = files[i];
form.append(i.toString(), yield fileFromPath(file.path), file.name);
}
2022-05-31 14:18:28 -04:00
const response = yield lib_default()("https://api.modrinth.com/api/v1/version", {
2021-09-26 15:31:45 -04:00
method: "POST",
headers: { Authorization: token },
body: form
});
if (!response.ok) {
let errorText = response.statusText;
try {
errorText += `, ${yield response.text()}`;
}
catch (_a) { }
2022-01-12 10:27:38 -05:00
const isServerError = response.status >= 500;
throw new SoftError(isServerError, `Failed to upload file: ${response.status} (${errorText})`);
2021-09-26 15:31:45 -04:00
}
2022-01-12 10:27:38 -05:00
const versionId = (yield response.json()).id;
const primaryFile = files[0];
if (primaryFile) {
yield makeFilePrimary(versionId, primaryFile.path, token);
}
return versionId;
});
}
function makeFilePrimary(versionId, filePath, token) {
return modrinth_utils_awaiter(this, void 0, void 0, function* () {
const algorithm = "sha1";
const hash = (yield computeHash(filePath, algorithm)).digest("hex");
2022-05-31 14:18:28 -04:00
const response = yield lib_default()(`https://api.modrinth.com/api/v1/version/${versionId}`, {
2022-01-12 10:27:38 -05:00
method: "PATCH",
headers: {
"Authorization": token,
"Content-Type": "application/json"
},
body: JSON.stringify({
primary_file: [algorithm, hash]
})
});
return response.ok;
2021-09-26 15:31:45 -04:00
});
}
;// CONCATENATED MODULE: ./src/utils/version.ts
class Version {
constructor(major, minor, build) {
if (typeof major === "string") {
[this.major, this.minor, this.build] = major.split(".").map(x => isNaN(+x) ? 0 : +x).concat(0, 0);
}
else {
this.major = major || 0;
this.minor = minor || 0;
this.build = build || 0;
}
}
2021-10-01 09:38:36 -04:00
equals(version) {
if (version instanceof Version) {
return this.major === version.major && this.minor === version.minor && this.build === version.build;
}
return typeof version === "string" && this.equals(new Version(version));
}
2021-09-26 15:31:45 -04:00
}
;// CONCATENATED MODULE: ./src/utils/minecraft-utils.ts
var minecraft_utils_awaiter = (undefined && undefined.__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 MinecraftVersionType;
(function (MinecraftVersionType) {
MinecraftVersionType["Release"] = "release";
MinecraftVersionType["Snapshot"] = "snapshot";
MinecraftVersionType["OldBeta"] = "old_beta";
MinecraftVersionType["OldAlpha"] = "old_alpha";
})(MinecraftVersionType || (MinecraftVersionType = {}));
class MinecraftVersion {
constructor(id, name, type, url, time, releaseTime) {
this.id = id;
this.name = name;
this.version = new Version(name);
this.type = type;
this.url = url;
this.time = time;
this.releaseTime = releaseTime;
}
get isRelease() {
return this.type === MinecraftVersionType.Release;
}
get isSnapshot() {
return this.type === MinecraftVersionType.Snapshot;
}
}
let cachedVersionsById = null;
function getVersionMap() {
return minecraft_utils_awaiter(this, void 0, void 0, function* () {
if (!cachedVersionsById) {
cachedVersionsById = yield loadVersions();
}
return cachedVersionsById;
});
}
function loadVersions() {
return minecraft_utils_awaiter(this, void 0, void 0, function* () {
2022-05-31 14:18:28 -04:00
const response = yield (yield lib_default()("https://launchermeta.mojang.com/mc/game/version_manifest.json")).json();
2021-09-26 15:31:45 -04:00
const versionsById = new Map();
for (let i = 0; i < response.versions.length; ++i) {
const version = response.versions[i];
versionsById.set(version.id, new MinecraftVersion(version.id, getNearestReleaseVersionName(response.versions, i), version.type, version.url, new Date(version.time), new Date(version.releaseTime)));
}
return versionsById;
});
}
function getNearestReleaseVersionName(versions, start) {
for (let i = start; i >= 0; --i) {
if (versions[i].type === MinecraftVersionType.Release) {
return versions[i].id;
}
}
const versionMatch = versions[start].id.match(/\d+\.\d+(?:\.\d+)?/);
if (versionMatch && versionMatch.length > 0) {
return versionMatch[0];
}
for (let i = start + 1; i < versions.length; ++i) {
if (versions[i].type === MinecraftVersionType.Release) {
return extractVersion(versions[i].id).split(".").map((x, i) => i === 1 ? (+x + 1) : x).filter((x, i) => i < 2).join(".");
}
}
return null;
}
function getVersions() {
return minecraft_utils_awaiter(this, void 0, void 0, function* () {
return [...(yield getVersionMap()).values()];
});
}
function getVersionById(id) {
return minecraft_utils_awaiter(this, void 0, void 0, function* () {
return (yield getVersionMap()).get(id.trim()) || null;
});
}
function findVersionByName(name, snapshot) {
return minecraft_utils_awaiter(this, void 0, void 0, function* () {
const versionMap = yield getVersionMap();
snapshot !== null && snapshot !== void 0 ? snapshot : (snapshot = isSnapshot(name));
const foundVersion = versionMap.get(name);
if (foundVersion && foundVersion.isSnapshot === !!snapshot) {
return foundVersion;
}
name = extractVersion(name);
for (const version of versionMap.values()) {
if (version.name === name && version.isSnapshot) {
return version;
}
}
return null;
});
}
function extractVersion(versionName) {
return versionName.match(/(?<![a-z][\w\s\-.]*)\d+/ig).join(".");
}
const weirdOldSnapshots = new Set(["1.7.1", "1.7", "1.6.3", "1.6", "1.5", "1.4.3", "1.4.1", "1.4", "1.3"]);
function isSnapshot(versionName) {
return !versionName.match(/^\s*\d+\.\d+/) || !!versionName.match(/pre|rc|snapshot/i) || weirdOldSnapshots.has(versionName);
}
function parseVersionNameFromFileVersion(fileVersion) {
const mcMatch = fileVersion.match(/mc(\d+\.\d+(?:\.\d+)?)/i);
if (mcMatch) {
return mcMatch[1];
}
else {
const versionCandidates = fileVersion.split(/[+-]/).map(x => x.match(/\d+\.\d+(?:\.\d+)?/)).filter(x => x).map(x => x[0]);
return versionCandidates.length > 1 ? versionCandidates.filter(x => x.startsWith("1.")).reverse()[0] : null;
}
}
2021-12-11 08:00:14 -05:00
function parseVersionName(version) {
const versionCandidates = [...(version.match(/\d+\.\d+(?:\.\d+)?/g) || [])];
return versionCandidates.filter(x => x.startsWith("1."))[0] || null;
}
2021-09-26 15:31:45 -04:00
function getLatestRelease() {
return minecraft_utils_awaiter(this, void 0, void 0, function* () {
return (yield getVersions()).find(x => x.isRelease) || null;
});
}
function getCompatibleBuilds(build) {
return minecraft_utils_awaiter(this, void 0, void 0, function* () {
if (!(build instanceof Version)) {
build = new Version(build);
}
const versions = new Array();
for (const version of yield getVersions()) {
if (version.version.major !== build.major) {
continue;
}
if (version.version.minor < build.minor) {
break;
}
if (version.version.minor === build.minor && version.version.build >= build.build) {
versions.push(version);
}
}
return versions;
});
}
2021-10-01 09:38:36 -04:00
;// CONCATENATED MODULE: ./src/utils/game-version-resolver.ts
var game_version_resolver_awaiter = (undefined && undefined.__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());
});
};
class GameVersionResolver {
constructor(filter) {
this._filter = filter || ((_, x) => x);
}
resolve(version) {
return game_version_resolver_awaiter(this, void 0, void 0, function* () {
return this.filter(version, yield this.getCompatibleVersions(version));
});
}
filter(version, versions) {
return this._filter(version, versions);
}
}
;// CONCATENATED MODULE: ./src/utils/minecraft-version-resolver.ts
class MinecraftVersionResolver extends GameVersionResolver {
static byName(name) {
for (const [key, value] of Object.entries(MinecraftVersionResolver)) {
if (value instanceof MinecraftVersionResolver && key.localeCompare(name, undefined, { sensitivity: "accent" }) === 0) {
return value;
}
}
return null;
}
getCompatibleVersions(version) {
return getCompatibleBuilds(version);
}
}
MinecraftVersionResolver.exact = new MinecraftVersionResolver((n, v) => [v.find(x => x.version.equals(n))].filter(x => x));
MinecraftVersionResolver.latest = new MinecraftVersionResolver((_, v) => v.find(x => x.isRelease) ? [v.find(x => x.isRelease)] : v.length ? [v[0]] : []);
MinecraftVersionResolver.all = new MinecraftVersionResolver((_, v) => v);
MinecraftVersionResolver.releases = new MinecraftVersionResolver((_, v) => v.filter(x => x.isRelease));
MinecraftVersionResolver.releasesIfAny = new MinecraftVersionResolver((_, v) => v.find(x => x.isRelease) ? v.filter(x => x.isRelease) : v);
2021-12-11 08:00:14 -05:00
;// CONCATENATED MODULE: ./src/metadata/mod-loader-type.ts
var ModLoaderType;
(function (ModLoaderType) {
ModLoaderType[ModLoaderType["Fabric"] = 1] = "Fabric";
ModLoaderType[ModLoaderType["Forge"] = 2] = "Forge";
})(ModLoaderType || (ModLoaderType = {}));
(function (ModLoaderType) {
function getValues() {
return Object.values(ModLoaderType).filter(x => typeof x === "number");
}
ModLoaderType.getValues = getValues;
function toString(target) {
var _a;
return (_a = ModLoaderType[target]) !== null && _a !== void 0 ? _a : target.toString();
}
ModLoaderType.toString = toString;
})(ModLoaderType || (ModLoaderType = {}));
/* harmony default export */ const mod_loader_type = (ModLoaderType);
// EXTERNAL MODULE: ./node_modules/node-stream-zip/node_stream_zip.js
var node_stream_zip = __nccwpck_require__(8119);
;// CONCATENATED MODULE: ./src/metadata/zipped-mod-metadata-reader.ts
var zipped_mod_metadata_reader_awaiter = (undefined && undefined.__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());
});
};
class ZippedModMetadataReader {
constructor(configEntryName) {
this.configEntryName = configEntryName;
}
readMetadata(modPath) {
return zipped_mod_metadata_reader_awaiter(this, void 0, void 0, function* () {
let zip = null;
try {
zip = new node_stream_zip.async({ file: modPath });
const buffer = yield zip.entryData(this.configEntryName).catch(_ => null);
if (buffer) {
return this.createMetadataFromConfig(this.loadConfig(buffer));
}
else {
return null;
}
}
catch (_a) {
return null;
}
finally {
yield (zip === null || zip === void 0 ? void 0 : zip.close());
}
});
}
}
;// CONCATENATED MODULE: ./package.json
const package_namespaceObject = {"u2":"mc-publish"};
;// CONCATENATED MODULE: ./src/metadata/mod-config.ts
class ModConfig {
constructor(config) {
this.config = config || {};
}
getProjectId(project) {
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
const projectName = publisher_target.toString(project).toLowerCase();
const custom = this.config["custom"];
const projects = this.config["projects"];
const projectId = ((_l = (_h = (_g = (_e = (_c = (_b = (_a = custom === null || custom === void 0 ? void 0 : custom[package_namespaceObject.u2]) === null || _a === void 0 ? void 0 : _a[projectName]) === null || _b === void 0 ? void 0 : _b.id) !== null && _c !== void 0 ? _c : (_d = custom === null || custom === void 0 ? void 0 : custom[package_namespaceObject.u2]) === null || _d === void 0 ? void 0 : _d[projectName]) !== null && _e !== void 0 ? _e : (_f = projects === null || projects === void 0 ? void 0 : projects[projectName]) === null || _f === void 0 ? void 0 : _f.id) !== null && _g !== void 0 ? _g : projects === null || projects === void 0 ? void 0 : projects[projectName]) !== null && _h !== void 0 ? _h : (_k = (_j = custom === null || custom === void 0 ? void 0 : custom.projects) === null || _j === void 0 ? void 0 : _j[projectName]) === null || _k === void 0 ? void 0 : _k.id) !== null && _l !== void 0 ? _l : (_m = custom === null || custom === void 0 ? void 0 : custom.projects) === null || _m === void 0 ? void 0 : _m[projectName]);
return projectId === undefined ? projectId : String(projectId);
}
}
;// CONCATENATED MODULE: ./src/metadata/dependency-kind.ts
var DependencyKind;
(function (DependencyKind) {
DependencyKind[DependencyKind["Depends"] = 1] = "Depends";
DependencyKind[DependencyKind["Recommends"] = 2] = "Recommends";
DependencyKind[DependencyKind["Includes"] = 3] = "Includes";
DependencyKind[DependencyKind["Suggests"] = 4] = "Suggests";
DependencyKind[DependencyKind["Conflicts"] = 5] = "Conflicts";
DependencyKind[DependencyKind["Breaks"] = 6] = "Breaks";
})(DependencyKind || (DependencyKind = {}));
(function (DependencyKind) {
function getValues() {
return Object.values(DependencyKind).filter(x => typeof x === "number");
}
DependencyKind.getValues = getValues;
function parse(kindName) {
if (typeof DependencyKind[kindName] === "number") {
return DependencyKind[kindName];
}
for (const kind of Object.values(DependencyKind)) {
if (typeof kind === "number" && kindName.localeCompare(DependencyKind[kind], undefined, { sensitivity: "accent" }) === 0) {
return kind;
}
}
return undefined;
}
DependencyKind.parse = parse;
function toString(target) {
var _a;
return (_a = DependencyKind[target]) !== null && _a !== void 0 ? _a : target.toString();
}
DependencyKind.toString = toString;
})(DependencyKind || (DependencyKind = {}));
/* harmony default export */ const dependency_kind = (DependencyKind);
;// CONCATENATED MODULE: ./src/metadata/mod-config-dependency.ts
class ModConfigDependency {
constructor(metadata) {
var _a, _b, _c, _d, _e, _f, _g, _h;
this.id = String((_a = metadata.id) !== null && _a !== void 0 ? _a : "");
this.version = String((_b = metadata.version) !== null && _b !== void 0 ? _b : "*");
this.kind = metadata.kind || dependency_kind.Depends;
this.metadata = metadata;
this.ignore = (_h = (_g = (_e = (_d = (_c = this.metadata["custom"]) === null || _c === void 0 ? void 0 : _c[package_namespaceObject.u2]) === null || _d === void 0 ? void 0 : _d.ignore) !== null && _e !== void 0 ? _e : (_f = this.metadata[package_namespaceObject.u2]) === null || _f === void 0 ? void 0 : _f.ignore) !== null && _g !== void 0 ? _g : this.metadata.ignore) !== null && _h !== void 0 ? _h : false;
}
getProjectSlug(project) {
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
const projectName = publisher_target.toString(project).toLowerCase();
const custom = this.metadata["custom"];
const projects = this.metadata["projects"];
return String((_o = (_l = (_h = (_g = (_e = (_c = (_b = (_a = custom === null || custom === void 0 ? void 0 : custom[package_namespaceObject.u2]) === null || _a === void 0 ? void 0 : _a[projectName]) === null || _b === void 0 ? void 0 : _b.slug) !== null && _c !== void 0 ? _c : (_d = custom === null || custom === void 0 ? void 0 : custom[package_namespaceObject.u2]) === null || _d === void 0 ? void 0 : _d[projectName]) !== null && _e !== void 0 ? _e : (_f = projects === null || projects === void 0 ? void 0 : projects[projectName]) === null || _f === void 0 ? void 0 : _f.slug) !== null && _g !== void 0 ? _g : projects === null || projects === void 0 ? void 0 : projects[projectName]) !== null && _h !== void 0 ? _h : (_k = (_j = custom === null || custom === void 0 ? void 0 : custom.projects) === null || _j === void 0 ? void 0 : _j[projectName]) === null || _k === void 0 ? void 0 : _k.slug) !== null && _l !== void 0 ? _l : (_m = custom === null || custom === void 0 ? void 0 : custom.projects) === null || _m === void 0 ? void 0 : _m[projectName]) !== null && _o !== void 0 ? _o : this.id);
}
}
;// CONCATENATED MODULE: ./src/metadata/dependency.ts
var Dependency;
(function (Dependency) {
function create({ id, version = "*", kind = dependency_kind.Depends, ignore = false, aliases = null }) {
return {
id,
version: version !== null && version !== void 0 ? version : "*",
kind: kind !== null && kind !== void 0 ? kind : dependency_kind.Depends,
ignore: ignore !== null && ignore !== void 0 ? ignore : false,
getProjectSlug: target => (aliases === null || aliases === void 0 ? void 0 : aliases.has(target)) ? aliases.get(target) : id
};
}
Dependency.create = create;
})(Dependency || (Dependency = {}));
/* harmony default export */ const dependency = (Dependency);
;// CONCATENATED MODULE: ./src/metadata/fabric/fabric-mod-metadata.ts
const ignoredByDefault = ["minecraft", "java", "fabricloader"];
const aliases = new Map([
["fabric", "fabric-api"]
]);
function getDependenciesByKind(config, kind) {
const kindName = dependency_kind.toString(kind).toLowerCase();
const dependencies = new Array();
for (const [id, value] of Object.entries(config[kindName] || {})) {
const ignore = ignoredByDefault.includes(id);
if (typeof value === "string") {
const dependencyAliases = aliases.has(id) ? new Map(publisher_target.getValues().map(x => [x, aliases.get(id)])) : null;
dependencies.push(dependency.create({ id, kind, version: value, ignore, aliases: dependencyAliases }));
}
else {
const dependencyMetadata = Object.assign(Object.assign({ ignore }, value), { id, kind });
if (aliases.has(id)) {
if (!dependencyMetadata.custom) {
dependencyMetadata.custom = {};
}
if (!dependencyMetadata.custom[package_namespaceObject.u2]) {
dependencyMetadata.custom[package_namespaceObject.u2] = {};
}
for (const target of publisher_target.getValues()) {
const targetName = publisher_target.toString(target).toLowerCase();
if (typeof dependencyMetadata.custom[package_namespaceObject.u2][targetName] !== "string") {
dependencyMetadata.custom[package_namespaceObject.u2][targetName] = aliases.get(id);
}
}
}
dependencies.push(new ModConfigDependency(dependencyMetadata));
}
}
return dependencies;
}
class FabricModMetadata extends ModConfig {
constructor(config) {
var _a, _b, _c;
super(config);
this.id = String((_a = this.config.id) !== null && _a !== void 0 ? _a : "");
this.name = String((_b = this.config.name) !== null && _b !== void 0 ? _b : this.id);
this.version = String((_c = this.config.version) !== null && _c !== void 0 ? _c : "*");
this.loaders = ["fabric"];
this.dependencies = dependency_kind.getValues().flatMap(x => getDependenciesByKind(this.config, x));
}
getProjectId(project) {
var _a, _b, _c, _d;
const projectId = super.getProjectId(project);
if (projectId) {
return projectId;
}
const projectName = publisher_target.toString(project).toLowerCase();
const custom = this.config.custom;
const modManagerProjectId = (_c = (_b = (_a = custom === null || custom === void 0 ? void 0 : custom.modmanager) === null || _a === void 0 ? void 0 : _a[projectName]) === null || _b === void 0 ? void 0 : _b.id) !== null && _c !== void 0 ? _c : (_d = custom === null || custom === void 0 ? void 0 : custom.modmanager) === null || _d === void 0 ? void 0 : _d[projectName];
return modManagerProjectId === undefined ? modManagerProjectId : String(modManagerProjectId);
}
}
;// CONCATENATED MODULE: ./src/metadata/fabric/fabric-mod-metadata-reader.ts
class FabricModMetadataReader extends ZippedModMetadataReader {
constructor() {
super("fabric.mod.json");
}
loadConfig(buffer) {
return JSON.parse(buffer.toString("utf8"));
}
createMetadataFromConfig(config) {
return new FabricModMetadata(config);
}
}
// EXTERNAL MODULE: ./node_modules/toml/index.js
var toml = __nccwpck_require__(4920);
var toml_default = /*#__PURE__*/__nccwpck_require__.n(toml);
;// CONCATENATED MODULE: ./src/metadata/forge/forge-mod-metadata.ts
const forge_mod_metadata_ignoredByDefault = ["minecraft", "java", "forge"];
function createDependency(body) {
return new ModConfigDependency(Object.assign(Object.assign({ ignore: forge_mod_metadata_ignoredByDefault.includes(body.modId) }, body), { id: body.modId, version: body.versionRange, kind: body.incompatible && dependency_kind.Breaks || body.embedded && dependency_kind.Includes || body.mandatory && dependency_kind.Depends || dependency_kind.Recommends }));
}
class ForgeModMetadata extends ModConfig {
constructor(config) {
super(config);
const mods = Array.isArray(this.config.mods) && this.config.mods || [];
const mod = mods[0];
if (!mod) {
throw new Error("At least one mod should be specified");
}
this.id = mod.modId;
this.name = mod.displayName || this.id;
this.version = mod.version || "*";
this.loaders = ["forge"];
this.dependencies = Object
.values(this.config.dependencies || {})
.filter(Array.isArray)
.flatMap(x => x)
.map(createDependency)
.filter((x, i, self) => self.findIndex(y => x.id === y.id && x.kind === y.kind) === i);
}
}
;// CONCATENATED MODULE: ./src/metadata/forge/forge-mod-metadata-reader.ts
class ForgeModMetadataReader extends ZippedModMetadataReader {
constructor() {
super("META-INF/mods.toml");
}
loadConfig(buffer) {
return toml_default().parse(buffer.toString("utf8"));
}
createMetadataFromConfig(config) {
return new ForgeModMetadata(config);
}
}
;// CONCATENATED MODULE: ./src/metadata/mod-metadata-reader-factory.ts
class ModMetadataReaderFactory {
create(loaderType) {
switch (loaderType) {
case mod_loader_type.Fabric:
return new FabricModMetadataReader();
case mod_loader_type.Forge:
return new ForgeModMetadataReader();
default:
throw new Error(`Unknown mod loader "${mod_loader_type.toString(loaderType)}"`);
}
}
}
;// CONCATENATED MODULE: ./src/metadata/mod-metadata-reader.ts
var mod_metadata_reader_awaiter = (undefined && undefined.__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 ModMetadataReader;
(function (ModMetadataReader) {
function readMetadata(modPath) {
return mod_metadata_reader_awaiter(this, void 0, void 0, function* () {
const factory = new ModMetadataReaderFactory();
for (const loaderType of mod_loader_type.getValues()) {
const metadata = yield factory.create(loaderType).readMetadata(modPath).catch(_ => null);
if (metadata) {
return metadata;
}
}
return null;
});
}
ModMetadataReader.readMetadata = readMetadata;
})(ModMetadataReader || (ModMetadataReader = {}));
/* harmony default export */ const mod_metadata_reader = (ModMetadataReader);
;// CONCATENATED MODULE: ./src/utils/version-utils.ts
function parseVersionFromName(name) {
const match = name.match(/[a-z]{0,2}\d+\.\d+.*/i);
return match ? match[0] : name;
}
function parseVersionTypeFromName(name) {
if (name.match(/[+-_]alpha/i)) {
return "alpha";
}
else if (name.match(/[+-_]beta/i)) {
return "beta";
}
else {
return "release";
}
}
2021-09-26 15:31:45 -04:00
;// CONCATENATED MODULE: ./src/publishing/mod-publisher.ts
var mod_publisher_awaiter = (undefined && undefined.__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-01 09:38:36 -04:00
2021-12-11 08:00:14 -05:00
2021-09-26 15:31:45 -04:00
function processMultilineInput(input, splitter) {
if (!input) {
return [];
}
return (typeof input === "string" ? input.split(splitter || /(\r?\n)+/) : input).map(x => x.trim()).filter(x => x);
}
2021-12-11 08:00:14 -05:00
function processDependenciesInput(input, inputSplitter, entrySplitter) {
return processMultilineInput(input, inputSplitter).map(x => {
var _a;
const parts = x.split(entrySplitter || /\|/);
const id = parts[0].trim();
return dependency.create({
id,
kind: parts[1] && dependency_kind.parse(parts[1].trim()) || dependency_kind.Depends,
version: ((_a = parts[2]) === null || _a === void 0 ? void 0 : _a.trim()) || "*"
});
});
}
function readChangelog(changelogPath) {
2021-09-26 15:31:45 -04:00
return mod_publisher_awaiter(this, void 0, void 0, function* () {
2021-12-11 08:00:14 -05:00
const file = (yield getFiles(changelogPath))[0];
2021-09-26 15:31:45 -04:00
if (!file) {
throw new Error("Changelog file was not found");
}
return (yield file.getBuffer()).toString("utf8");
});
}
class ModPublisher extends Publisher {
2021-10-01 09:38:36 -04:00
publish(files, options) {
2021-09-26 15:31:45 -04:00
var _a, _b;
return mod_publisher_awaiter(this, void 0, void 0, function* () {
2021-10-01 09:38:36 -04:00
this.validateOptions(options);
2021-09-26 15:31:45 -04:00
const releaseInfo = github.context.payload.release;
2021-12-11 08:00:14 -05:00
if (!Array.isArray(files) || !files.length) {
throw new Error("No upload files were specified");
2021-09-26 15:31:45 -04:00
}
2021-10-01 09:38:36 -04:00
const token = options.token;
2021-09-26 15:31:45 -04:00
if (!token) {
throw new Error(`Token is required to publish your assets to ${publisher_target.toString(this.target)}`);
}
2021-12-11 08:00:14 -05:00
const metadata = yield mod_metadata_reader.readMetadata(files[0].path);
const id = options.id || (metadata === null || metadata === void 0 ? void 0 : metadata.getProjectId(this.target));
if (!id) {
throw new Error(`Project id is required to publish your assets to ${publisher_target.toString(this.target)}`);
}
const filename = external_path_default().parse(files[0].path).name;
const version = (typeof options.version === "string" && options.version) || (releaseInfo === null || releaseInfo === void 0 ? void 0 : releaseInfo.tag_name) || (metadata === null || metadata === void 0 ? void 0 : metadata.version) || parseVersionFromName(filename);
const versionType = ((_a = options.versionType) === null || _a === void 0 ? void 0 : _a.toLowerCase()) || parseVersionTypeFromName((metadata === null || metadata === void 0 ? void 0 : metadata.version) || filename);
2021-10-01 09:38:36 -04:00
const name = typeof options.name === "string" ? options.name : ((releaseInfo === null || releaseInfo === void 0 ? void 0 : releaseInfo.name) || version);
2021-12-11 08:00:14 -05:00
const changelog = typeof options.changelog === "string"
? options.changelog
: ((_b = options.changelog) === null || _b === void 0 ? void 0 : _b.file)
? yield readChangelog(options.changelog.file)
: (releaseInfo === null || releaseInfo === void 0 ? void 0 : releaseInfo.body) || "";
2021-10-01 09:38:36 -04:00
const loaders = processMultilineInput(options.loaders, /\s+/);
2021-09-26 15:31:45 -04:00
if (!loaders.length) {
2021-12-11 08:00:14 -05:00
if (metadata) {
loaders.push(...metadata.loaders);
}
if (!loaders.length) {
throw new Error("At least one mod loader should be specified");
}
2021-09-26 15:31:45 -04:00
}
2021-10-01 09:38:36 -04:00
const gameVersions = processMultilineInput(options.gameVersions);
2021-09-26 15:31:45 -04:00
if (!gameVersions.length) {
2021-12-11 08:00:14 -05:00
const minecraftVersion = (metadata === null || metadata === void 0 ? void 0 : metadata.dependencies.filter(x => x.id === "minecraft").map(x => parseVersionName(x.version))[0]) ||
parseVersionNameFromFileVersion(version);
2021-09-26 15:31:45 -04:00
if (minecraftVersion) {
2021-10-01 09:38:36 -04:00
const resolver = options.versionResolver && MinecraftVersionResolver.byName(options.versionResolver) || MinecraftVersionResolver.releasesIfAny;
gameVersions.push(...(yield resolver.resolve(minecraftVersion)).map(x => x.id));
2021-09-26 15:31:45 -04:00
}
if (!gameVersions.length) {
throw new Error("At least one game version should be specified");
}
}
2021-10-01 09:38:36 -04:00
const java = processMultilineInput(options.java);
2021-12-11 08:00:14 -05:00
const dependencies = typeof options.dependencies === "string"
? processDependenciesInput(options.dependencies)
: (metadata === null || metadata === void 0 ? void 0 : metadata.dependencies) || [];
const uniqueDependencies = dependencies.filter((x, i, self) => !x.ignore && self.findIndex(y => y.id === x.id && y.kind === x.kind) === i);
yield this.publishMod(id, token, name, version, versionType, loaders, gameVersions, java, changelog, files, uniqueDependencies);
2021-09-26 15:31:45 -04:00
});
}
}
2021-12-11 08:00:14 -05:00
;// CONCATENATED MODULE: ./src/publishing/modrinth/modrinth-publisher.ts
2021-09-26 15:31:45 -04:00
var modrinth_publisher_awaiter = (undefined && undefined.__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());
});
};
class ModrinthPublisher extends ModPublisher {
get target() {
return publisher_target.Modrinth;
}
publishMod(id, token, name, version, channel, loaders, gameVersions, _java, changelog, files) {
return modrinth_publisher_awaiter(this, void 0, void 0, function* () {
const data = {
2021-10-01 09:38:36 -04:00
version_title: name || version,
2021-09-26 15:31:45 -04:00
version_number: version,
version_body: changelog,
release_channel: channel,
game_versions: gameVersions,
loaders,
featured: true,
};
yield createVersion(id, data, files, token);
});
}
}
;// CONCATENATED MODULE: ./src/utils/curseforge-utils.ts
var curseforge_utils_awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
2022-01-12 10:27:38 -05:00
2021-09-26 15:31:45 -04:00
const baseUrl = "https://minecraft.curseforge.com/api";
2022-01-12 10:27:38 -05:00
class CurseForgeUploadError extends SoftError {
constructor(soft, message, info) {
super(soft, message);
2021-12-11 08:00:14 -05:00
this.info = info;
}
}
2021-09-26 15:31:45 -04:00
let cachedCurseForgeVersions = null;
function getCurseForgeVersions(token) {
return curseforge_utils_awaiter(this, void 0, void 0, function* () {
if (!cachedCurseForgeVersions) {
cachedCurseForgeVersions = yield loadCurseForgeVersions(token);
}
return cachedCurseForgeVersions;
});
}
function loadCurseForgeVersions(token) {
return curseforge_utils_awaiter(this, void 0, void 0, function* () {
2022-05-31 14:18:28 -04:00
const versionTypes = yield (yield lib_default()(`${baseUrl}/game/version-types?token=${token}`)).json();
2021-09-26 15:31:45 -04:00
const javaVersionTypes = versionTypes.filter(x => x.slug.startsWith("java")).map(x => x.id);
const minecraftVersionTypes = versionTypes.filter(x => x.slug.startsWith("minecraft")).map(x => x.id);
const loaderVersionTypes = versionTypes.filter(x => x.slug.startsWith("modloader")).map(x => x.id);
2022-05-31 14:18:28 -04:00
const versions = yield (yield lib_default()(`${baseUrl}/game/versions?token=${token}`)).json();
2021-09-26 15:31:45 -04:00
return versions.reduce((container, version) => {
if (javaVersionTypes.includes(version.gameVersionTypeID)) {
container.java.push(version);
}
else if (minecraftVersionTypes.includes(version.gameVersionTypeID)) {
container.gameVersions.push(version);
}
else if (loaderVersionTypes.includes(version.gameVersionTypeID)) {
container.loaders.push(version);
}
return container;
}, { gameVersions: new Array(), loaders: new Array(), java: new Array() });
});
}
function unifyGameVersion(gameVersion) {
return curseforge_utils_awaiter(this, void 0, void 0, function* () {
gameVersion = gameVersion.trim();
const minecraftVersion = yield findVersionByName(gameVersion);
if (minecraftVersion) {
return `${minecraftVersion.name}${(minecraftVersion.isSnapshot ? "-Snapshot" : "")}`;
}
return gameVersion.replace(/([^\w]|_)+/g, ".").replace(/[.-][a-zA-Z]\w+$/, "-Snapshot");
});
}
function unifyJava(java) {
java = java.trim();
const match = java.match(/(?:\d+\D)?(\d+)$/);
if (match && match.length === 2) {
return `Java ${match[1]}`;
}
return java;
}
function addVersionIntersectionToSet(curseForgeVersions, versions, unify, comparer, intersection) {
return curseforge_utils_awaiter(this, void 0, void 0, function* () {
for (const version of versions) {
const unifiedVersion = yield unify(version);
const curseForgeVersion = curseForgeVersions.find(x => comparer(x, unifiedVersion));
if (curseForgeVersion) {
intersection.add(curseForgeVersion.id);
}
}
});
}
function convertToCurseForgeVersions(gameVersions, loaders, java, token) {
return curseforge_utils_awaiter(this, void 0, void 0, function* () {
const versions = new Set();
const curseForgeVersions = yield getCurseForgeVersions(token);
yield addVersionIntersectionToSet(curseForgeVersions.gameVersions, gameVersions, unifyGameVersion, (cfv, v) => cfv.name === v, versions);
yield addVersionIntersectionToSet(curseForgeVersions.loaders, loaders, x => x.trim().toLowerCase(), (cfv, v) => cfv.slug === v, versions);
yield addVersionIntersectionToSet(curseForgeVersions.java, java, unifyJava, (cfv, v) => cfv.name === v, versions);
return [...versions];
});
}
function uploadFile(id, data, file, token) {
2022-05-31 14:18:28 -04:00
var _a;
2021-09-26 15:31:45 -04:00
return curseforge_utils_awaiter(this, void 0, void 0, function* () {
2022-05-31 14:18:28 -04:00
if (Array.isArray((_a = data.relations) === null || _a === void 0 ? void 0 : _a.projects) && (!data.relations.projects.length || data.parentFileID)) {
delete data.relations;
}
if (data.gameVersions && data.parentFileID) {
delete data.gameVersions;
}
2021-09-26 15:31:45 -04:00
const form = new FormData();
form.append("file", yield fileFromPath(file.path), file.name);
form.append("metadata", JSON.stringify(data));
2022-05-31 14:18:28 -04:00
const response = yield lib_default()(`${baseUrl}/projects/${id}/upload-file?token=${token}`, {
2021-09-26 15:31:45 -04:00
method: "POST",
body: form
});
if (!response.ok) {
let errorText = response.statusText;
2021-12-11 08:00:14 -05:00
let info;
2021-09-26 15:31:45 -04:00
try {
2021-12-11 08:00:14 -05:00
info = (yield response.json());
errorText += `, ${JSON.stringify(info)}`;
2021-09-26 15:31:45 -04:00
}
2022-05-31 14:18:28 -04:00
catch (_b) { }
2022-01-12 10:27:38 -05:00
const isServerError = response.status >= 500;
throw new CurseForgeUploadError(isServerError, `Failed to upload file: ${response.status} (${errorText})`, info);
2021-09-26 15:31:45 -04:00
}
return (yield response.json()).id;
});
}
2021-12-11 08:00:14 -05:00
;// CONCATENATED MODULE: ./src/publishing/curseforge/curseforge-publisher.ts
var curseforge_publisher_awaiter = (undefined && undefined.__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());
});
};
const forgeDependencyKinds = new Map([
[dependency_kind.Depends, "requiredDependency"],
[dependency_kind.Recommends, "optionalDependency"],
[dependency_kind.Suggests, "optionalDependency"],
[dependency_kind.Includes, "embeddedLibrary"],
[dependency_kind.Breaks, "incompatible"],
]);
class CurseForgePublisher extends ModPublisher {
get target() {
return publisher_target.CurseForge;
}
publishMod(id, token, name, _version, channel, loaders, gameVersions, java, changelog, files, dependencies) {
return curseforge_publisher_awaiter(this, void 0, void 0, function* () {
let parentFileId = undefined;
const versions = yield convertToCurseForgeVersions(gameVersions, loaders, java, token);
const projects = dependencies
.filter((x, _, self) => x.kind !== dependency_kind.Suggests || !self.find(y => y.id === x.id && y.kind !== dependency_kind.Suggests))
.map(x => ({
slug: x.getProjectSlug(this.target),
type: forgeDependencyKinds.get(x.kind)
}))
.filter(x => x.slug && x.type);
for (const file of files) {
const data = {
changelog,
changelogType: "markdown",
displayName: (parentFileId || !name) ? file.name : name,
parentFileID: parentFileId,
releaseType: channel,
gameVersions: parentFileId ? undefined : versions,
relations: (parentFileId || !projects.length) ? undefined : { projects }
};
const fileId = yield this.upload(id, data, file, token);
if (!parentFileId) {
parentFileId = fileId;
}
}
});
}
upload(id, data, file, token) {
var _a, _b;
return curseforge_publisher_awaiter(this, void 0, void 0, function* () {
while (true) {
try {
return yield uploadFile(id, data, file, token);
}
catch (error) {
if (((_a = error === null || error === void 0 ? void 0 : error.info) === null || _a === void 0 ? void 0 : _a.errorCode) === 1018 && typeof error.info.errorMessage === "string") {
const match = error.info.errorMessage.match(/Invalid slug in project relations: '([^']+)'/);
const projects = (_b = data.relations) === null || _b === void 0 ? void 0 : _b.projects;
if (match && (projects === null || projects === void 0 ? void 0 : projects.length)) {
const invalidSlugIndex = projects.findIndex(x => x.slug === match[1]);
if (invalidSlugIndex !== -1) {
projects.splice(invalidSlugIndex, 1);
continue;
}
}
}
throw error;
}
}
});
}
}
;// CONCATENATED MODULE: ./src/publishing/publisher-factory.ts
class PublisherFactory {
create(target, logger) {
switch (target) {
case publisher_target.GitHub:
return new GitHubPublisher(logger);
case publisher_target.Modrinth:
return new ModrinthPublisher(logger);
case publisher_target.CurseForge:
return new CurseForgePublisher(logger);
default:
throw new Error(`Unknown target "${publisher_target.toString(target)}"`);
}
}
}
;// CONCATENATED MODULE: external "process"
const external_process_namespaceObject = require("process");
var external_process_default = /*#__PURE__*/__nccwpck_require__.n(external_process_namespaceObject);
;// CONCATENATED MODULE: ./src/utils/input-utils.ts
const undefinedValue = "${undefined}";
function getInputAsObject() {
const inputs = Object.entries((external_process_default()).env).filter(([key, _]) => key.startsWith("INPUT_"));
const input = {};
for (const [name, value] of inputs) {
const words = name.substring(6).toLowerCase().split(/[\W_]/).filter(x => x);
init(input, words, value);
}
return input;
}
function init(root, path, value) {
if (value === undefinedValue) {
return;
}
const name = path.reduce((a, b, i) => a + (i === 0 ? b : (b.substring(0, 1).toUpperCase() + b.substring(1))), "");
root[name] = value;
if (path.length === 1) {
return;
}
const innerPath = path[0];
const inner = root[innerPath] ? root[innerPath] : (root[innerPath] = {});
if (typeof inner === "object") {
init(inner, path.slice(1), value);
}
}
2022-01-12 10:27:38 -05:00
;// CONCATENATED MODULE: ./src/utils/sleep.ts
function sleep(ms) {
return new Promise(resolve => setTimeout(resolve, ms));
}
;// CONCATENATED MODULE: ./src/utils/function-utils.ts
var function_utils_awaiter = (undefined && undefined.__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());
});
};
function retry({ func, delay = 0, maxAttempts = -1, softErrorPredicate, errorCallback }) {
return function_utils_awaiter(this, void 0, void 0, function* () {
let attempts = 0;
while (true) {
try {
return yield func();
}
catch (e) {
const isSoft = softErrorPredicate ? softErrorPredicate(e) : e === null || e === void 0 ? void 0 : e.soft;
if (!isSoft || maxAttempts >= 0 && ++attempts >= maxAttempts) {
throw e;
}
if (errorCallback) {
errorCallback(e);
}
}
yield sleep(delay);
}
});
}
2021-12-11 08:00:14 -05:00
;// CONCATENATED MODULE: ./src/index.ts
var src_awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
2022-01-12 10:27:38 -05:00
2021-12-11 08:00:14 -05:00
function main() {
2022-01-12 10:27:38 -05:00
var _a, _b;
2021-12-11 08:00:14 -05:00
return src_awaiter(this, void 0, void 0, function* () {
const commonOptions = getInputAsObject();
const publisherFactory = new PublisherFactory();
const logger = getDefaultLogger();
const publishedTo = new Array();
for (const target of publisher_target.getValues()) {
const targetName = publisher_target.toString(target);
const publisherOptions = commonOptions[targetName.toLowerCase()];
if (!(publisherOptions === null || publisherOptions === void 0 ? void 0 : publisherOptions.token) || typeof publisherOptions.token !== "string") {
continue;
}
const options = Object.assign(Object.assign({}, commonOptions), publisherOptions);
const fileSelector = options.files && (typeof (options.files) === "string" || options.files.primary) ? options.files : gradleOutputSelector;
const files = yield getRequiredFiles(fileSelector);
2022-01-12 10:27:38 -05:00
const retryAttempts = +((_a = options.retry) === null || _a === void 0 ? void 0 : _a["attempts"]) || 0;
const retryDelay = +((_b = options.retry) === null || _b === void 0 ? void 0 : _b["delay"]) || 0;
2021-12-11 08:00:14 -05:00
const publisher = publisherFactory.create(target, logger);
logger.info(`Publishing assets to ${targetName}...`);
const start = new Date();
2022-01-12 10:27:38 -05:00
yield retry({
func: () => publisher.publish(files, options),
maxAttempts: retryAttempts,
delay: retryDelay,
errorCallback: e => {
logger.error(`${e}`);
logger.info(`Retrying to publish assets to ${targetName} in ${retryDelay} ms...`);
}
});
const end = new Date();
logger.info(`Successfully published assets to ${targetName} (in ${end.getTime() - start.getTime()} ms)`);
2021-12-11 08:00:14 -05:00
publishedTo.push(targetName);
}
if (publishedTo.length) {
logger.info(`Your assets have been successfully published to: ${publishedTo.join(", ")}`);
}
else {
logger.warn("You didn't specify any targets, your assets have not been published");
}
});
}
2022-01-12 10:27:38 -05:00
main().catch(error => getDefaultLogger().fatal(error instanceof Error ? `${error}` : `Something went horribly wrong: ${error}`));
2021-12-11 08:00:14 -05:00
/***/ }),
/***/ 2877:
/***/ ((module) => {
module.exports = eval("require")("encoding");
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 9491:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
"use strict";
module.exports = require("assert");
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 2361:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
"use strict";
module.exports = require("events");
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 7147:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
"use strict";
module.exports = require("fs");
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 3685:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
"use strict";
module.exports = require("http");
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 5687:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
"use strict";
module.exports = require("https");
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 1808:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2021-12-11 08:00:14 -05:00
"use strict";
module.exports = require("net");
2021-09-26 15:31:45 -04:00
2021-12-11 08:00:14 -05:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 2037:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2021-12-11 08:00:14 -05:00
"use strict";
module.exports = require("os");
2021-09-26 15:31:45 -04:00
2021-12-11 08:00:14 -05:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 1017:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2021-12-11 08:00:14 -05:00
"use strict";
module.exports = require("path");
2021-09-26 15:31:45 -04:00
2021-12-11 08:00:14 -05:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 5477:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2021-12-11 08:00:14 -05:00
"use strict";
module.exports = require("punycode");
2021-09-26 15:31:45 -04:00
2021-12-11 08:00:14 -05:00
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 2781:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2021-12-11 08:00:14 -05:00
"use strict";
module.exports = require("stream");
2021-09-26 15:31:45 -04:00
2021-12-11 08:00:14 -05:00
/***/ }),
2021-10-01 09:38:36 -04:00
2022-05-31 14:18:28 -04:00
/***/ 4404:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
2021-09-26 15:31:45 -04:00
2021-12-11 08:00:14 -05:00
"use strict";
module.exports = require("tls");
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 7310:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
"use strict";
module.exports = require("url");
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 3837:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
"use strict";
module.exports = require("util");
/***/ }),
2021-09-26 15:31:45 -04:00
2022-05-31 14:18:28 -04:00
/***/ 1267:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
"use strict";
module.exports = require("worker_threads");
/***/ }),
2022-05-31 14:18:28 -04:00
/***/ 9796:
2021-12-11 08:00:14 -05:00
/***/ ((module) => {
"use strict";
module.exports = require("zlib");
2022-05-31 14:18:28 -04:00
/***/ }),
/***/ 1907:
/***/ ((module) => {
"use strict";
module.exports = JSON.parse('[[[0,44],"disallowed_STD3_valid"],[[45,46],"valid"],[[47,47],"disallowed_STD3_valid"],[[48,57],"valid"],[[58,64],"disallowed_STD3_valid"],[[65,65],"mapped",[97]],[[66,66],"mapped",[98]],[[67,67],"mapped",[99]],[[68,68],"mapped",[100]],[[69,69],"mapped",[101]],[[70,70],"mapped",[102]],[[71,71],"mapped",[103]],[[72,72],"mapped",[104]],[[73,73],"mapped",[105]],[[74,74],"mapped",[106]],[[75,75],"mapped",[107]],[[76,76],"mapped",[108]],[[77,77],"mapped",[109]],[[78,78],"mapped",[110]],[[79,79],"mapped",[111]],[[80,80],"mapped",[112]],[[81,81],"mapped",[113]],[[82,82],"mapped",[114]],[[83,83],"mapped",[115]],[[84,84],"mapped",[116]],[[85,85],"mapped",[117]],[[86,86],"mapped",[118]],[[87,87],"mapped",[119]],[[88,88],"mapped",[120]],[[89,89],"mapped",[121]],[[90,90],"mapped",[122]],[[91,96],"disallowed_STD3_valid"],[[97,122],"valid"],[[123,127],"disallowed_STD3_valid"],[[128,159],"disallowed"],[[160,160],"disallowed_STD3_mapped",[32]],[[161,167],"valid",[],"NV8"],[[168,168],"disallowed_STD3_mapped",[32,776]],[[169,169],"valid",[],"NV8"],[[170,170],"mapped",[97]],[[171,172],"valid",[],"NV8"],[[173,173],"ignored"],[[174,174],"valid",[],"NV8"],[[175,175],"disallowed_STD3_mapped",[32,772]],[[176,177],"valid",[],"NV8"],[[178,178],"mapped",[50]],[[179,179],"mapped",[51]],[[180,180],"disallowed_STD3_mapped",[32,769]],[[181,181],"mapped",[956]],[[182,182],"valid",[],"NV8"],[[183,183],"valid"],[[184,184],"disallowed_STD3_mapped",[32,807]],[[185,185],"mapped",[49]],[[186,186],"mapped",[111]],[[187,187],"valid",[],"NV8"],[[188,188],"mapped",[49,8260,52]],[[189,189],"mapped",[49,8260,50]],[[190,190],"mapped",[51,8260,52]],[[191,191],"valid",[],"NV8"],[[192,192],"mapped",[224]],[[193,193],"mapped",[225]],[[194,194],"mapped",[226]],[[195,195],"mapped",[227]],[[196,196],"mapped",[228]],[[197,197],"mapped",[229]],[[198,198],"mapped",[230]],[[199,199],"mapped",[231]],[[200,200],"mapped",[232]],[[201,201],"mapped",[233]],[[202,202],"mapped",[234]],[[203,203],"mapped",[235]],[[204,204],"mapped",[236]],[[205,205],"mapped",[237]],[[206,206],"mapped",[238]],[[207,207],"mapped",[239]],[[208,208],"mapped",[240]],[[209,209],"mapped",[241]],[[210,210],"mapped",[242]],[[211,211],"mapped",[243]],[[212,212],"mapped",[244]],[[213,213],"mapped",[245]],[[214,214],"mapped",[246]],[[215,215],"valid",[],"NV8"],[[216,216],"mapped",[248]],[[217,217],"mapped",[249]],[[218,218],"mapped",[250]],[[219,219],"mapped",[251]],[[220,220],"mapped",[252]],[[221,221],"mapped",[253]],[[222,222],"mapped",[254]],[[223,223],"deviation",[115,115]],[[224,246],"valid"],[[247,247],"valid",[],"NV8"],[[248,255],"valid"],[[256,256],"mapped",[257]],[[257,257],"valid"],[[258,258],"mapped",[259]],[[259,259],"valid"],[[260,260],"mapped",[261]],[[261,261],"valid"],[[262,262],"mapped",[263]],[[263,263],"valid"],[[264,264],"mapped",[265]],[[265,265],"valid"],[[266,266],"mapped",[267]],[[267,267],"valid"],[[268,268],"mapped",[269]],[[269,269],"valid"],[[270,270],"mapped",[271]],[[271,271],"valid"],[[272,272],"mapped",[273]],[[273,273],"valid"],[[274,274],"mapped",[275]],[[275,275],"valid"],[[276,276],"mapped",[277]],[[277,277],"valid"],[[278,278],"mapped",[279]],[[279,279],"valid"],[[280,280],"mapped",[281]],[[281,281],"valid"],[[282,282],"mapped",[283]],[[283,283],"valid"],[[284,284],"mapped",[285]],[[285,285],"valid"],[[286,286],"mapped",[287]],[[287,287],"valid"],[[288,288],"mapped",[289]],[[289,289],"valid"],[[290,290],"mapped",[291]],[[291,291],"valid"],[[292,292],"mapped",[293]],[[293,293],"valid"],[[294,294],"mapped",[295]],[[295,295],"valid"],[[296,296],"mapped",[297]],[[297,297],"valid"],[[298,298],"mapped",[299]],[[299,299],"valid"],[[300,300],"mapped",[301]],[[301,301],"valid"],[[302,302],"mapped",[303]],[[303,303],"valid"],[[304,304],"mapped",[105,775]],[[305,305],"valid"],[[306,307],"mapped",[105,106]],[[308,308],"mapped",[309]],[[309,309],"valid"],[[310,310],"mapped",[311]],[[311,312],"valid"],[[313,313],"mapped",[314]],[[314,314],"valid"],[[315,315],"mapped",[316]],[[316,316],"valid"],[[317,317],"mapped",[318]],[[318,318],"valid"],[[319,320],"mapped",
2021-12-11 08:00:14 -05:00
/***/ })
/******/ });
/************************************************************************/
/******/ // The module cache
/******/ var __webpack_module_cache__ = {};
/******/
/******/ // The require function
/******/ function __nccwpck_require__(moduleId) {
/******/ // Check if module is in cache
/******/ var cachedModule = __webpack_module_cache__[moduleId];
/******/ if (cachedModule !== undefined) {
/******/ return cachedModule.exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = __webpack_module_cache__[moduleId] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ var threw = true;
/******/ try {
/******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __nccwpck_require__);
/******/ threw = false;
/******/ } finally {
/******/ if(threw) delete __webpack_module_cache__[moduleId];
/******/ }
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/************************************************************************/
/******/ /* webpack/runtime/compat get default export */
/******/ (() => {
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __nccwpck_require__.n = (module) => {
/******/ var getter = module && module.__esModule ?
/******/ () => (module['default']) :
/******/ () => (module);
/******/ __nccwpck_require__.d(getter, { a: getter });
/******/ return getter;
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/define property getters */
/******/ (() => {
/******/ // define getter functions for harmony exports
/******/ __nccwpck_require__.d = (exports, definition) => {
/******/ for(var key in definition) {
/******/ if(__nccwpck_require__.o(definition, key) && !__nccwpck_require__.o(exports, key)) {
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ }
/******/ }
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/hasOwnProperty shorthand */
/******/ (() => {
/******/ __nccwpck_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
/******/ })();
/******/
/******/ /* webpack/runtime/make namespace object */
/******/ (() => {
/******/ // define __esModule on exports
/******/ __nccwpck_require__.r = (exports) => {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/compat */
/******/
/******/ if (typeof __nccwpck_require__ !== 'undefined') __nccwpck_require__.ab = __dirname + "/";
/******/
/************************************************************************/
/******/
/******/ // startup
/******/ // Load entry module and return exports
/******/ // This entry module doesn't tell about it's top-level declarations so it can't be inlined
2022-05-31 14:18:28 -04:00
/******/ var __webpack_exports__ = __nccwpck_require__(8047);
2021-12-11 08:00:14 -05:00
/******/ module.exports = __webpack_exports__;
/******/
2021-09-26 15:31:45 -04:00
/******/ })()
;
//# sourceMappingURL=index.js.map