"use strict"; var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __commonJS = (cb, mod) => function __require() { return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; }; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // ../../node_modules/.pnpm/path-to-regexp@6.1.0/node_modules/path-to-regexp/dist/index.js var require_dist = __commonJS({ "../../node_modules/.pnpm/path-to-regexp@6.1.0/node_modules/path-to-regexp/dist/index.js"(exports) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); function lexer(str) { var tokens = []; var i = 0; while (i < str.length) { var char = str[i]; if (char === "*" || char === "+" || char === "?") { tokens.push({ type: "MODIFIER", index: i, value: str[i++] }); continue; } if (char === "\\") { tokens.push({ type: "ESCAPED_CHAR", index: i++, value: str[i++] }); continue; } if (char === "{") { tokens.push({ type: "OPEN", index: i, value: str[i++] }); continue; } if (char === "}") { tokens.push({ type: "CLOSE", index: i, value: str[i++] }); continue; } if (char === ":") { var name = ""; var j = i + 1; while (j < str.length) { var code = str.charCodeAt(j); if ( // `0-9` code >= 48 && code <= 57 || // `A-Z` code >= 65 && code <= 90 || // `a-z` code >= 97 && code <= 122 || // `_` code === 95 ) { name += str[j++]; continue; } break; } if (!name) throw new TypeError("Missing parameter name at " + i); tokens.push({ type: "NAME", index: i, value: name }); i = j; continue; } if (char === "(") { var count = 1; var pattern = ""; var j = i + 1; if (str[j] === "?") { throw new TypeError('Pattern cannot start with "?" at ' + j); } while (j < str.length) { if (str[j] === "\\") { pattern += str[j++] + str[j++]; continue; } if (str[j] === ")") { count--; if (count === 0) { j++; break; } } else if (str[j] === "(") { count++; if (str[j + 1] !== "?") { throw new TypeError("Capturing groups are not allowed at " + j); } } pattern += str[j++]; } if (count) throw new TypeError("Unbalanced pattern at " + i); if (!pattern) throw new TypeError("Missing pattern at " + i); tokens.push({ type: "PATTERN", index: i, value: pattern }); i = j; continue; } tokens.push({ type: "CHAR", index: i, value: str[i++] }); } tokens.push({ type: "END", index: i, value: "" }); return tokens; } function parse(str, options) { if (options === void 0) { options = {}; } var tokens = lexer(str); var _a = options.prefixes, prefixes = _a === void 0 ? "./" : _a; var defaultPattern = "[^" + escapeString(options.delimiter || "/#?") + "]+?"; var result = []; var key = 0; var i = 0; var path = ""; var tryConsume = function(type) { if (i < tokens.length && tokens[i].type === type) return tokens[i++].value; }; var mustConsume = function(type) { var value2 = tryConsume(type); if (value2 !== void 0) return value2; var _a2 = tokens[i], nextType = _a2.type, index = _a2.index; throw new TypeError("Unexpected " + nextType + " at " + index + ", expected " + type); }; var consumeText = function() { var result2 = ""; var value2; while (value2 = tryConsume("CHAR") || tryConsume("ESCAPED_CHAR")) { result2 += value2; } return result2; }; while (i < tokens.length) { var char = tryConsume("CHAR"); var name = tryConsume("NAME"); var pattern = tryConsume("PATTERN"); if (name || pattern) { var prefix = char || ""; if (prefixes.indexOf(prefix) === -1) { path += prefix; prefix = ""; } if (path) { result.push(path); path = ""; } result.push({ name: name || key++, prefix, suffix: "", pattern: pattern || defaultPattern, modifier: tryConsume("MODIFIER") || "" }); continue; } var value = char || tryConsume("ESCAPED_CHAR"); if (value) { path += value; continue; } if (path) { result.push(path); path = ""; } var open = tryConsume("OPEN"); if (open) { var prefix = consumeText(); var name_1 = tryConsume("NAME") || ""; var pattern_1 = tryConsume("PATTERN") || ""; var suffix = consumeText(); mustConsume("CLOSE"); result.push({ name: name_1 || (pattern_1 ? key++ : ""), pattern: name_1 && !pattern_1 ? defaultPattern : pattern_1, prefix, suffix, modifier: tryConsume("MODIFIER") || "" }); continue; } mustConsume("END"); } return result; } exports.parse = parse; function compile(str, options) { return tokensToFunction(parse(str, options), options); } exports.compile = compile; function tokensToFunction(tokens, options) { if (options === void 0) { options = {}; } var reFlags = flags(options); var _a = options.encode, encode = _a === void 0 ? function(x) { return x; } : _a, _b = options.validate, validate = _b === void 0 ? true : _b; var matches = tokens.map(function(token) { if (typeof token === "object") { return new RegExp("^(?:" + token.pattern + ")$", reFlags); } }); return function(data) { var path = ""; for (var i = 0; i < tokens.length; i++) { var token = tokens[i]; if (typeof token === "string") { path += token; continue; } var value = data ? data[token.name] : void 0; var optional = token.modifier === "?" || token.modifier === "*"; var repeat = token.modifier === "*" || token.modifier === "+"; if (Array.isArray(value)) { if (!repeat) { throw new TypeError('Expected "' + token.name + '" to not repeat, but got an array'); } if (value.length === 0) { if (optional) continue; throw new TypeError('Expected "' + token.name + '" to not be empty'); } for (var j = 0; j < value.length; j++) { var segment = encode(value[j], token); if (validate && !matches[i].test(segment)) { throw new TypeError('Expected all "' + token.name + '" to match "' + token.pattern + '", but got "' + segment + '"'); } path += token.prefix + segment + token.suffix; } continue; } if (typeof value === "string" || typeof value === "number") { var segment = encode(String(value), token); if (validate && !matches[i].test(segment)) { throw new TypeError('Expected "' + token.name + '" to match "' + token.pattern + '", but got "' + segment + '"'); } path += token.prefix + segment + token.suffix; continue; } if (optional) continue; var typeOfMessage = repeat ? "an array" : "a string"; throw new TypeError('Expected "' + token.name + '" to be ' + typeOfMessage); } return path; }; } exports.tokensToFunction = tokensToFunction; function match(str, options) { var keys = []; var re = pathToRegexp(str, keys, options); return regexpToFunction(re, keys, options); } exports.match = match; function regexpToFunction(re, keys, options) { if (options === void 0) { options = {}; } var _a = options.decode, decode = _a === void 0 ? function(x) { return x; } : _a; return function(pathname) { var m = re.exec(pathname); if (!m) return false; var path = m[0], index = m.index; var params = /* @__PURE__ */ Object.create(null); var _loop_1 = function(i2) { if (m[i2] === void 0) return "continue"; var key = keys[i2 - 1]; if (key.modifier === "*" || key.modifier === "+") { params[key.name] = m[i2].split(key.prefix + key.suffix).map(function(value) { return decode(value, key); }); } else { params[key.name] = decode(m[i2], key); } }; for (var i = 1; i < m.length; i++) { _loop_1(i); } return { path, index, params }; }; } exports.regexpToFunction = regexpToFunction; function escapeString(str) { return str.replace(/([.+*?=^!:${}()[\]|/\\])/g, "\\$1"); } function flags(options) { return options && options.sensitive ? "" : "i"; } function regexpToRegexp(path, keys) { if (!keys) return path; var groups = path.source.match(/\((?!\?)/g); if (groups) { for (var i = 0; i < groups.length; i++) { keys.push({ name: i, prefix: "", suffix: "", modifier: "", pattern: "" }); } } return path; } function arrayToRegexp(paths, keys, options) { var parts = paths.map(function(path) { return pathToRegexp(path, keys, options).source; }); return new RegExp("(?:" + parts.join("|") + ")", flags(options)); } function stringToRegexp(path, keys, options) { return tokensToRegexp(parse(path, options), keys, options); } function tokensToRegexp(tokens, keys, options) { if (options === void 0) { options = {}; } var _a = options.strict, strict = _a === void 0 ? false : _a, _b = options.start, start = _b === void 0 ? true : _b, _c = options.end, end = _c === void 0 ? true : _c, _d = options.encode, encode = _d === void 0 ? function(x) { return x; } : _d; var endsWith = "[" + escapeString(options.endsWith || "") + "]|$"; var delimiter = "[" + escapeString(options.delimiter || "/#?") + "]"; var route = start ? "^" : ""; for (var _i = 0, tokens_1 = tokens; _i < tokens_1.length; _i++) { var token = tokens_1[_i]; if (typeof token === "string") { route += escapeString(encode(token)); } else { var prefix = escapeString(encode(token.prefix)); var suffix = escapeString(encode(token.suffix)); if (token.pattern) { if (keys) keys.push(token); if (prefix || suffix) { if (token.modifier === "+" || token.modifier === "*") { var mod = token.modifier === "*" ? "?" : ""; route += "(?:" + prefix + "((?:" + token.pattern + ")(?:" + suffix + prefix + "(?:" + token.pattern + "))*)" + suffix + ")" + mod; } else { route += "(?:" + prefix + "(" + token.pattern + ")" + suffix + ")" + token.modifier; } } else { route += "(" + token.pattern + ")" + token.modifier; } } else { route += "(?:" + prefix + suffix + ")" + token.modifier; } } } if (end) { if (!strict) route += delimiter + "?"; route += !options.endsWith ? "$" : "(?=" + endsWith + ")"; } else { var endToken = tokens[tokens.length - 1]; var isEndDelimited = typeof endToken === "string" ? delimiter.indexOf(endToken[endToken.length - 1]) > -1 : ( // tslint:disable-next-line endToken === void 0 ); if (!strict) { route += "(?:" + delimiter + "(?=" + endsWith + "))?"; } if (!isEndDelimited) { route += "(?=" + delimiter + "|" + endsWith + ")"; } } return new RegExp(route, flags(options)); } exports.tokensToRegexp = tokensToRegexp; function pathToRegexp(path, keys, options) { if (path instanceof RegExp) return regexpToRegexp(path, keys); if (Array.isArray(path)) return arrayToRegexp(path, keys, options); return stringToRegexp(path, keys, options); } exports.pathToRegexp = pathToRegexp; } }); // ../../node_modules/.pnpm/path-to-regexp@6.3.0/node_modules/path-to-regexp/dist/index.js var require_dist2 = __commonJS({ "../../node_modules/.pnpm/path-to-regexp@6.3.0/node_modules/path-to-regexp/dist/index.js"(exports) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.pathToRegexp = exports.tokensToRegexp = exports.regexpToFunction = exports.match = exports.tokensToFunction = exports.compile = exports.parse = void 0; function lexer(str) { var tokens = []; var i = 0; while (i < str.length) { var char = str[i]; if (char === "*" || char === "+" || char === "?") { tokens.push({ type: "MODIFIER", index: i, value: str[i++] }); continue; } if (char === "\\") { tokens.push({ type: "ESCAPED_CHAR", index: i++, value: str[i++] }); continue; } if (char === "{") { tokens.push({ type: "OPEN", index: i, value: str[i++] }); continue; } if (char === "}") { tokens.push({ type: "CLOSE", index: i, value: str[i++] }); continue; } if (char === ":") { var name = ""; var j = i + 1; while (j < str.length) { var code = str.charCodeAt(j); if ( // `0-9` code >= 48 && code <= 57 || // `A-Z` code >= 65 && code <= 90 || // `a-z` code >= 97 && code <= 122 || // `_` code === 95 ) { name += str[j++]; continue; } break; } if (!name) throw new TypeError("Missing parameter name at ".concat(i)); tokens.push({ type: "NAME", index: i, value: name }); i = j; continue; } if (char === "(") { var count = 1; var pattern = ""; var j = i + 1; if (str[j] === "?") { throw new TypeError('Pattern cannot start with "?" at '.concat(j)); } while (j < str.length) { if (str[j] === "\\") { pattern += str[j++] + str[j++]; continue; } if (str[j] === ")") { count--; if (count === 0) { j++; break; } } else if (str[j] === "(") { count++; if (str[j + 1] !== "?") { throw new TypeError("Capturing groups are not allowed at ".concat(j)); } } pattern += str[j++]; } if (count) throw new TypeError("Unbalanced pattern at ".concat(i)); if (!pattern) throw new TypeError("Missing pattern at ".concat(i)); tokens.push({ type: "PATTERN", index: i, value: pattern }); i = j; continue; } tokens.push({ type: "CHAR", index: i, value: str[i++] }); } tokens.push({ type: "END", index: i, value: "" }); return tokens; } function parse(str, options) { if (options === void 0) { options = {}; } var tokens = lexer(str); var _a = options.prefixes, prefixes = _a === void 0 ? "./" : _a, _b = options.delimiter, delimiter = _b === void 0 ? "/#?" : _b; var result = []; var key = 0; var i = 0; var path = ""; var tryConsume = function(type) { if (i < tokens.length && tokens[i].type === type) return tokens[i++].value; }; var mustConsume = function(type) { var value2 = tryConsume(type); if (value2 !== void 0) return value2; var _a2 = tokens[i], nextType = _a2.type, index = _a2.index; throw new TypeError("Unexpected ".concat(nextType, " at ").concat(index, ", expected ").concat(type)); }; var consumeText = function() { var result2 = ""; var value2; while (value2 = tryConsume("CHAR") || tryConsume("ESCAPED_CHAR")) { result2 += value2; } return result2; }; var isSafe = function(value2) { for (var _i = 0, delimiter_1 = delimiter; _i < delimiter_1.length; _i++) { var char2 = delimiter_1[_i]; if (value2.indexOf(char2) > -1) return true; } return false; }; var safePattern = function(prefix2) { var prev = result[result.length - 1]; var prevText = prefix2 || (prev && typeof prev === "string" ? prev : ""); if (prev && !prevText) { throw new TypeError('Must have text between two parameters, missing text after "'.concat(prev.name, '"')); } if (!prevText || isSafe(prevText)) return "[^".concat(escapeString(delimiter), "]+?"); return "(?:(?!".concat(escapeString(prevText), ")[^").concat(escapeString(delimiter), "])+?"); }; while (i < tokens.length) { var char = tryConsume("CHAR"); var name = tryConsume("NAME"); var pattern = tryConsume("PATTERN"); if (name || pattern) { var prefix = char || ""; if (prefixes.indexOf(prefix) === -1) { path += prefix; prefix = ""; } if (path) { result.push(path); path = ""; } result.push({ name: name || key++, prefix, suffix: "", pattern: pattern || safePattern(prefix), modifier: tryConsume("MODIFIER") || "" }); continue; } var value = char || tryConsume("ESCAPED_CHAR"); if (value) { path += value; continue; } if (path) { result.push(path); path = ""; } var open = tryConsume("OPEN"); if (open) { var prefix = consumeText(); var name_1 = tryConsume("NAME") || ""; var pattern_1 = tryConsume("PATTERN") || ""; var suffix = consumeText(); mustConsume("CLOSE"); result.push({ name: name_1 || (pattern_1 ? key++ : ""), pattern: name_1 && !pattern_1 ? safePattern(prefix) : pattern_1, prefix, suffix, modifier: tryConsume("MODIFIER") || "" }); continue; } mustConsume("END"); } return result; } exports.parse = parse; function compile(str, options) { return tokensToFunction(parse(str, options), options); } exports.compile = compile; function tokensToFunction(tokens, options) { if (options === void 0) { options = {}; } var reFlags = flags(options); var _a = options.encode, encode = _a === void 0 ? function(x) { return x; } : _a, _b = options.validate, validate = _b === void 0 ? true : _b; var matches = tokens.map(function(token) { if (typeof token === "object") { return new RegExp("^(?:".concat(token.pattern, ")$"), reFlags); } }); return function(data) { var path = ""; for (var i = 0; i < tokens.length; i++) { var token = tokens[i]; if (typeof token === "string") { path += token; continue; } var value = data ? data[token.name] : void 0; var optional = token.modifier === "?" || token.modifier === "*"; var repeat = token.modifier === "*" || token.modifier === "+"; if (Array.isArray(value)) { if (!repeat) { throw new TypeError('Expected "'.concat(token.name, '" to not repeat, but got an array')); } if (value.length === 0) { if (optional) continue; throw new TypeError('Expected "'.concat(token.name, '" to not be empty')); } for (var j = 0; j < value.length; j++) { var segment = encode(value[j], token); if (validate && !matches[i].test(segment)) { throw new TypeError('Expected all "'.concat(token.name, '" to match "').concat(token.pattern, '", but got "').concat(segment, '"')); } path += token.prefix + segment + token.suffix; } continue; } if (typeof value === "string" || typeof value === "number") { var segment = encode(String(value), token); if (validate && !matches[i].test(segment)) { throw new TypeError('Expected "'.concat(token.name, '" to match "').concat(token.pattern, '", but got "').concat(segment, '"')); } path += token.prefix + segment + token.suffix; continue; } if (optional) continue; var typeOfMessage = repeat ? "an array" : "a string"; throw new TypeError('Expected "'.concat(token.name, '" to be ').concat(typeOfMessage)); } return path; }; } exports.tokensToFunction = tokensToFunction; function match(str, options) { var keys = []; var re = pathToRegexp(str, keys, options); return regexpToFunction(re, keys, options); } exports.match = match; function regexpToFunction(re, keys, options) { if (options === void 0) { options = {}; } var _a = options.decode, decode = _a === void 0 ? function(x) { return x; } : _a; return function(pathname) { var m = re.exec(pathname); if (!m) return false; var path = m[0], index = m.index; var params = /* @__PURE__ */ Object.create(null); var _loop_1 = function(i2) { if (m[i2] === void 0) return "continue"; var key = keys[i2 - 1]; if (key.modifier === "*" || key.modifier === "+") { params[key.name] = m[i2].split(key.prefix + key.suffix).map(function(value) { return decode(value, key); }); } else { params[key.name] = decode(m[i2], key); } }; for (var i = 1; i < m.length; i++) { _loop_1(i); } return { path, index, params }; }; } exports.regexpToFunction = regexpToFunction; function escapeString(str) { return str.replace(/([.+*?=^!:${}()[\]|/\\])/g, "\\$1"); } function flags(options) { return options && options.sensitive ? "" : "i"; } function regexpToRegexp(path, keys) { if (!keys) return path; var groupsRegex = /\((?:\?<(.*?)>)?(?!\?)/g; var index = 0; var execResult = groupsRegex.exec(path.source); while (execResult) { keys.push({ // Use parenthesized substring match if available, index otherwise name: execResult[1] || index++, prefix: "", suffix: "", modifier: "", pattern: "" }); execResult = groupsRegex.exec(path.source); } return path; } function arrayToRegexp(paths, keys, options) { var parts = paths.map(function(path) { return pathToRegexp(path, keys, options).source; }); return new RegExp("(?:".concat(parts.join("|"), ")"), flags(options)); } function stringToRegexp(path, keys, options) { return tokensToRegexp(parse(path, options), keys, options); } function tokensToRegexp(tokens, keys, options) { if (options === void 0) { options = {}; } var _a = options.strict, strict = _a === void 0 ? false : _a, _b = options.start, start = _b === void 0 ? true : _b, _c = options.end, end = _c === void 0 ? true : _c, _d = options.encode, encode = _d === void 0 ? function(x) { return x; } : _d, _e = options.delimiter, delimiter = _e === void 0 ? "/#?" : _e, _f = options.endsWith, endsWith = _f === void 0 ? "" : _f; var endsWithRe = "[".concat(escapeString(endsWith), "]|$"); var delimiterRe = "[".concat(escapeString(delimiter), "]"); var route = start ? "^" : ""; for (var _i = 0, tokens_1 = tokens; _i < tokens_1.length; _i++) { var token = tokens_1[_i]; if (typeof token === "string") { route += escapeString(encode(token)); } else { var prefix = escapeString(encode(token.prefix)); var suffix = escapeString(encode(token.suffix)); if (token.pattern) { if (keys) keys.push(token); if (prefix || suffix) { if (token.modifier === "+" || token.modifier === "*") { var mod = token.modifier === "*" ? "?" : ""; route += "(?:".concat(prefix, "((?:").concat(token.pattern, ")(?:").concat(suffix).concat(prefix, "(?:").concat(token.pattern, "))*)").concat(suffix, ")").concat(mod); } else { route += "(?:".concat(prefix, "(").concat(token.pattern, ")").concat(suffix, ")").concat(token.modifier); } } else { if (token.modifier === "+" || token.modifier === "*") { throw new TypeError('Can not repeat "'.concat(token.name, '" without a prefix and suffix')); } route += "(".concat(token.pattern, ")").concat(token.modifier); } } else { route += "(?:".concat(prefix).concat(suffix, ")").concat(token.modifier); } } } if (end) { if (!strict) route += "".concat(delimiterRe, "?"); route += !options.endsWith ? "$" : "(?=".concat(endsWithRe, ")"); } else { var endToken = tokens[tokens.length - 1]; var isEndDelimited = typeof endToken === "string" ? delimiterRe.indexOf(endToken[endToken.length - 1]) > -1 : endToken === void 0; if (!strict) { route += "(?:".concat(delimiterRe, "(?=").concat(endsWithRe, "))?"); } if (!isEndDelimited) { route += "(?=".concat(delimiterRe, "|").concat(endsWithRe, ")"); } } return new RegExp(route, flags(options)); } exports.tokensToRegexp = tokensToRegexp; function pathToRegexp(path, keys, options) { if (path instanceof RegExp) return regexpToRegexp(path, keys); if (Array.isArray(path)) return arrayToRegexp(path, keys, options); return stringToRegexp(path, keys, options); } exports.pathToRegexp = pathToRegexp; } }); // ../routing-utils/dist/superstatic.js var require_superstatic = __commonJS({ "../routing-utils/dist/superstatic.js"(exports, module2) { "use strict"; var __defProp2 = Object.defineProperty; var __getOwnPropDesc2 = Object.getOwnPropertyDescriptor; var __getOwnPropNames2 = Object.getOwnPropertyNames; var __hasOwnProp2 = Object.prototype.hasOwnProperty; var __export2 = (target, all) => { for (var name in all) __defProp2(target, name, { get: all[name], enumerable: true }); }; var __copyProps2 = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames2(from)) if (!__hasOwnProp2.call(to, key) && key !== except) __defProp2(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc2(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS2 = (mod) => __copyProps2(__defProp2({}, "__esModule", { value: true }), mod); var superstatic_exports = {}; __export2(superstatic_exports, { collectHasSegments: () => collectHasSegments, convertCleanUrls: () => convertCleanUrls, convertHeaders: () => convertHeaders, convertRedirects: () => convertRedirects, convertRewrites: () => convertRewrites, convertTrailingSlash: () => convertTrailingSlash, getCleanUrls: () => getCleanUrls2, pathToRegexp: () => pathToRegexp, sourceToRegex: () => sourceToRegex2 }); module2.exports = __toCommonJS2(superstatic_exports); var import_url = require("url"); var import_path_to_regexp = require_dist(); var import_path_to_regexp_updated = require_dist2(); function cloneKeys(keys) { if (typeof keys === "undefined") { return void 0; } return keys.slice(0); } function compareKeys(left, right) { const leftSerialized = typeof left === "undefined" ? "undefined" : left.toString(); const rightSerialized = typeof right === "undefined" ? "undefined" : right.toString(); return leftSerialized === rightSerialized; } function pathToRegexp(callerId, path, keys, options) { const newKeys = cloneKeys(keys); const currentRegExp = (0, import_path_to_regexp.pathToRegexp)(path, keys, options); try { const currentKeys = keys; const newRegExp = (0, import_path_to_regexp_updated.pathToRegexp)(path, newKeys, options); const isDiffRegExp = currentRegExp.toString() !== newRegExp.toString(); if (process.env.FORCE_PATH_TO_REGEXP_LOG || isDiffRegExp) { const message = JSON.stringify({ path, currentRegExp: currentRegExp.toString(), newRegExp: newRegExp.toString() }); console.error(`[vc] PATH TO REGEXP PATH DIFF @ #${callerId}: ${message}`); } const isDiffKeys = !compareKeys(keys, newKeys); if (process.env.FORCE_PATH_TO_REGEXP_LOG || isDiffKeys) { const message = JSON.stringify({ isDiffKeys, currentKeys, newKeys }); console.error(`[vc] PATH TO REGEXP KEYS DIFF @ #${callerId}: ${message}`); } } catch (err) { const error = err; const message = JSON.stringify({ path, error: error.message }); console.error(`[vc] PATH TO REGEXP ERROR @ #${callerId}: ${message}`); } return currentRegExp; } var UN_NAMED_SEGMENT = "__UN_NAMED_SEGMENT__"; function getCleanUrls2(filePaths) { const htmlFiles = filePaths.map(toRoute).filter((f) => f.endsWith(".html")).map((f) => ({ html: f, clean: f.slice(0, -5) })); return htmlFiles; } function convertCleanUrls(cleanUrls, trailingSlash, status = 308) { const routes = []; if (cleanUrls) { const loc = trailingSlash ? "/$1/" : "/$1"; routes.push({ src: "^/(?:(.+)/)?index(?:\\.html)?/?$", headers: { Location: loc }, status }); routes.push({ src: "^/(.*)\\.html/?$", headers: { Location: loc }, status }); } return routes; } function convertRedirects(redirects, defaultStatus = 308) { return redirects.map((r) => { const { src, segments } = sourceToRegex2(r.source); const hasSegments = collectHasSegments(r.has); normalizeHasKeys(r.has); normalizeHasKeys(r.missing); try { const loc = replaceSegments(segments, hasSegments, r.destination, true); let status; if (typeof r.permanent === "boolean") { status = r.permanent ? 308 : 307; } else if (r.statusCode) { status = r.statusCode; } else { status = defaultStatus; } const route = { src, headers: { Location: loc }, status }; if (typeof r.env !== "undefined") { route.env = r.env; } if (r.has) { route.has = r.has; } if (r.missing) { route.missing = r.missing; } return route; } catch (e) { throw new Error(`Failed to parse redirect: ${JSON.stringify(r)}`); } }); } function convertRewrites(rewrites, internalParamNames) { return rewrites.map((r) => { const { src, segments } = sourceToRegex2(r.source); const hasSegments = collectHasSegments(r.has); normalizeHasKeys(r.has); normalizeHasKeys(r.missing); try { const dest = replaceSegments( segments, hasSegments, r.destination, false, internalParamNames ); const route = { src, dest, check: true }; if (typeof r.env !== "undefined") { route.env = r.env; } if (r.has) { route.has = r.has; } if (r.missing) { route.missing = r.missing; } if (r.statusCode) { route.status = r.statusCode; } return route; } catch (e) { throw new Error(`Failed to parse rewrite: ${JSON.stringify(r)}`); } }); } function convertHeaders(headers) { return headers.map((h) => { const obj = {}; const { src, segments } = sourceToRegex2(h.source); const hasSegments = collectHasSegments(h.has); normalizeHasKeys(h.has); normalizeHasKeys(h.missing); const namedSegments = segments.filter((name) => name !== UN_NAMED_SEGMENT); const indexes = {}; segments.forEach((name, index) => { indexes[name] = toSegmentDest(index); }); hasSegments.forEach((name) => { indexes[name] = "$" + name; }); h.headers.forEach(({ key, value }) => { if (namedSegments.length > 0 || hasSegments.length > 0) { if (key.includes(":")) { key = safelyCompile(key, indexes); } if (value.includes(":")) { value = safelyCompile(value, indexes); } } obj[key] = value; }); const route = { src, headers: obj, continue: true }; if (h.has) { route.has = h.has; } if (h.missing) { route.missing = h.missing; } return route; }); } function convertTrailingSlash(enable, status = 308) { const routes = []; if (enable) { routes.push({ src: "^/\\.well-known(?:/.*)?$" }); routes.push({ src: "^/((?:[^/]+/)*[^/\\.]+)$", headers: { Location: "/$1/" }, status }); routes.push({ src: "^/((?:[^/]+/)*[^/]+\\.\\w+)/$", headers: { Location: "/$1" }, status }); } else { routes.push({ src: "^/(.*)\\/$", headers: { Location: "/$1" }, status }); } return routes; } function sourceToRegex2(source) { const keys = []; const r = pathToRegexp("632", source, keys, { strict: true, sensitive: true, delimiter: "/" }); const segments = keys.map((k) => k.name).map((name) => { if (typeof name !== "string") { return UN_NAMED_SEGMENT; } return name; }); return { src: r.source, segments }; } var namedGroupsRegex = /\(\?<([a-zA-Z][a-zA-Z0-9_]*)>/g; var normalizeHasKeys = (hasItems = []) => { for (const hasItem of hasItems) { if ("key" in hasItem && hasItem.type === "header") { hasItem.key = hasItem.key.toLowerCase(); } } return hasItems; }; function getStringValueForRegex(value) { if (typeof value === "string") { return value; } if (value && typeof value === "object" && value !== null) { if ("re" in value && typeof value.re === "string") { return value.re; } } return null; } function collectHasSegments(has) { const hasSegments = /* @__PURE__ */ new Set(); for (const hasItem of has || []) { if (!hasItem.value && "key" in hasItem) { hasSegments.add(hasItem.key); } const stringValue = getStringValueForRegex(hasItem.value); if (stringValue) { for (const match of stringValue.matchAll(namedGroupsRegex)) { if (match[1]) { hasSegments.add(match[1]); } } if (hasItem.type === "host") { hasSegments.add("host"); } } } return [...hasSegments]; } var escapeSegment = (str, segmentName) => str.replace(new RegExp(`:${segmentName}`, "g"), `__ESC_COLON_${segmentName}`); var unescapeSegments = (str) => str.replace(/__ESC_COLON_/gi, ":"); function replaceSegments(segments, hasItemSegments, destination, isRedirect, internalParamNames) { const namedSegments = segments.filter((name) => name !== UN_NAMED_SEGMENT); const canNeedReplacing = destination.includes(":") && namedSegments.length > 0 || hasItemSegments.length > 0 || !isRedirect; if (!canNeedReplacing) { return destination; } let escapedDestination = destination; const indexes = {}; segments.forEach((name, index) => { indexes[name] = toSegmentDest(index); escapedDestination = escapeSegment(escapedDestination, name); }); hasItemSegments.forEach((name) => { indexes[name] = "$" + name; escapedDestination = escapeSegment(escapedDestination, name); }); const parsedDestination = (0, import_url.parse)(escapedDestination, true); delete parsedDestination.href; delete parsedDestination.path; delete parsedDestination.search; delete parsedDestination.host; let { pathname, hash, query, hostname, ...rest } = parsedDestination; pathname = unescapeSegments(pathname || ""); hash = unescapeSegments(hash || ""); hostname = unescapeSegments(hostname || ""); let destParams = /* @__PURE__ */ new Set(); const pathnameKeys = []; const hashKeys = []; const hostnameKeys = []; try { pathToRegexp("528", pathname, pathnameKeys); pathToRegexp("834", hash || "", hashKeys); pathToRegexp("712", hostname || "", hostnameKeys); } catch (_) { } destParams = new Set( [...pathnameKeys, ...hashKeys, ...hostnameKeys].map((key) => key.name).filter((val) => typeof val === "string") ); pathname = safelyCompile(pathname, indexes, true); hash = hash ? safelyCompile(hash, indexes, true) : null; hostname = hostname ? safelyCompile(hostname, indexes, true) : null; for (const [key, strOrArray] of Object.entries(query)) { if (Array.isArray(strOrArray)) { query[key] = strOrArray.map( (str) => safelyCompile(unescapeSegments(str), indexes, true) ); } else { query[key] = safelyCompile( unescapeSegments(strOrArray), indexes, true ); } } const paramKeys = Object.keys(indexes); const needsQueryUpdating = ( // we do not consider an internal param since it is added automatically !isRedirect && !paramKeys.some( (param) => !(internalParamNames && internalParamNames.includes(param)) && destParams.has(param) ) ); if (needsQueryUpdating) { for (const param of paramKeys) { if (!(param in query) && param !== UN_NAMED_SEGMENT) { query[param] = indexes[param]; } } } destination = (0, import_url.format)({ ...rest, hostname, pathname, query, hash }); return destination.replace(/%24/g, "$"); } function safelyCompile(value, indexes, attemptDirectCompile) { if (!value) { return value; } if (attemptDirectCompile) { try { return (0, import_path_to_regexp.compile)(value, { validate: false })(indexes); } catch (e) { } } for (const key of Object.keys(indexes)) { if (value.includes(`:${key}`)) { value = value.replace( new RegExp(`:${key}\\*`, "g"), `:${key}--ESCAPED_PARAM_ASTERISK` ).replace( new RegExp(`:${key}\\?`, "g"), `:${key}--ESCAPED_PARAM_QUESTION` ).replace(new RegExp(`:${key}\\+`, "g"), `:${key}--ESCAPED_PARAM_PLUS`).replace( new RegExp(`:${key}(?!\\w)`, "g"), `--ESCAPED_PARAM_COLON${key}` ); } } value = value.replace(/(:|\*|\?|\+|\(|\)|\{|\})/g, "\\$1").replace(/--ESCAPED_PARAM_PLUS/g, "+").replace(/--ESCAPED_PARAM_COLON/g, ":").replace(/--ESCAPED_PARAM_QUESTION/g, "?").replace(/--ESCAPED_PARAM_ASTERISK/g, "*"); return (0, import_path_to_regexp.compile)(`/${value}`, { validate: false })(indexes).slice(1); } function toSegmentDest(index) { const i = index + 1; return "$" + i.toString(); } function toRoute(filePath) { return filePath.startsWith("/") ? filePath : "/" + filePath; } } }); // ../routing-utils/dist/append.js var require_append = __commonJS({ "../routing-utils/dist/append.js"(exports, module2) { "use strict"; var __defProp2 = Object.defineProperty; var __getOwnPropDesc2 = Object.getOwnPropertyDescriptor; var __getOwnPropNames2 = Object.getOwnPropertyNames; var __hasOwnProp2 = Object.prototype.hasOwnProperty; var __export2 = (target, all) => { for (var name in all) __defProp2(target, name, { get: all[name], enumerable: true }); }; var __copyProps2 = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames2(from)) if (!__hasOwnProp2.call(to, key) && key !== except) __defProp2(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc2(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS2 = (mod) => __copyProps2(__defProp2({}, "__esModule", { value: true }), mod); var append_exports = {}; __export2(append_exports, { appendRoutesToPhase: () => appendRoutesToPhase2 }); module2.exports = __toCommonJS2(append_exports); var import_index = require_dist3(); function appendRoutesToPhase2({ routes: prevRoutes, newRoutes, phase }) { const routes = prevRoutes ? [...prevRoutes] : []; if (newRoutes === null || newRoutes.length === 0) { return routes; } let isInPhase = false; let insertIndex = -1; routes.forEach((r, i) => { if ((0, import_index.isHandler)(r)) { if (r.handle === phase) { isInPhase = true; } else if (isInPhase) { insertIndex = i; isInPhase = false; } } }); if (isInPhase) { routes.push(...newRoutes); } else if (phase === null) { const lastPhase = routes.findIndex((r) => (0, import_index.isHandler)(r) && r.handle); if (lastPhase === -1) { routes.push(...newRoutes); } else { routes.splice(lastPhase, 0, ...newRoutes); } } else if (insertIndex > -1) { routes.splice(insertIndex, 0, ...newRoutes); } else { routes.push({ handle: phase }); routes.push(...newRoutes); } return routes; } } }); // ../routing-utils/dist/merge.js var require_merge = __commonJS({ "../routing-utils/dist/merge.js"(exports, module2) { "use strict"; var __defProp2 = Object.defineProperty; var __getOwnPropDesc2 = Object.getOwnPropertyDescriptor; var __getOwnPropNames2 = Object.getOwnPropertyNames; var __hasOwnProp2 = Object.prototype.hasOwnProperty; var __export2 = (target, all) => { for (var name in all) __defProp2(target, name, { get: all[name], enumerable: true }); }; var __copyProps2 = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames2(from)) if (!__hasOwnProp2.call(to, key) && key !== except) __defProp2(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc2(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS2 = (mod) => __copyProps2(__defProp2({}, "__esModule", { value: true }), mod); var merge_exports = {}; __export2(merge_exports, { mergeRoutes: () => mergeRoutes2 }); module2.exports = __toCommonJS2(merge_exports); var import_index = require_dist3(); function getBuilderRoutesMapping(builds) { const builderRoutes = {}; for (const { entrypoint, routes, use } of builds) { if (routes) { if (!builderRoutes[entrypoint]) { builderRoutes[entrypoint] = {}; } builderRoutes[entrypoint][use] = routes; } } return builderRoutes; } function getCheckAndContinue(routes) { const checks = []; const continues = []; const others = []; for (const route of routes) { if ((0, import_index.isHandler)(route)) { throw new Error( `Unexpected route found in getCheckAndContinue(): ${JSON.stringify( route )}` ); } else if (route.check && !route.override) { checks.push(route); } else if (route.continue && !route.override) { continues.push(route); } else { others.push(route); } } return { checks, continues, others }; } function mergeRoutes2({ userRoutes, builds }) { const userHandleMap = /* @__PURE__ */ new Map(); let userPrevHandle = null; (userRoutes || []).forEach((route) => { if ((0, import_index.isHandler)(route)) { userPrevHandle = route.handle; } else { const routes = userHandleMap.get(userPrevHandle); if (!routes) { userHandleMap.set(userPrevHandle, [route]); } else { routes.push(route); } } }); const builderHandleMap = /* @__PURE__ */ new Map(); const builderRoutes = getBuilderRoutesMapping(builds); const sortedPaths = Object.keys(builderRoutes).sort(); sortedPaths.forEach((path) => { const br = builderRoutes[path]; const sortedBuilders = Object.keys(br).sort(); sortedBuilders.forEach((use) => { let builderPrevHandle = null; br[use].forEach((route) => { if ((0, import_index.isHandler)(route)) { builderPrevHandle = route.handle; } else { const routes = builderHandleMap.get(builderPrevHandle); if (!routes) { builderHandleMap.set(builderPrevHandle, [route]); } else { routes.push(route); } } }); }); }); const outputRoutes = []; const uniqueHandleValues = /* @__PURE__ */ new Set([ null, ...userHandleMap.keys(), ...builderHandleMap.keys() ]); for (const handle of uniqueHandleValues) { const userRoutes2 = userHandleMap.get(handle) || []; const builderRoutes2 = builderHandleMap.get(handle) || []; const builderSorted = getCheckAndContinue(builderRoutes2); if (handle !== null && (userRoutes2.length > 0 || builderRoutes2.length > 0)) { outputRoutes.push({ handle }); } outputRoutes.push(...builderSorted.continues); outputRoutes.push(...userRoutes2); outputRoutes.push(...builderSorted.checks); outputRoutes.push(...builderSorted.others); } return outputRoutes; } } }); // ../routing-utils/dist/schemas.js var require_schemas = __commonJS({ "../routing-utils/dist/schemas.js"(exports, module2) { "use strict"; var __defProp2 = Object.defineProperty; var __getOwnPropDesc2 = Object.getOwnPropertyDescriptor; var __getOwnPropNames2 = Object.getOwnPropertyNames; var __hasOwnProp2 = Object.prototype.hasOwnProperty; var __export2 = (target, all) => { for (var name in all) __defProp2(target, name, { get: all[name], enumerable: true }); }; var __copyProps2 = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames2(from)) if (!__hasOwnProp2.call(to, key) && key !== except) __defProp2(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc2(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS2 = (mod) => __copyProps2(__defProp2({}, "__esModule", { value: true }), mod); var schemas_exports = {}; __export2(schemas_exports, { bulkRedirectsSchema: () => bulkRedirectsSchema, cleanUrlsSchema: () => cleanUrlsSchema, hasSchema: () => hasSchema, headersSchema: () => headersSchema, redirectsSchema: () => redirectsSchema, rewritesSchema: () => rewritesSchema, routesSchema: () => routesSchema, trailingSlashSchema: () => trailingSlashSchema }); module2.exports = __toCommonJS2(schemas_exports); var mitigateSchema = { description: "Mitigation action to take on a route", type: "object", additionalProperties: false, required: ["action"], properties: { action: { description: "The mitigation action to take", type: "string", enum: ["challenge", "deny"] } } }; var matchableValueSchema = { description: "A value to match against. Can be a string (regex) or a condition operation object", anyOf: [ { description: "A regular expression used to match thev value. Named groups can be used in the destination.", type: "string", maxLength: 4096 }, { description: "A condition operation object", type: "object", additionalProperties: false, minProperties: 1, properties: { eq: { description: "Equal to", anyOf: [ { type: "string", maxLength: 4096 }, { type: "number" } ] }, neq: { description: "Not equal", type: "string", maxLength: 4096 }, inc: { description: "In array", type: "array", items: { type: "string", maxLength: 4096 } }, ninc: { description: "Not in array", type: "array", items: { type: "string", maxLength: 4096 } }, pre: { description: "Starts with", type: "string", maxLength: 4096 }, suf: { description: "Ends with", type: "string", maxLength: 4096 }, re: { description: "Regex", type: "string", maxLength: 4096 }, gt: { description: "Greater than", type: "number" }, gte: { description: "Greater than or equal to", type: "number" }, lt: { description: "Less than", type: "number" }, lte: { description: "Less than or equal to", type: "number" } } } ] }; var hasSchema = { description: "An array of requirements that are needed to match", type: "array", maxItems: 16, items: { anyOf: [ { type: "object", additionalProperties: false, required: ["type", "value"], properties: { type: { description: "The type of request element to check", type: "string", enum: ["host"] }, value: matchableValueSchema } }, { type: "object", additionalProperties: false, required: ["type", "key"], properties: { type: { description: "The type of request element to check", type: "string", enum: ["header", "cookie", "query"] }, key: { description: "The name of the element contained in the particular type", type: "string", maxLength: 4096 }, value: matchableValueSchema } } ] } }; var transformsSchema = { description: "A list of transform rules to adjust the query parameters of a request or HTTP headers of request or response", type: "array", minItems: 1, items: { type: "object", additionalProperties: false, required: ["type", "op", "target"], properties: { type: { description: "The scope of the transform to apply", type: "string", enum: ["request.headers", "request.query", "response.headers"] }, op: { description: "The operation to perform on the target", type: "string", enum: ["append", "set", "delete"] }, target: { description: "The target of the transform", type: "object", required: ["key"], properties: { // re is not supported for transforms. Once supported, replace target.key with matchableValueSchema key: { description: "A value to match against. Can be a string or a condition operation object (without regex support)", anyOf: [ { description: "A valid header name (letters, numbers, hyphens, underscores)", type: "string", maxLength: 4096 }, { description: "A condition operation object", type: "object", additionalProperties: false, minProperties: 1, properties: { eq: { description: "Equal to", anyOf: [ { type: "string", maxLength: 4096 }, { type: "number" } ] }, neq: { description: "Not equal", type: "string", maxLength: 4096 }, inc: { description: "In array", type: "array", items: { type: "string", maxLength: 4096 } }, ninc: { description: "Not in array", type: "array", items: { type: "string", maxLength: 4096 } }, pre: { description: "Starts with", type: "string", maxLength: 4096 }, suf: { description: "Ends with", type: "string", maxLength: 4096 }, gt: { description: "Greater than", type: "number" }, gte: { description: "Greater than or equal to", type: "number" }, lt: { description: "Less than", type: "number" }, lte: { description: "Less than or equal to", type: "number" } } } ] } } }, args: { description: "The arguments to the operation", anyOf: [ { type: "string", maxLength: 4096 }, { type: "array", minItems: 1, items: { type: "string", maxLength: 4096 } } ] }, env: { description: "An array of environment variable names that should be replaced at runtime in the args value", type: "array", minItems: 1, maxItems: 64, items: { type: "string", maxLength: 256 } } }, allOf: [ { if: { properties: { op: { enum: ["append", "set"] } } }, then: { required: ["args"] } }, { if: { allOf: [ { properties: { type: { enum: ["request.headers", "response.headers"] } } }, { properties: { op: { enum: ["set", "append"] } } } ] }, then: { properties: { target: { properties: { key: { if: { type: "string" }, then: { pattern: "^[a-zA-Z0-9_-]+$" } } } }, args: { anyOf: [ { type: "string", pattern: "^[a-zA-Z0-9_ :;.,\"'?!(){}\\[\\]@<>=+*#$&`|~\\^%/-]+$" }, { type: "array", items: { type: "string", pattern: "^[a-zA-Z0-9_ :;.,\"'?!(){}\\[\\]@<>=+*#$&`|~\\^%/-]+$" } } ] } } } } ] } }; var routesSchema = { type: "array", deprecated: true, description: "A list of routes objects used to rewrite paths to point towards other internal or external paths", example: [{ dest: "https://docs.example.com", src: "/docs" }], items: { anyOf: [ { type: "object", required: ["src"], additionalProperties: false, properties: { src: { type: "string", maxLength: 4096 }, dest: { type: "string", maxLength: 4096 }, headers: { type: "object", additionalProperties: false, minProperties: 1, maxProperties: 100, patternProperties: { "^.{1,256}$": { type: "string", maxLength: 32768 } } }, methods: { type: "array", maxItems: 10, items: { type: "string", maxLength: 32 } }, caseSensitive: { type: "boolean" }, important: { type: "boolean" }, user: { type: "boolean" }, continue: { type: "boolean" }, override: { type: "boolean" }, check: { type: "boolean" }, isInternal: { type: "boolean" }, status: { type: "integer", minimum: 100, maximum: 999 }, locale: { type: "object", additionalProperties: false, minProperties: 1, properties: { redirect: { type: "object", additionalProperties: false, minProperties: 1, maxProperties: 100, patternProperties: { "^.{1,256}$": { type: "string", maxLength: 4096 } } }, value: { type: "string", maxLength: 4096 }, path: { type: "string", maxLength: 4096 }, cookie: { type: "string", maxLength: 4096 }, default: { type: "string", maxLength: 4096 } } }, middleware: { type: "number" }, middlewarePath: { type: "string" }, middlewareRawSrc: { type: "array", items: { type: "string" } }, has: hasSchema, missing: hasSchema, mitigate: mitigateSchema, transforms: transformsSchema, env: { description: "An array of environment variable names that should be replaced at runtime in the destination or headers", type: "array", minItems: 1, maxItems: 64, items: { type: "string", maxLength: 256 } }, respectOriginCacheControl: { description: "When set to true (default), external rewrites will respect the Cache-Control header from the origin. When false, caching is disabled for this rewrite.", type: "boolean" } } }, { type: "object", required: ["handle"], additionalProperties: false, properties: { handle: { type: "string", maxLength: 32, enum: ["error", "filesystem", "hit", "miss", "resource", "rewrite"] } } } ] } }; var rewritesSchema = { type: "array", maxItems: 2048, description: "A list of rewrite definitions.", items: { type: "object", additionalProperties: false, required: ["source", "destination"], properties: { source: { description: "A pattern that matches each incoming pathname (excluding querystring).", type: "string", maxLength: 4096 }, destination: { description: "An absolute pathname to an existing resource or an external URL.", type: "string", maxLength: 4096 }, has: hasSchema, missing: hasSchema, statusCode: { description: "An optional integer to override the status code of the response.", type: "integer", minimum: 100, maximum: 999 }, env: { description: "An array of environment variable names that should be replaced at runtime in the destination", type: "array", minItems: 1, maxItems: 64, items: { type: "string", maxLength: 256 } }, respectOriginCacheControl: { description: "When set to true (default), external rewrites will respect the Cache-Control header from the origin. When false, caching is disabled for this rewrite.", type: "boolean" } } } }; var redirectsSchema = { title: "Redirects", type: "array", maxItems: 2048, description: "A list of redirect definitions.", items: { type: "object", additionalProperties: false, required: ["source", "destination"], properties: { source: { description: "A pattern that matches each incoming pathname (excluding querystring).", type: "string", maxLength: 4096 }, destination: { description: "A location destination defined as an absolute pathname or external URL.", type: "string", maxLength: 4096 }, permanent: { description: "A boolean to toggle between permanent and temporary redirect. When `true`, the status code is `308`. When `false` the status code is `307`.", type: "boolean" }, statusCode: { description: "An optional integer to define the status code of the redirect.", private: true, type: "integer", minimum: 100, maximum: 999 }, has: hasSchema, missing: hasSchema, env: { description: "An array of environment variable names that should be replaced at runtime in the destination", type: "array", minItems: 1, maxItems: 64, items: { type: "string", maxLength: 256 } } } } }; var headersSchema = { type: "array", maxItems: 2048, description: "A list of header definitions.", items: { type: "object", additionalProperties: false, required: ["source", "headers"], properties: { source: { description: "A pattern that matches each incoming pathname (excluding querystring)", type: "string", maxLength: 4096 }, headers: { description: "An array of key/value pairs representing each response header.", type: "array", maxItems: 1024, items: { type: "object", additionalProperties: false, required: ["key", "value"], properties: { key: { type: "string", maxLength: 4096 }, value: { type: "string", maxLength: 32768 } } } }, has: hasSchema, missing: hasSchema } } }; var cleanUrlsSchema = { description: "When set to `true`, all HTML files and Serverless Functions will have their extension removed. When visiting a path that ends with the extension, a 308 response will redirect the client to the extensionless path.", type: "boolean" }; var trailingSlashSchema = { description: "When `false`, visiting a path that ends with a forward slash will respond with a `308` status code and redirect to the path without the trailing slash.", type: "boolean" }; var bulkRedirectsSchema = { type: "array", description: "A list of bulk redirect definitions.", items: { type: "object", additionalProperties: false, required: ["source", "destination"], properties: { source: { description: "The exact URL path or pattern to match.", type: "string", maxLength: 2048 }, destination: { description: "The target URL path where traffic should be redirected.", type: "string", maxLength: 2048 }, permanent: { description: "A boolean to toggle between permanent and temporary redirect. When `true`, the status code is `308`. When `false` the status code is `307`.", type: "boolean" }, statusCode: { description: "An optional integer to define the status code of the redirect.", type: "integer", enum: [301, 302, 307, 308] }, sensitive: { description: "A boolean to toggle between case-sensitive and case-insensitive redirect. When `true`, the redirect is case-sensitive. When `false` the redirect is case-insensitive.", type: "boolean" }, query: { description: "Whether the query string should be preserved by the redirect. The default is `false`.", type: "boolean" } } } }; } }); // ../routing-utils/dist/types.js var require_types = __commonJS({ "../routing-utils/dist/types.js"(exports, module2) { "use strict"; var __defProp2 = Object.defineProperty; var __getOwnPropDesc2 = Object.getOwnPropertyDescriptor; var __getOwnPropNames2 = Object.getOwnPropertyNames; var __hasOwnProp2 = Object.prototype.hasOwnProperty; var __copyProps2 = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames2(from)) if (!__hasOwnProp2.call(to, key) && key !== except) __defProp2(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc2(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS2 = (mod) => __copyProps2(__defProp2({}, "__esModule", { value: true }), mod); var types_exports = {}; module2.exports = __toCommonJS2(types_exports); } }); // ../routing-utils/dist/index.js var require_dist3 = __commonJS({ "../routing-utils/dist/index.js"(exports, module2) { "use strict"; var __defProp2 = Object.defineProperty; var __getOwnPropDesc2 = Object.getOwnPropertyDescriptor; var __getOwnPropNames2 = Object.getOwnPropertyNames; var __hasOwnProp2 = Object.prototype.hasOwnProperty; var __export2 = (target, all) => { for (var name in all) __defProp2(target, name, { get: all[name], enumerable: true }); }; var __copyProps2 = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames2(from)) if (!__hasOwnProp2.call(to, key) && key !== except) __defProp2(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc2(from, key)) || desc.enumerable }); } return to; }; var __reExport = (target, mod, secondTarget) => (__copyProps2(target, mod, "default"), secondTarget && __copyProps2(secondTarget, mod, "default")); var __toCommonJS2 = (mod) => __copyProps2(__defProp2({}, "__esModule", { value: true }), mod); var src_exports2 = {}; __export2(src_exports2, { appendRoutesToPhase: () => import_append.appendRoutesToPhase, getCleanUrls: () => import_superstatic2.getCleanUrls, getTransformedRoutes: () => getTransformedRoutes2, isHandler: () => isHandler, isValidHandleValue: () => isValidHandleValue, mergeRoutes: () => import_merge.mergeRoutes, normalizeRoutes: () => normalizeRoutes, sourceToRegex: () => import_superstatic2.sourceToRegex }); module2.exports = __toCommonJS2(src_exports2); var import_url = require("url"); var import_superstatic = require_superstatic(); var import_append = require_append(); var import_merge = require_merge(); __reExport(src_exports2, require_schemas(), module2.exports); var import_superstatic2 = require_superstatic(); __reExport(src_exports2, require_types(), module2.exports); var VALID_HANDLE_VALUES = [ "filesystem", "hit", "miss", "rewrite", "error", "resource" ]; var validHandleValues = new Set(VALID_HANDLE_VALUES); function isHandler(route) { return typeof route.handle !== "undefined"; } function isValidHandleValue(handle) { return validHandleValues.has(handle); } function normalizeRoutes(inputRoutes) { if (!inputRoutes || inputRoutes.length === 0) { return { routes: inputRoutes, error: null }; } const routes = []; const handling = []; const errors = []; inputRoutes.forEach((r, i) => { const route = { ...r }; routes.push(route); const keys = Object.keys(route); if (isHandler(route)) { const { handle } = route; if (keys.length !== 1) { const unknownProp = keys.find((prop) => prop !== "handle"); errors.push( `Route at index ${i} has unknown property \`${unknownProp}\`.` ); } else if (!isValidHandleValue(handle)) { errors.push( `Route at index ${i} has unknown handle value \`handle: ${handle}\`.` ); } else if (handling.includes(handle)) { errors.push( `Route at index ${i} is a duplicate. Please use one \`handle: ${handle}\` at most.` ); } else { handling.push(handle); } } else if (route.src) { if (!route.src.startsWith("^")) { route.src = `^${route.src}`; } if (!route.src.endsWith("$")) { route.src = `${route.src}$`; } route.src = route.src.replace(/\\\//g, "/"); const regError = checkRegexSyntax("Route", i, route.src); if (regError) { errors.push(regError); } const handleValue = handling[handling.length - 1]; if (handleValue === "hit") { if (route.dest) { errors.push( `Route at index ${i} cannot define \`dest\` after \`handle: hit\`.` ); } if (route.status) { errors.push( `Route at index ${i} cannot define \`status\` after \`handle: hit\`.` ); } if (!route.continue) { errors.push( `Route at index ${i} must define \`continue: true\` after \`handle: hit\`.` ); } } else if (handleValue === "miss") { if (route.dest && !route.check) { errors.push( `Route at index ${i} must define \`check: true\` after \`handle: miss\`.` ); } else if (!route.dest && !route.continue) { errors.push( `Route at index ${i} must define \`continue: true\` after \`handle: miss\`.` ); } } } else { errors.push( `Route at index ${i} must define either \`handle\` or \`src\` property.` ); } }); const error = errors.length > 0 ? createError( "invalid_route", errors, "https://vercel.link/routes-json", "Learn More" ) : null; return { routes, error }; } function checkRegexSyntax(type, index, src) { try { new RegExp(src); } catch (err) { const prop = type === "Route" ? "src" : "source"; return `${type} at index ${index} has invalid \`${prop}\` regular expression "${src}".`; } return null; } function checkPatternSyntax(type, index, { source, destination, has }) { let sourceSegments = /* @__PURE__ */ new Set(); const destinationSegments = /* @__PURE__ */ new Set(); try { sourceSegments = new Set((0, import_superstatic.sourceToRegex)(source).segments); } catch (err) { return { message: `${type} at index ${index} has invalid \`source\` pattern "${source}".`, link: "https://vercel.link/invalid-route-source-pattern" }; } if (destination) { try { const { hostname, pathname, query } = (0, import_url.parse)(destination, true); (0, import_superstatic.sourceToRegex)(hostname || "").segments.forEach( (name) => destinationSegments.add(name) ); (0, import_superstatic.sourceToRegex)(pathname || "").segments.forEach( (name) => destinationSegments.add(name) ); for (const strOrArray of Object.values(query)) { const value = Array.isArray(strOrArray) ? strOrArray[0] : strOrArray; (0, import_superstatic.sourceToRegex)(value || "").segments.forEach( (name) => destinationSegments.add(name) ); } } catch (err) { } const hasSegments = (0, import_superstatic.collectHasSegments)(has); for (const segment of destinationSegments) { if (!sourceSegments.has(segment) && !hasSegments.includes(segment)) { return { message: `${type} at index ${index} has segment ":${segment}" in \`destination\` property but not in \`source\` or \`has\` property.`, link: "https://vercel.link/invalid-route-destination-segment" }; } } } return null; } function checkRedirect(r, index) { if (typeof r.permanent !== "undefined" && typeof r.statusCode !== "undefined") { return `Redirect at index ${index} cannot define both \`permanent\` and \`statusCode\` properties.`; } return null; } function createError(code, allErrors, link, action) { const errors = Array.isArray(allErrors) ? allErrors : [allErrors]; const message = errors[0]; const error = { name: "RouteApiError", code, message, link, action, errors }; return error; } function notEmpty(value) { return value !== null && value !== void 0; } function getTransformedRoutes2(vercelConfig) { const { cleanUrls, rewrites, redirects, headers, trailingSlash } = vercelConfig; let { routes = null } = vercelConfig; if (routes) { const hasNewProperties = typeof cleanUrls !== "undefined" || typeof trailingSlash !== "undefined" || typeof redirects !== "undefined" || typeof headers !== "undefined" || typeof rewrites !== "undefined"; if (hasNewProperties) { const error = createError( "invalid_mixed_routes", "If `rewrites`, `redirects`, `headers`, `cleanUrls` or `trailingSlash` are used, then `routes` cannot be present.", "https://vercel.link/mix-routing-props", "Learn More" ); return { routes, error }; } return normalizeRoutes(routes); } if (typeof cleanUrls !== "undefined") { const normalized = normalizeRoutes( (0, import_superstatic.convertCleanUrls)(cleanUrls, trailingSlash) ); if (normalized.error) { normalized.error.code = "invalid_clean_urls"; return { routes, error: normalized.error }; } routes = routes || []; routes.push(...normalized.routes || []); } if (typeof trailingSlash !== "undefined") { const normalized = normalizeRoutes((0, import_superstatic.convertTrailingSlash)(trailingSlash)); if (normalized.error) { normalized.error.code = "invalid_trailing_slash"; return { routes, error: normalized.error }; } routes = routes || []; routes.push(...normalized.routes || []); } if (typeof redirects !== "undefined") { const code = "invalid_redirect"; const regexErrorMessage = redirects.map((r, i) => checkRegexSyntax("Redirect", i, r.source)).find(notEmpty); if (regexErrorMessage) { return { routes, error: createError( "invalid_redirect", regexErrorMessage, "https://vercel.link/invalid-route-source-pattern", "Learn More" ) }; } const patternError = redirects.map((r, i) => checkPatternSyntax("Redirect", i, r)).find(notEmpty); if (patternError) { return { routes, error: createError( code, patternError.message, patternError.link, "Learn More" ) }; } const redirectErrorMessage = redirects.map(checkRedirect).find(notEmpty); if (redirectErrorMessage) { return { routes, error: createError( code, redirectErrorMessage, "https://vercel.link/redirects-json", "Learn More" ) }; } const normalized = normalizeRoutes((0, import_superstatic.convertRedirects)(redirects)); if (normalized.error) { normalized.error.code = code; return { routes, error: normalized.error }; } routes = routes || []; routes.push(...normalized.routes || []); } if (typeof headers !== "undefined") { const code = "invalid_header"; const regexErrorMessage = headers.map((r, i) => checkRegexSyntax("Header", i, r.source)).find(notEmpty); if (regexErrorMessage) { return { routes, error: createError( code, regexErrorMessage, "https://vercel.link/invalid-route-source-pattern", "Learn More" ) }; } const patternError = headers.map((r, i) => checkPatternSyntax("Header", i, r)).find(notEmpty); if (patternError) { return { routes, error: createError( code, patternError.message, patternError.link, "Learn More" ) }; } const normalized = normalizeRoutes((0, import_superstatic.convertHeaders)(headers)); if (normalized.error) { normalized.error.code = code; return { routes, error: normalized.error }; } routes = routes || []; routes.push(...normalized.routes || []); } if (typeof rewrites !== "undefined") { const code = "invalid_rewrite"; const regexErrorMessage = rewrites.map((r, i) => checkRegexSyntax("Rewrite", i, r.source)).find(notEmpty); if (regexErrorMessage) { return { routes, error: createError( code, regexErrorMessage, "https://vercel.link/invalid-route-source-pattern", "Learn More" ) }; } const patternError = rewrites.map((r, i) => checkPatternSyntax("Rewrite", i, r)).find(notEmpty); if (patternError) { return { routes, error: createError( code, patternError.message, patternError.link, "Learn More" ) }; } const normalized = normalizeRoutes((0, import_superstatic.convertRewrites)(rewrites)); if (normalized.error) { normalized.error.code = code; return { routes, error: normalized.error }; } routes = routes || []; routes.push({ handle: "filesystem" }); routes.push(...normalized.routes || []); } return { routes, error: null }; } } }); // src/index.ts var src_exports = {}; __export(src_exports, { build: () => build, prepareCache: () => prepareCache, version: () => version }); module.exports = __toCommonJS(src_exports); var import_path = require("path"); var import_ts_morph = require("ts-morph"); var import_static_config = require("@vercel/static-config"); var import_fs = require("fs"); var import_semver = require("semver"); var import_build_utils = require("@vercel/build-utils"); var import_nft = require("@vercel/nft"); var import_routing_utils = __toESM(require_dist3()); var version = 2; var build = async ({ workPath, files, entrypoint, meta = {}, config = {} }) => { await (0, import_build_utils.download)(files, workPath, meta); const prefixedEnvs = (0, import_build_utils.getPrefixedEnvVars)({ envPrefix: "REDWOOD_ENV_", envs: process.env }); for (const [key, value] of Object.entries(prefixedEnvs)) { process.env[key] = value; } const { installCommand, buildCommand } = config; const mountpoint = (0, import_path.dirname)(entrypoint); const entrypointFsDirname = (0, import_path.join)(workPath, mountpoint); const nodeVersion = await (0, import_build_utils.getNodeVersion)( entrypointFsDirname, void 0, config, meta ); const { cliType, lockfileVersion, packageJsonPackageManager, turboSupportsCorepackHome } = await (0, import_build_utils.scanParentDirs)(entrypointFsDirname, true); const spawnEnv = (0, import_build_utils.getEnvForPackageManager)({ cliType, lockfileVersion, packageJsonPackageManager, env: process.env, turboSupportsCorepackHome, projectCreatedAt: config.projectSettings?.createdAt }); if (typeof installCommand === "string") { if (installCommand.trim()) { console.log(`Running "install" command: \`${installCommand}\`...`); await (0, import_build_utils.execCommand)(installCommand, { env: spawnEnv, cwd: entrypointFsDirname }); } else { console.log(`Skipping "install" command...`); } } else { await (0, import_build_utils.runNpmInstall)( entrypointFsDirname, [], { env: spawnEnv }, meta, config.projectSettings?.createdAt ); } if (meta.isDev) { throw new Error("Detected `@vercel/redwood` dev but this is not supported"); } const pkg = await (0, import_build_utils.readConfigFile)((0, import_path.join)(workPath, "package.json")); const toml = await (0, import_build_utils.readConfigFile)( (0, import_path.join)(workPath, "redwood.toml") ); if (buildCommand) { (0, import_build_utils.debug)(`Executing build command "${buildCommand}"`); await (0, import_build_utils.execCommand)(buildCommand, { env: spawnEnv, cwd: workPath }); } else if (hasScript("vercel-build", pkg)) { (0, import_build_utils.debug)(`Executing "yarn vercel-build"`); await (0, import_build_utils.runPackageJsonScript)( workPath, "vercel-build", { env: spawnEnv }, config.projectSettings?.createdAt ); } else if (hasScript("build", pkg)) { (0, import_build_utils.debug)(`Executing "yarn build"`); await (0, import_build_utils.runPackageJsonScript)( workPath, "build", { env: spawnEnv }, config.projectSettings?.createdAt ); } else { const { devDependencies = {} } = pkg || {}; const versionRange = devDependencies["@redwoodjs/core"]; let cmd; if (!versionRange || !(0, import_semver.validRange)(versionRange)) { console.log( "WARNING: Unable to detect RedwoodJS version in package.json devDependencies" ); cmd = "yarn rw deploy vercel"; } else if ((0, import_semver.intersects)(versionRange, "<0.25.0")) { cmd = "yarn rw build && yarn rw db up --no-db-client --auto-approve && yarn rw dataMigrate up"; } else { cmd = "yarn rw deploy vercel"; } await (0, import_build_utils.execCommand)(cmd, { env: spawnEnv, cwd: workPath }); } const apiDir = toml?.web?.apiProxyPath?.replace(/^\//, "") ?? "api"; const apiDistPath = (0, import_path.join)(workPath, "api", "dist", "functions"); const webDistPath = (0, import_path.join)(workPath, "web", "dist"); const lambdaOutputs = {}; const webDistFiles = await (0, import_build_utils.glob)("**", webDistPath); const staticOutputs = {}; for (const [fileName, fileFsRef] of Object.entries(webDistFiles)) { const parsedPath = (0, import_path.parse)(fileFsRef.fsPath); if (parsedPath.ext !== ".html") { staticOutputs[fileName] = fileFsRef; } else { const fileNameWithoutExtension = (0, import_path.basename)(fileName, ".html"); const pathWithoutHtmlExtension = (0, import_path.join)( parsedPath.dir, fileNameWithoutExtension ); fileFsRef.contentType = "text/html; charset=utf-8"; staticOutputs[(0, import_path.relative)(webDistPath, pathWithoutHtmlExtension)] = fileFsRef; } } const functionFiles = await (0, import_build_utils.glob)("**/*.{js,ts}", apiDistPath); const sourceCache = /* @__PURE__ */ new Map(); const fsCache = /* @__PURE__ */ new Map(); const project = new import_ts_morph.Project(); for (const [funcName, fileFsRef] of Object.entries(functionFiles)) { const outputName = (0, import_path.join)(apiDir, (0, import_path.parse)(funcName).name); const absEntrypoint = fileFsRef.fsPath; const relativeEntrypoint = (0, import_path.relative)(workPath, absEntrypoint); const awsLambdaHandler = getAWSLambdaHandler(relativeEntrypoint, "handler"); let sourceFile = relativeEntrypoint.replace("/dist/", "/src/"); const sourceFileBase = (0, import_path.basename)(sourceFile, ".js"); const sourceFileDir = (0, import_path.dirname)(sourceFile); if ((0, import_fs.existsSync)((0, import_path.join)(sourceFileDir, `${sourceFileBase}.ts`))) { sourceFile = (0, import_path.join)(sourceFileDir, `${sourceFileBase}.ts`); } const { fileList, esmFileList, warnings } = await (0, import_nft.nodeFileTrace)( [absEntrypoint], { base: workPath, processCwd: workPath, ts: true, mixedModules: true, ignore: config.excludeFiles, async readFile(fsPath) { const relPath = (0, import_path.relative)(workPath, fsPath); const cached = sourceCache.get(relPath); if (cached) return cached.toString(); if (cached === null) return null; try { const source = (0, import_fs.readFileSync)(fsPath); const { mode } = (0, import_fs.lstatSync)(fsPath); let entry; if ((0, import_build_utils.isSymbolicLink)(mode)) { entry = new import_build_utils.FileFsRef({ fsPath, mode }); } else { entry = new import_build_utils.FileBlob({ data: source, mode }); } fsCache.set(relPath, entry); sourceCache.set(relPath, source); return source.toString(); } catch (e) { if (e.code === "ENOENT" || e.code === "EISDIR") { sourceCache.set(relPath, null); return null; } throw e; } } } ); for (const warning of warnings) { (0, import_build_utils.debug)(`Warning from trace: ${warning.message}`); } const lambdaFiles = {}; const allFiles = [...fileList, ...esmFileList]; for (const filePath of allFiles) { lambdaFiles[filePath] = await import_build_utils.FileFsRef.fromFsPath({ fsPath: (0, import_path.join)(workPath, filePath) }); } lambdaFiles[(0, import_path.relative)(workPath, fileFsRef.fsPath)] = fileFsRef; const staticConfig = (0, import_static_config.getConfig)(project, sourceFile); const regions = staticConfig?.regions; if (regions && !Array.isArray(regions)) { throw new Error('"regions" configuration must be an array'); } const lambda = new import_build_utils.NodejsLambda({ ...staticConfig, regions, files: lambdaFiles, handler: relativeEntrypoint, runtime: nodeVersion.runtime, shouldAddHelpers: false, shouldAddSourcemapSupport: false, awsLambdaHandler, shouldDisableAutomaticFetchInstrumentation: process.env.VERCEL_TRACING_DISABLE_AUTOMATIC_FETCH_INSTRUMENTATION === "1" }); lambdaOutputs[outputName] = lambda; } const fallbackHtmlPage = (0, import_fs.existsSync)((0, import_path.join)(webDistPath, "200.html")) ? "/200" : "/index"; const defaultRoutesConfig = (0, import_routing_utils.getTransformedRoutes)({ // this makes sure we send back 200.html for unprerendered pages rewrites: [{ source: "/(.*)", destination: fallbackHtmlPage }], cleanUrls: true, trailingSlash: false }); if (defaultRoutesConfig.error) { throw new Error(defaultRoutesConfig.error.message); } return { output: { ...staticOutputs, ...lambdaOutputs }, routes: defaultRoutesConfig.routes }; }; function getAWSLambdaHandler(filePath, handlerName) { const { dir, name } = (0, import_path.parse)(filePath); return `${dir}${dir ? import_path.sep : ""}${name}.${handlerName}`; } function hasScript(scriptName, pkg) { const scripts = pkg && pkg.scripts || {}; return typeof scripts[scriptName] === "string"; } var prepareCache = ({ repoRootPath, workPath }) => { return (0, import_build_utils.glob)(import_build_utils.defaultCachePathGlob, repoRootPath || workPath); }; // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { build, prepareCache, version });