From ffad9e288e757c4d36fe4998e1a498abca211e21 Mon Sep 17 00:00:00 2001 From: exoego Date: Mon, 6 May 2024 14:07:21 +0900 Subject: [PATCH 1/4] Implement top-ten largest paths visualization --- dist/index.mjs | 138 ++++++++++++++++++++++++++++++++++++++--- src/compare.ts | 164 +++++++++++++++++++++++++++++++++++++++++++++---- src/types.ts | 9 +++ 3 files changed, 291 insertions(+), 20 deletions(-) diff --git a/dist/index.mjs b/dist/index.mjs index 314ccd7..e2d4ad1 100644 --- a/dist/index.mjs +++ b/dist/index.mjs @@ -165,6 +165,33 @@ function getInput(name) { } // src/compare.ts +function buildTree(input) { + const root = { name: "", path: "", value: 0, children: [] }; + for (const [filePath, { bytesInOutput }] of Object.entries(input)) { + const directories = filePath.split("/"); + buildNode(root, directories, bytesInOutput); + } + return root; +} +function buildNode(node, paths, value) { + const first = paths.shift(); + if (first === void 0) { + node.value += value; + return; + } + let child = node.children.find((child2) => child2.name === first); + if (!child) { + child = { + name: first, + path: `${node.path}/${first}`.replace(/^\//, ""), + value: 0, + children: [] + }; + node.children.push(child); + } + node.value += value; + buildNode(child, paths, value); +} function compare(input) { let hasAnyChange = false; let output = `## \u{1F4E6} esbuild Bundle Analysis for ${input.name} @@ -186,6 +213,18 @@ This analysis was generated by [esbuild-bundle-analyzer](https://github.com/exoe } catch (e) { base = {}; } + const trees = /* @__PURE__ */ new Map(); + for (const metafileRelPath of input.metafiles) { + const metafile = loadMetaFile(path.join(process.cwd(), metafileRelPath)); + for (const [outfile, buildMeta] of Object.entries(metafile.outputs)) { + const tree = buildTree(buildMeta.inputs); + trees.set(`${metafileRelPath} -> ${outfile}`, tree); + fs2.writeFileSync( + path.join(process.cwd(), input.analyzerDirectory, "tree.json"), + JSON.stringify(tree, null, 2) + ); + } + } const allOutFiles = [ .../* @__PURE__ */ new Set([...Object.keys(current), ...Object.keys(base)]) ].sort(); @@ -194,11 +233,14 @@ This analysis was generated by [esbuild-bundle-analyzer](https://github.com/exoe const baseStats = base[outfile]; if (!currentStats) { hasAnyChange = true; - return { ...baseStats, diff: -1, remark: "deleted" }; + return { ...baseStats, diff: -1, remark: "deleted", tree: void 0 }; } + const tree = trees.get( + `${currentStats.metafile} -> ${currentStats.outfile}` + ); if (!baseStats) { hasAnyChange = true; - return { ...currentStats, diff: -1, remark: "added" }; + return { ...currentStats, diff: -1, remark: "added", tree }; } const diff = currentStats.bytes - baseStats.bytes; const increase = !!Math.sign(diff); @@ -208,11 +250,13 @@ This analysis was generated by [esbuild-bundle-analyzer](https://github.com/exoe return { ...currentStats, diff, + tree, remark: increase ? "increased" : "decreased" }; }); if (hasAnyChange) { output += markdownTable(comparison, input.percentExtraAttention); + output += fileSizeTable(comparison); if (input.showDetails) { output += `
@@ -232,11 +276,6 @@ This analysis was generated by [esbuild-bundle-analyzer](https://github.com/exoe output += "This PR introduced no changes to the esbuild bundle! \u{1F64C}"; } output += ``; - console.dir({ - input, - hasAnyChange, - output - }); fs2.mkdirSync(path.join(process.cwd(), input.analyzerDirectory), { recursive: true }); @@ -267,6 +306,89 @@ Meta File | Out File | Size (raw) | Note ----------|----------|-----------:|------ ${rows}`; } +function findLargeDirectories(root) { + const nodes = []; + const queue = [ + { node: root, depth: 0 } + ]; + while (queue.length > 0) { + const shift = queue.shift(); + if (!shift) { + break; + } + const { node, depth } = shift; + if (depth === 3) { + nodes.push(node); + continue; + } + if (node.children.length === 0) { + nodes.push(node); + } else { + for (const item of node.children) { + queue.push({ node: item, depth: depth + 1 }); + } + } + } + const largeNodes = nodes.sort((a, b) => b.value - a.value).slice(0, 10); + return { + largeNodes, + hasOther: nodes.length > 10 + }; +} +function fixedPercent(n, d) { + return Number.parseFloat((n / d * 100).toFixed(1)); +} +function fileSizeTable(data) { + if (data.length === 0) { + return ""; + } + let output = ""; + output += "
\n"; + output += "Top ten largest paths\n"; + for (const d of data) { + output += "\n"; + output += `## Meta file: ${d.metafile}, Out file: ${d.outfile} +`; + if (!d.tree) { + output += "\uFE0F\uFE0F\u{1F5D1}\uFE0FDeleted\n"; + continue; + } + output += "| Path | Size |\n"; + output += "|------|-------|\n"; + const totalSize = d.tree.value; + const { largeNodes, hasOther } = findLargeDirectories(d.tree); + for (const { path: path3, value } of largeNodes) { + const percent = fixedPercent(value, totalSize); + output += `| ${path3} | ${renderBar(percent, value)} | +`; + } + if (hasOther) { + const otherSize = totalSize - largeNodes[0].value; + const otherPercent = fixedPercent(otherSize, totalSize); + output += `| (other) | ${renderBar(otherPercent, otherSize)} | +`; + } + } + output += "
\n"; + return output; +} +function renderBar(percent, bytes) { + const bar = progress(percent / 100); + return `\${{\\color{Goldenrod}{ ${bar} }}}$ ${percent.toFixed( + 1 + )}%, ${filesize2(bytes)}`; +} +var blocks = ["", "\u258F", "\u258E", "\u258D", "\u258C", "\u258B", "\u258A", "\u2589", "\u2588"]; +var progression = 1 / (blocks.length - 1); +function progress(value, length = 25, vmin = 0, vmax = 1) { + const v = value * length; + const integerPart = Math.floor(v); + const fractionalPart = v - integerPart; + const i = Math.round( + progression * Math.floor(fractionalPart / progression) / progression + ); + return "\u2588".repeat(integerPart) + blocks[i]; +} function renderSize(d) { return filesize2(d.bytes); } @@ -393,4 +515,4 @@ filesize/dist/filesize.esm.js: * @version 10.1.1 *) */ -//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/compare.ts", "../src/utils.ts", "../src/report.ts"],
  "sourcesContent": ["import { pathToFileURL } from \"node:url\";\nimport { compare } from \"./compare\";\nimport { report } from \"./report\";\nimport type { Options } from \"./types\";\nimport { getInput } from \"./utils\";\n\nfunction getOptions(): Options {\n\tconst rawMetafiles = getInput(\"metafiles\");\n\tif (!rawMetafiles) {\n\t\tthrow new Error(\"metafiles is not specified\");\n\t}\n\tconst name = getInput(\"name\");\n\tif (!name) {\n\t\tthrow new Error(\"name is not specified\");\n\t}\n\treturn {\n\t\tpercentExtraAttention: Number.parseInt(\n\t\t\tgetInput(\"percent_extra_attention\") || \"20\",\n\t\t\t10,\n\t\t),\n\t\tshowDetails: [\"true\", \"True\", \"TRUE\"].includes(\n\t\t\tgetInput(\"show_details\") || \"true\",\n\t\t),\n\t\tincludeExtensions: (\n\t\t\tgetInput(\"include_extensions\") || \".js,.mjs,.cjs\"\n\t\t).split(\",\"),\n\t\tname,\n\t\tanalyzerDirectory: getInput(\"analyze_directory\") || \".analyzer\",\n\t\tmetafiles: rawMetafiles.split(\",\"),\n\t};\n}\n\nexport function run(options: Options = getOptions()): void {\n\treport(options);\n\tcompare(options);\n}\n\nif (import.meta.url === pathToFileURL(process.argv[1]).href) {\n\trun();\n}\n", "import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { filesize as originalFilesize } from \"filesize\";\nimport type { CompareResult, Options, Report } from \"./types\";\nimport { loadAnalysisJson } from \"./utils\";\n\nexport function compare(input: Options): void {\n\tlet hasAnyChange = false;\n\tlet output = `## \uD83D\uDCE6 esbuild Bundle Analysis for ${input.name}\n\nThis analysis was generated by [esbuild-bundle-analyzer](https://github.com/exoego/esbuild-bundle-analyzer). \uD83E\uDD16\n`;\n\n\tconst current = loadAnalysisJson(\n\t\tpath.join(process.cwd(), input.analyzerDirectory, \"bundle_analysis.json\"),\n\t);\n\tlet base: Report;\n\ttry {\n\t\tbase = loadAnalysisJson(\n\t\t\tpath.join(\n\t\t\t\tprocess.cwd(),\n\t\t\t\tinput.analyzerDirectory,\n\t\t\t\t\"base/bundle/bundle_analysis.json\",\n\t\t\t),\n\t\t);\n\t} catch (e) {\n\t\tbase = {};\n\t}\n\n\tconst allOutFiles: string[] = [\n\t\t...new Set([...Object.keys(current), ...Object.keys(base)]),\n\t].sort();\n\tconst comparison: Array<CompareResult> = allOutFiles.map((outfile) => {\n\t\tconst currentStats = current[outfile];\n\t\tconst baseStats = base[outfile];\n\n\t\tif (!currentStats) {\n\t\t\thasAnyChange = true;\n\t\t\t// deleted out file\n\t\t\treturn { ...baseStats, diff: -1, remark: \"deleted\" };\n\t\t}\n\t\tif (!baseStats) {\n\t\t\thasAnyChange = true;\n\t\t\t// new out file\n\t\t\treturn { ...currentStats, diff: -1, remark: \"added\" };\n\t\t}\n\t\tconst diff = currentStats.bytes - baseStats.bytes;\n\t\tconst increase = !!Math.sign(diff);\n\t\tif (diff !== 0) {\n\t\t\thasAnyChange = true;\n\t\t}\n\t\treturn {\n\t\t\t...currentStats,\n\t\t\tdiff,\n\t\t\tremark: increase ? \"increased\" : \"decreased\",\n\t\t};\n\t});\n\n\tif (hasAnyChange) {\n\t\toutput += markdownTable(comparison, input.percentExtraAttention);\n\n\t\tif (input.showDetails) {\n\t\t\toutput += `\\n<details>\n<summary>Details</summary>\n<p>Next to the size is how much the size has increased or decreased compared with the base branch of this PR.</p>\n<ul>\n<li>\u203C\uFE0F: Size increased by ${input.percentExtraAttention}% or more. Special attention should be given to this.</li>\n<li>\u26A0\uFE0F: Size increased in acceptable range (lower than ${input.percentExtraAttention}%).</li>\n<li>\u2705: No change or even downsized.</li>\n<li>\uD83D\uDDD1\uFE0F: The out file is deleted: not found in base branch.</li>\n<li>\uD83C\uDD95: The out file is newly found: will be added to base branch.</li>\n</ul>\n</details>\\n`;\n\t\t}\n\t} else {\n\t\toutput += \"This PR introduced no changes to the esbuild bundle! \uD83D\uDE4C\";\n\t}\n\n\t// we add this tag so that our action can be able to easily and\n\t// consistently find the right comment to edit as more commits are pushed.\n\toutput += `<!-- __ESBUILD_BUNDLE_${input.name} -->`;\n\n\t// Log mostly for testing and debugging.\n\t// This will show up in the github actions console.\n\tconsole.dir({\n\t\tinput,\n\t\thasAnyChange,\n\t\toutput,\n\t});\n\n\t// Write the output to a file which is later read in\n\t// as comment contents by the actions workflow.\n\tfs.mkdirSync(path.join(process.cwd(), input.analyzerDirectory), {\n\t\trecursive: true,\n\t});\n\tfs.writeFileSync(\n\t\tpath.join(\n\t\t\tprocess.cwd(),\n\t\t\tinput.analyzerDirectory,\n\t\t\t\"bundle_analysis_comment.txt\",\n\t\t),\n\t\toutput.trim(),\n\t);\n}\n\nfunction filesize(bytes: number): string {\n\treturn originalFilesize(bytes, {\n\t\tspacer: \"\u00A0\",\n\t});\n}\n\nfunction markdownTable(\n\tdata: Array<CompareResult>,\n\tredThreshold: number,\n): string {\n\tconst rows = data\n\t\t.map((d) => {\n\t\t\treturn `${d.metafile} | ${d.outfile} | ${renderSize(d)} | ${renderNote(\n\t\t\t\td,\n\t\t\t\tredThreshold,\n\t\t\t)}\\n`;\n\t\t})\n\t\t.join(\"\");\n\n\treturn `\nMeta File | Out File  | Size (raw) | Note \n----------|----------|-----------:|------\n${rows}`;\n}\n\nfunction renderSize(d: CompareResult): string {\n\treturn filesize(d.bytes);\n}\n\nfunction renderNote(d: CompareResult, redThreshold: number): string {\n\tif (d.remark === \"deleted\") {\n\t\treturn \"\uD83D\uDDD1\uFE0F Deleted\";\n\t}\n\tif (d.remark === \"added\") {\n\t\treturn \"\uD83C\uDD95 Added\";\n\t}\n\tif (d.diff) {\n\t\tconst percentChange = (d.diff / d.bytes) * 100;\n\t\treturn `${renderStatusIndicator(percentChange, redThreshold)}${filesize(\n\t\t\td.diff,\n\t\t)} (${sign(percentChange)}${percentChange.toFixed(1)}%)`;\n\t}\n\treturn \"\u2705  No change\";\n}\n\nfunction sign(num: number): string {\n\treturn num < 0 ? \"\" : \"+\";\n}\n\nfunction renderStatusIndicator(\n\tpercentChange: number,\n\tredThreshold: number,\n): string {\n\tlet res: string;\n\tif (percentChange > 0 && percentChange < redThreshold) {\n\t\tres = \"\u26A0\uFE0F\";\n\t} else if (percentChange >= redThreshold) {\n\t\tres = \"\u203C\uFE0F\";\n\t} else {\n\t\tres = \"\u2705 \";\n\t}\n\treturn `${res} ${sign(percentChange)}`;\n}\n", "import fs from \"node:fs\";\n\nimport type { Metafile } from \"esbuild\";\nimport type { Report } from \"./types\";\n\nfunction loadJsonFile(path: string) {\n\treturn JSON.parse(fs.readFileSync(path).toString(\"utf-8\"));\n}\n\nexport function loadMetaFile(path: string): Metafile {\n\treturn loadJsonFile(path) as Metafile;\n}\n\nexport function loadAnalysisJson(path: string): Report {\n\treturn loadJsonFile(path) as Report;\n}\n\n// https://github.com/actions/toolkit/blob/81a73aba8bedd532f6eddcc41ed3a0fad8b1cfeb/packages/core/src/core.ts#L126\nexport function getInput(name: string): string {\n\tconst val = process.env[`INPUT_${name.toUpperCase()}`] || \"\";\n\treturn val.trim();\n}\n", "import fs from \"node:fs\";\nimport path from \"node:path\";\nimport process from \"node:process\";\n\nimport type { Options, Report } from \"./types\";\nimport { loadMetaFile } from \"./utils\";\n\nexport function report(input: Options): void {\n\tconst allPageSizes = getAllPageSizes(input);\n\tfs.mkdirSync(path.join(process.cwd(), input.analyzerDirectory), {\n\t\trecursive: true,\n\t});\n\tconst resultJsonPath = path.join(\n\t\tprocess.cwd(),\n\t\tinput.analyzerDirectory,\n\t\t\"bundle_analysis.json\",\n\t);\n\tfs.writeFileSync(resultJsonPath, JSON.stringify(allPageSizes, null, 2));\n\tconsole.log(`Wrote ${resultJsonPath}`);\n}\n\nfunction getAllPageSizes(input: Options): Report {\n\tconst acc: Report = {};\n\treturn input.metafiles.reduce((acc, metafile) => {\n\t\tconst metaFilePath = path.join(process.cwd(), metafile);\n\t\ttry {\n\t\t\tfs.accessSync(metaFilePath, fs.constants.R_OK);\n\t\t} catch (err) {\n\t\t\tconsole.error(\n\t\t\t\t`No meta file found at \"${metaFilePath}\" - a path to meta file may be wrong, or esbuild is not executed.`,\n\t\t\t);\n\t\t\tprocess.exit(1);\n\t\t}\n\n\t\tconst metaFileJson = loadMetaFile(metaFilePath);\n\t\tObject.entries(metaFileJson.outputs).reduce((acc, output) => {\n\t\t\tconst [outfile, buildMeta] = output;\n\t\t\tif (\n\t\t\t\t!input.includeExtensions.some((ext) =>\n\t\t\t\t\toutfile.toLowerCase().endsWith(ext),\n\t\t\t\t)\n\t\t\t) {\n\t\t\t\treturn acc;\n\t\t\t}\n\t\t\tacc[`${metafile} -> ${outfile}`] = {\n\t\t\t\tbytes: buildMeta.bytes,\n\t\t\t\tmetafile,\n\t\t\t\toutfile,\n\t\t\t};\n\t\t\treturn acc;\n\t\t}, acc);\n\t\treturn acc;\n\t}, acc);\n}\n"],
  "mappings": "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",
  "names": ["fs", "path", "fs", "filesize", "fs", "path", "process", "fs", "path", "process", "acc"]
}
 +//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/compare.ts", "../src/utils.ts", "../src/report.ts"],
  "sourcesContent": ["import { pathToFileURL } from \"node:url\";\nimport { compare } from \"./compare\";\nimport { report } from \"./report\";\nimport type { Options } from \"./types\";\nimport { getInput } from \"./utils\";\n\nfunction getOptions(): Options {\n\tconst rawMetafiles = getInput(\"metafiles\");\n\tif (!rawMetafiles) {\n\t\tthrow new Error(\"metafiles is not specified\");\n\t}\n\tconst name = getInput(\"name\");\n\tif (!name) {\n\t\tthrow new Error(\"name is not specified\");\n\t}\n\treturn {\n\t\tpercentExtraAttention: Number.parseInt(\n\t\t\tgetInput(\"percent_extra_attention\") || \"20\",\n\t\t\t10,\n\t\t),\n\t\tshowDetails: [\"true\", \"True\", \"TRUE\"].includes(\n\t\t\tgetInput(\"show_details\") || \"true\",\n\t\t),\n\t\tincludeExtensions: (\n\t\t\tgetInput(\"include_extensions\") || \".js,.mjs,.cjs\"\n\t\t).split(\",\"),\n\t\tname,\n\t\tanalyzerDirectory: getInput(\"analyze_directory\") || \".analyzer\",\n\t\tmetafiles: rawMetafiles.split(\",\"),\n\t};\n}\n\nexport function run(options: Options = getOptions()): void {\n\treport(options);\n\tcompare(options);\n}\n\nif (import.meta.url === pathToFileURL(process.argv[1]).href) {\n\trun();\n}\n", "import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { filesize as originalFilesize } from \"filesize\";\nimport type { CompareResult, Options, Report, TreeMapNode } from \"./types\";\nimport { loadAnalysisJson, loadMetaFile } from \"./utils\";\n\nfunction buildTree(\n\tinput: Record<string, { bytesInOutput: number }>,\n): TreeMapNode {\n\tconst root: TreeMapNode = { name: \"\", path: \"\", value: 0, children: [] };\n\tfor (const [filePath, { bytesInOutput }] of Object.entries(input)) {\n\t\tconst directories = filePath.split(\"/\");\n\t\tbuildNode(root, directories, bytesInOutput);\n\t}\n\treturn root;\n}\n\nfunction buildNode(\n\tnode: TreeMapNode,\n\tpaths: Array<string>,\n\tvalue: number,\n): void {\n\tconst first = paths.shift();\n\tif (first === undefined) {\n\t\t// leaf node (file)\n\t\tnode.value += value;\n\t\treturn;\n\t}\n\tlet child = node.children.find((child) => child.name === first);\n\tif (!child) {\n\t\tchild = {\n\t\t\tname: first,\n\t\t\tpath: `${node.path}/${first}`.replace(/^\\//, \"\"),\n\t\t\tvalue: 0,\n\t\t\tchildren: [],\n\t\t};\n\t\tnode.children.push(child);\n\t}\n\tnode.value += value;\n\tbuildNode(child, paths, value);\n}\n\nexport function compare(input: Options): void {\n\tlet hasAnyChange = false;\n\tlet output = `## \uD83D\uDCE6 esbuild Bundle Analysis for ${input.name}\n\nThis analysis was generated by [esbuild-bundle-analyzer](https://github.com/exoego/esbuild-bundle-analyzer). \uD83E\uDD16\n`;\n\n\tconst current = loadAnalysisJson(\n\t\tpath.join(process.cwd(), input.analyzerDirectory, \"bundle_analysis.json\"),\n\t);\n\tlet base: Report;\n\ttry {\n\t\tbase = loadAnalysisJson(\n\t\t\tpath.join(\n\t\t\t\tprocess.cwd(),\n\t\t\t\tinput.analyzerDirectory,\n\t\t\t\t\"base/bundle/bundle_analysis.json\",\n\t\t\t),\n\t\t);\n\t} catch (e) {\n\t\tbase = {};\n\t}\n\n\tconst trees = new Map<string, TreeMapNode>();\n\tfor (const metafileRelPath of input.metafiles) {\n\t\tconst metafile = loadMetaFile(path.join(process.cwd(), metafileRelPath));\n\t\tfor (const [outfile, buildMeta] of Object.entries(metafile.outputs)) {\n\t\t\tconst tree = buildTree(buildMeta.inputs);\n\t\t\ttrees.set(`${metafileRelPath} -> ${outfile}`, tree);\n\n\t\t\tfs.writeFileSync(\n\t\t\t\tpath.join(process.cwd(), input.analyzerDirectory, \"tree.json\"),\n\t\t\t\tJSON.stringify(tree, null, 2),\n\t\t\t);\n\t\t}\n\t}\n\n\tconst allOutFiles: string[] = [\n\t\t...new Set([...Object.keys(current), ...Object.keys(base)]),\n\t].sort();\n\n\tconst comparison: Array<CompareResult> = allOutFiles.map((outfile) => {\n\t\tconst currentStats = current[outfile];\n\t\tconst baseStats = base[outfile];\n\n\t\tif (!currentStats) {\n\t\t\thasAnyChange = true;\n\t\t\t// deleted out file\n\t\t\treturn { ...baseStats, diff: -1, remark: \"deleted\", tree: undefined };\n\t\t}\n\n\t\tconst tree = trees.get(\n\t\t\t`${currentStats.metafile} -> ${currentStats.outfile}`,\n\t\t);\n\n\t\tif (!baseStats) {\n\t\t\thasAnyChange = true;\n\t\t\t// new out file\n\t\t\treturn { ...currentStats, diff: -1, remark: \"added\", tree };\n\t\t}\n\t\tconst diff = currentStats.bytes - baseStats.bytes;\n\t\tconst increase = !!Math.sign(diff);\n\t\tif (diff !== 0) {\n\t\t\thasAnyChange = true;\n\t\t}\n\t\treturn {\n\t\t\t...currentStats,\n\t\t\tdiff,\n\t\t\ttree,\n\t\t\tremark: increase ? \"increased\" : \"decreased\",\n\t\t};\n\t});\n\n\tif (hasAnyChange) {\n\t\toutput += markdownTable(comparison, input.percentExtraAttention);\n\t\toutput += fileSizeTable(comparison);\n\n\t\tif (input.showDetails) {\n\t\t\toutput += `\\n<details>\n<summary>Details</summary>\n<p>Next to the size is how much the size has increased or decreased compared with the base branch of this PR.</p>\n<ul>\n<li>\u203C\uFE0F: Size increased by ${input.percentExtraAttention}% or more. Special attention should be given to this.</li>\n<li>\u26A0\uFE0F: Size increased in acceptable range (lower than ${input.percentExtraAttention}%).</li>\n<li>\u2705: No change or even downsized.</li>\n<li>\uD83D\uDDD1\uFE0F: The out file is deleted: not found in base branch.</li>\n<li>\uD83C\uDD95: The out file is newly found: will be added to base branch.</li>\n</ul>\n</details>\\n`;\n\t\t}\n\t} else {\n\t\toutput += \"This PR introduced no changes to the esbuild bundle! \uD83D\uDE4C\";\n\t}\n\n\t// we add this tag so that our action can be able to easily and\n\t// consistently find the right comment to edit as more commits are pushed.\n\toutput += `<!-- __ESBUILD_BUNDLE_${input.name} -->`;\n\n\t// Write the output to a file which is later read in\n\t// as comment contents by the actions workflow.\n\tfs.mkdirSync(path.join(process.cwd(), input.analyzerDirectory), {\n\t\trecursive: true,\n\t});\n\tfs.writeFileSync(\n\t\tpath.join(\n\t\t\tprocess.cwd(),\n\t\t\tinput.analyzerDirectory,\n\t\t\t\"bundle_analysis_comment.txt\",\n\t\t),\n\t\toutput.trim(),\n\t);\n}\n\nfunction filesize(bytes: number): string {\n\treturn originalFilesize(bytes, {\n\t\tspacer: \"\u00A0\",\n\t});\n}\n\nfunction markdownTable(\n\tdata: Array<CompareResult>,\n\tredThreshold: number,\n): string {\n\tconst rows = data\n\t\t.map((d) => {\n\t\t\treturn `${d.metafile} | ${d.outfile} | ${renderSize(d)} | ${renderNote(\n\t\t\t\td,\n\t\t\t\tredThreshold,\n\t\t\t)}\\n`;\n\t\t})\n\t\t.join(\"\");\n\n\treturn `\nMeta File | Out File  | Size (raw) | Note \n----------|----------|-----------:|------\n${rows}`;\n}\n\n/**\n * Find the top ten largest nodes in root tree.\n * Dig nodes until the depth of 3.\n */\nfunction findLargeDirectories(root: TreeMapNode) {\n\tconst nodes: TreeMapNode[] = [];\n\tconst queue: Array<{ node: TreeMapNode; depth: number }> = [\n\t\t{ node: root, depth: 0 },\n\t];\n\twhile (queue.length > 0) {\n\t\tconst shift = queue.shift();\n\t\tif (!shift) {\n\t\t\tbreak;\n\t\t}\n\t\tconst { node, depth } = shift;\n\t\tif (depth === 3) {\n\t\t\tnodes.push(node);\n\t\t\tcontinue;\n\t\t}\n\t\tif (node.children.length === 0) {\n\t\t\tnodes.push(node);\n\t\t} else {\n\t\t\tfor (const item of node.children) {\n\t\t\t\tqueue.push({ node: item, depth: depth + 1 });\n\t\t\t}\n\t\t}\n\t}\n\tconst largeNodes = nodes.sort((a, b) => b.value - a.value).slice(0, 10);\n\treturn {\n\t\tlargeNodes,\n\t\thasOther: nodes.length > 10,\n\t};\n}\n\nfunction fixedPercent(n: number, d: number): number {\n\treturn Number.parseFloat(((n / d) * 100).toFixed(1));\n}\n\nfunction fileSizeTable(data: Array<CompareResult>): string {\n\tif (data.length === 0) {\n\t\treturn \"\";\n\t}\n\tlet output = \"\";\n\toutput += \"<details>\\n\";\n\toutput += \"<summary>Top ten largest paths</summary>\\n\";\n\tfor (const d of data) {\n\t\toutput += \"\\n\";\n\t\toutput += `## Meta file: ${d.metafile}, Out file: ${d.outfile}\\n`;\n\t\tif (!d.tree) {\n\t\t\toutput += \"\uFE0F\uFE0F\uD83D\uDDD1\uFE0FDeleted\\n\";\n\t\t\tcontinue;\n\t\t}\n\t\toutput += \"| Path | Size |\\n\";\n\t\toutput += \"|------|-------|\\n\";\n\t\tconst totalSize = d.tree.value;\n\t\tconst { largeNodes, hasOther } = findLargeDirectories(d.tree);\n\t\tfor (const { path, value } of largeNodes) {\n\t\t\tconst percent = fixedPercent(value, totalSize);\n\t\t\toutput += `| ${path} | ${renderBar(percent, value)} |\\n`;\n\t\t}\n\t\tif (hasOther) {\n\t\t\tconst otherSize = totalSize - largeNodes[0].value;\n\t\t\tconst otherPercent = fixedPercent(otherSize, totalSize);\n\t\t\toutput += `| (other) | ${renderBar(otherPercent, otherSize)} |\\n`;\n\t\t}\n\t}\n\toutput += \"</details>\\n\";\n\treturn output;\n}\n\nfunction renderBar(percent: number, bytes: number): string {\n\tconst bar = progress(percent / 100);\n\treturn `\\${{\\\\color{Goldenrod}{ ${bar} }}}\\$ ${percent.toFixed(\n\t\t1,\n\t)}%, ${filesize(bytes)}`;\n}\n\n// Block progression is 1/8 = 0.125\nconst blocks = [\"\", \"\u258F\", \"\u258E\", \"\u258D\", \"\u258C\", \"\u258B\", \"\u258A\", \"\u2589\", \"\u2588\"];\nconst progression = 1 / (blocks.length - 1);\nfunction progress(value: number, length = 25, vmin = 0.0, vmax = 1.0) {\n\tconst v = value * length;\n\tconst integerPart = Math.floor(v);\n\tconst fractionalPart = v - integerPart;\n\tconst i = Math.round(\n\t\t(progression * Math.floor(fractionalPart / progression)) / progression,\n\t);\n\treturn \"\u2588\".repeat(integerPart) + blocks[i];\n}\n\nfunction renderSize(d: CompareResult): string {\n\treturn filesize(d.bytes);\n}\n\nfunction renderNote(d: CompareResult, redThreshold: number): string {\n\tif (d.remark === \"deleted\") {\n\t\treturn \"\uD83D\uDDD1\uFE0F Deleted\";\n\t}\n\tif (d.remark === \"added\") {\n\t\treturn \"\uD83C\uDD95 Added\";\n\t}\n\tif (d.diff) {\n\t\tconst percentChange = (d.diff / d.bytes) * 100;\n\t\treturn `${renderStatusIndicator(percentChange, redThreshold)}${filesize(\n\t\t\td.diff,\n\t\t)} (${sign(percentChange)}${percentChange.toFixed(1)}%)`;\n\t}\n\treturn \"\u2705  No change\";\n}\n\nfunction sign(num: number): string {\n\treturn num < 0 ? \"\" : \"+\";\n}\n\nfunction renderStatusIndicator(\n\tpercentChange: number,\n\tredThreshold: number,\n): string {\n\tlet res: string;\n\tif (percentChange > 0 && percentChange < redThreshold) {\n\t\tres = \"\u26A0\uFE0F\";\n\t} else if (percentChange >= redThreshold) {\n\t\tres = \"\u203C\uFE0F\";\n\t} else {\n\t\tres = \"\u2705 \";\n\t}\n\treturn `${res} ${sign(percentChange)}`;\n}\n", "import fs from \"node:fs\";\n\nimport type { Metafile } from \"esbuild\";\nimport type { Report } from \"./types\";\n\nfunction loadJsonFile(path: string) {\n\treturn JSON.parse(fs.readFileSync(path).toString(\"utf-8\"));\n}\n\nexport function loadMetaFile(path: string): Metafile {\n\treturn loadJsonFile(path) as Metafile;\n}\n\nexport function loadAnalysisJson(path: string): Report {\n\treturn loadJsonFile(path) as Report;\n}\n\n// https://github.com/actions/toolkit/blob/81a73aba8bedd532f6eddcc41ed3a0fad8b1cfeb/packages/core/src/core.ts#L126\nexport function getInput(name: string): string {\n\tconst val = process.env[`INPUT_${name.toUpperCase()}`] || \"\";\n\treturn val.trim();\n}\n", "import fs from \"node:fs\";\nimport path from \"node:path\";\nimport process from \"node:process\";\n\nimport type { Options, Report } from \"./types\";\nimport { loadMetaFile } from \"./utils\";\n\nexport function report(input: Options): void {\n\tconst allPageSizes = getAllPageSizes(input);\n\tfs.mkdirSync(path.join(process.cwd(), input.analyzerDirectory), {\n\t\trecursive: true,\n\t});\n\tconst resultJsonPath = path.join(\n\t\tprocess.cwd(),\n\t\tinput.analyzerDirectory,\n\t\t\"bundle_analysis.json\",\n\t);\n\tfs.writeFileSync(resultJsonPath, JSON.stringify(allPageSizes, null, 2));\n\tconsole.log(`Wrote ${resultJsonPath}`);\n}\n\nfunction getAllPageSizes(input: Options): Report {\n\tconst acc: Report = {};\n\treturn input.metafiles.reduce((acc, metafile) => {\n\t\tconst metaFilePath = path.join(process.cwd(), metafile);\n\t\ttry {\n\t\t\tfs.accessSync(metaFilePath, fs.constants.R_OK);\n\t\t} catch (err) {\n\t\t\tconsole.error(\n\t\t\t\t`No meta file found at \"${metaFilePath}\" - a path to meta file may be wrong, or esbuild is not executed.`,\n\t\t\t);\n\t\t\tprocess.exit(1);\n\t\t}\n\n\t\tconst metaFileJson = loadMetaFile(metaFilePath);\n\t\tObject.entries(metaFileJson.outputs).reduce((acc, output) => {\n\t\t\tconst [outfile, buildMeta] = output;\n\t\t\tif (\n\t\t\t\t!input.includeExtensions.some((ext) =>\n\t\t\t\t\toutfile.toLowerCase().endsWith(ext),\n\t\t\t\t)\n\t\t\t) {\n\t\t\t\treturn acc;\n\t\t\t}\n\t\t\tacc[`${metafile} -> ${outfile}`] = {\n\t\t\t\tbytes: buildMeta.bytes,\n\t\t\t\tmetafile,\n\t\t\t\toutfile,\n\t\t\t};\n\t\t\treturn acc;\n\t\t}, acc);\n\t\treturn acc;\n\t}, acc);\n}\n"],
  "mappings": "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",
  "names": ["fs", "path", "child", "fs", "filesize", "path", "fs", "path", "process", "fs", "path", "process", "acc"]
}
 diff --git a/src/compare.ts b/src/compare.ts index 2f94738..675bb46 100644 --- a/src/compare.ts +++ b/src/compare.ts @@ -1,8 +1,44 @@ import fs from "node:fs"; import path from "node:path"; import { filesize as originalFilesize } from "filesize"; -import type { CompareResult, Options, Report } from "./types"; -import { loadAnalysisJson } from "./utils"; +import type { CompareResult, Options, Report, TreeMapNode } from "./types"; +import { loadAnalysisJson, loadMetaFile } from "./utils"; + +function buildTree( + input: Record, +): TreeMapNode { + const root: TreeMapNode = { name: "", path: "", value: 0, children: [] }; + for (const [filePath, { bytesInOutput }] of Object.entries(input)) { + const directories = filePath.split("/"); + buildNode(root, directories, bytesInOutput); + } + return root; +} + +function buildNode( + node: TreeMapNode, + paths: Array, + value: number, +): void { + const first = paths.shift(); + if (first === undefined) { + // leaf node (file) + node.value += value; + return; + } + let child = node.children.find((child) => child.name === first); + if (!child) { + child = { + name: first, + path: `${node.path}/${first}`.replace(/^\//, ""), + value: 0, + children: [], + }; + node.children.push(child); + } + node.value += value; + buildNode(child, paths, value); +} export function compare(input: Options): void { let hasAnyChange = false; @@ -27,9 +63,24 @@ This analysis was generated by [esbuild-bundle-analyzer](https://github.com/exoe base = {}; } + const trees = new Map(); + for (const metafileRelPath of input.metafiles) { + const metafile = loadMetaFile(path.join(process.cwd(), metafileRelPath)); + for (const [outfile, buildMeta] of Object.entries(metafile.outputs)) { + const tree = buildTree(buildMeta.inputs); + trees.set(`${metafileRelPath} -> ${outfile}`, tree); + + fs.writeFileSync( + path.join(process.cwd(), input.analyzerDirectory, "tree.json"), + JSON.stringify(tree, null, 2), + ); + } + } + const allOutFiles: string[] = [ ...new Set([...Object.keys(current), ...Object.keys(base)]), ].sort(); + const comparison: Array = allOutFiles.map((outfile) => { const currentStats = current[outfile]; const baseStats = base[outfile]; @@ -37,12 +88,17 @@ This analysis was generated by [esbuild-bundle-analyzer](https://github.com/exoe if (!currentStats) { hasAnyChange = true; // deleted out file - return { ...baseStats, diff: -1, remark: "deleted" }; + return { ...baseStats, diff: -1, remark: "deleted", tree: undefined }; } + + const tree = trees.get( + `${currentStats.metafile} -> ${currentStats.outfile}`, + ); + if (!baseStats) { hasAnyChange = true; // new out file - return { ...currentStats, diff: -1, remark: "added" }; + return { ...currentStats, diff: -1, remark: "added", tree }; } const diff = currentStats.bytes - baseStats.bytes; const increase = !!Math.sign(diff); @@ -52,12 +108,14 @@ This analysis was generated by [esbuild-bundle-analyzer](https://github.com/exoe return { ...currentStats, diff, + tree, remark: increase ? "increased" : "decreased", }; }); if (hasAnyChange) { output += markdownTable(comparison, input.percentExtraAttention); + output += fileSizeTable(comparison); if (input.showDetails) { output += `\n
@@ -80,14 +138,6 @@ This analysis was generated by [esbuild-bundle-analyzer](https://github.com/exoe // consistently find the right comment to edit as more commits are pushed. output += ``; - // Log mostly for testing and debugging. - // This will show up in the github actions console. - console.dir({ - input, - hasAnyChange, - output, - }); - // Write the output to a file which is later read in // as comment contents by the actions workflow. fs.mkdirSync(path.join(process.cwd(), input.analyzerDirectory), { @@ -128,6 +178,96 @@ Meta File | Out File | Size (raw) | Note ${rows}`; } +/** + * Find the top ten largest nodes in root tree. + * Dig nodes until the depth of 3. + */ +function findLargeDirectories(root: TreeMapNode) { + const nodes: TreeMapNode[] = []; + const queue: Array<{ node: TreeMapNode; depth: number }> = [ + { node: root, depth: 0 }, + ]; + while (queue.length > 0) { + const shift = queue.shift(); + if (!shift) { + break; + } + const { node, depth } = shift; + if (depth === 3) { + nodes.push(node); + continue; + } + if (node.children.length === 0) { + nodes.push(node); + } else { + for (const item of node.children) { + queue.push({ node: item, depth: depth + 1 }); + } + } + } + const largeNodes = nodes.sort((a, b) => b.value - a.value).slice(0, 10); + return { + largeNodes, + hasOther: nodes.length > 10, + }; +} + +function fixedPercent(n: number, d: number): number { + return Number.parseFloat(((n / d) * 100).toFixed(1)); +} + +function fileSizeTable(data: Array): string { + if (data.length === 0) { + return ""; + } + let output = ""; + output += "
\n"; + output += "Top ten largest paths\n"; + for (const d of data) { + output += "\n"; + output += `## Meta file: ${d.metafile}, Out file: ${d.outfile}\n`; + if (!d.tree) { + output += "οΈοΈπŸ—‘οΈDeleted\n"; + continue; + } + output += "| Path | Size |\n"; + output += "|------|-------|\n"; + const totalSize = d.tree.value; + const { largeNodes, hasOther } = findLargeDirectories(d.tree); + for (const { path, value } of largeNodes) { + const percent = fixedPercent(value, totalSize); + output += `| ${path} | ${renderBar(percent, value)} |\n`; + } + if (hasOther) { + const otherSize = totalSize - largeNodes[0].value; + const otherPercent = fixedPercent(otherSize, totalSize); + output += `| (other) | ${renderBar(otherPercent, otherSize)} |\n`; + } + } + output += "
\n"; + return output; +} + +function renderBar(percent: number, bytes: number): string { + const bar = progress(percent / 100); + return `\${{\\color{Goldenrod}{ ${bar} }}}\$ ${percent.toFixed( + 1, + )}%, ${filesize(bytes)}`; +} + +// Block progression is 1/8 = 0.125 +const blocks = ["", "▏", "β–Ž", "▍", "β–Œ", "β–‹", "β–Š", "β–‰", "β–ˆ"]; +const progression = 1 / (blocks.length - 1); +function progress(value: number, length = 25, vmin = 0.0, vmax = 1.0) { + const v = value * length; + const integerPart = Math.floor(v); + const fractionalPart = v - integerPart; + const i = Math.round( + (progression * Math.floor(fractionalPart / progression)) / progression, + ); + return "β–ˆ".repeat(integerPart) + blocks[i]; +} + function renderSize(d: CompareResult): string { return filesize(d.bytes); } diff --git a/src/types.ts b/src/types.ts index 9646c2d..ff84763 100644 --- a/src/types.ts +++ b/src/types.ts @@ -11,6 +11,7 @@ export interface CompareResult { bytes: number; diff: number; remark: "added" | "deleted" | "increased" | "decreased"; + tree: TreeMapNode | undefined; } export interface Options { @@ -21,3 +22,11 @@ export interface Options { percentExtraAttention: number; showDetails: boolean; } + +export interface TreeMapNode { + value: number; + name: string; + color?: Array; + path: string; + children: TreeMapNode[]; +} From 0111f527c0460d430be53f66ff10cf4e1e9b53e2 Mon Sep 17 00:00:00 2001 From: exoego Date: Mon, 6 May 2024 22:32:24 +0900 Subject: [PATCH 2/4] Check with tsc --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 2590a1c..92c605a 100644 --- a/package.json +++ b/package.json @@ -7,7 +7,7 @@ "test": "vitest", "test:run": "vitest --run", "build": "npm run check && node esbuild.mjs", - "check": "biome check --apply ." + "check": "tsc && biome check --apply ." }, "repository": { "type": "git", From d0a608b98158a394e868c3d35cfd805d00d39561 Mon Sep 17 00:00:00 2001 From: exoego Date: Mon, 6 May 2024 20:15:40 +0900 Subject: [PATCH 3/4] Make source bigger than dependency --- .../examples/basic/package-lock.json | 1487 +---------------- .../__fixtures__/examples/basic/package.json | 2 +- .../__fixtures__/examples/basic/src/index.ts | 201 ++- 3 files changed, 198 insertions(+), 1492 deletions(-) diff --git a/__tests__/__fixtures__/examples/basic/package-lock.json b/__tests__/__fixtures__/examples/basic/package-lock.json index b9c5db7..0206063 100644 --- a/__tests__/__fixtures__/examples/basic/package-lock.json +++ b/__tests__/__fixtures__/examples/basic/package-lock.json @@ -8,810 +8,13 @@ "name": "esbuild-bundle-analysis-test-fixture", "version": "1.0.0", "dependencies": { - "@aws-sdk/client-s3": "^3.556.0" + "rambda": "^9.2.0" }, "devDependencies": { "esbuild": "^0.20.2", "typescript": "^5.4.5" } }, - "node_modules/@aws-crypto/crc32": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@aws-crypto/crc32/-/crc32-3.0.0.tgz", - "integrity": "sha512-IzSgsrxUcsrejQbPVilIKy16kAT52EwB6zSaI+M3xxIhKh5+aldEyvI+z6erM7TCLB2BJsFrtHjp6/4/sr+3dA==", - "dependencies": { - "@aws-crypto/util": "^3.0.0", - "@aws-sdk/types": "^3.222.0", - "tslib": "^1.11.1" - } - }, - "node_modules/@aws-crypto/crc32/node_modules/tslib": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", - "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==" - }, - "node_modules/@aws-crypto/crc32c": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@aws-crypto/crc32c/-/crc32c-3.0.0.tgz", - "integrity": "sha512-ENNPPManmnVJ4BTXlOjAgD7URidbAznURqD0KvfREyc4o20DPYdEldU1f5cQ7Jbj0CJJSPaMIk/9ZshdB3210w==", - "dependencies": { - "@aws-crypto/util": "^3.0.0", - "@aws-sdk/types": "^3.222.0", - "tslib": "^1.11.1" - } - }, - "node_modules/@aws-crypto/crc32c/node_modules/tslib": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", - "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==" - }, - "node_modules/@aws-crypto/ie11-detection": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@aws-crypto/ie11-detection/-/ie11-detection-3.0.0.tgz", - "integrity": "sha512-341lBBkiY1DfDNKai/wXM3aujNBkXR7tq1URPQDL9wi3AUbI80NR74uF1TXHMm7po1AcnFk8iu2S2IeU/+/A+Q==", - "dependencies": { - "tslib": "^1.11.1" - } - }, - "node_modules/@aws-crypto/ie11-detection/node_modules/tslib": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", - "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==" - }, - "node_modules/@aws-crypto/sha1-browser": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@aws-crypto/sha1-browser/-/sha1-browser-3.0.0.tgz", - "integrity": "sha512-NJth5c997GLHs6nOYTzFKTbYdMNA6/1XlKVgnZoaZcQ7z7UJlOgj2JdbHE8tiYLS3fzXNCguct77SPGat2raSw==", - "dependencies": { - "@aws-crypto/ie11-detection": "^3.0.0", - "@aws-crypto/supports-web-crypto": "^3.0.0", - "@aws-crypto/util": "^3.0.0", - "@aws-sdk/types": "^3.222.0", - "@aws-sdk/util-locate-window": "^3.0.0", - "@aws-sdk/util-utf8-browser": "^3.0.0", - "tslib": "^1.11.1" - } - }, - "node_modules/@aws-crypto/sha1-browser/node_modules/tslib": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", - "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==" - }, - "node_modules/@aws-crypto/sha256-browser": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@aws-crypto/sha256-browser/-/sha256-browser-3.0.0.tgz", - "integrity": "sha512-8VLmW2B+gjFbU5uMeqtQM6Nj0/F1bro80xQXCW6CQBWgosFWXTx77aeOF5CAIAmbOK64SdMBJdNr6J41yP5mvQ==", - "dependencies": { - "@aws-crypto/ie11-detection": "^3.0.0", - "@aws-crypto/sha256-js": "^3.0.0", - "@aws-crypto/supports-web-crypto": "^3.0.0", - "@aws-crypto/util": "^3.0.0", - "@aws-sdk/types": "^3.222.0", - "@aws-sdk/util-locate-window": "^3.0.0", - "@aws-sdk/util-utf8-browser": "^3.0.0", - "tslib": "^1.11.1" - } - }, - "node_modules/@aws-crypto/sha256-browser/node_modules/tslib": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", - "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==" - }, - "node_modules/@aws-crypto/sha256-js": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@aws-crypto/sha256-js/-/sha256-js-3.0.0.tgz", - "integrity": "sha512-PnNN7os0+yd1XvXAy23CFOmTbMaDxgxXtTKHybrJ39Y8kGzBATgBFibWJKH6BhytLI/Zyszs87xCOBNyBig6vQ==", - "dependencies": { - "@aws-crypto/util": "^3.0.0", - "@aws-sdk/types": "^3.222.0", - "tslib": "^1.11.1" - } - }, - "node_modules/@aws-crypto/sha256-js/node_modules/tslib": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", - "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==" - }, - "node_modules/@aws-crypto/supports-web-crypto": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@aws-crypto/supports-web-crypto/-/supports-web-crypto-3.0.0.tgz", - "integrity": "sha512-06hBdMwUAb2WFTuGG73LSC0wfPu93xWwo5vL2et9eymgmu3Id5vFAHBbajVWiGhPO37qcsdCap/FqXvJGJWPIg==", - "dependencies": { - "tslib": "^1.11.1" - } - }, - "node_modules/@aws-crypto/supports-web-crypto/node_modules/tslib": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", - "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==" - }, - "node_modules/@aws-crypto/util": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@aws-crypto/util/-/util-3.0.0.tgz", - "integrity": "sha512-2OJlpeJpCR48CC8r+uKVChzs9Iungj9wkZrl8Z041DWEWvyIHILYKCPNzJghKsivj+S3mLo6BVc7mBNzdxA46w==", - "dependencies": { - "@aws-sdk/types": "^3.222.0", - "@aws-sdk/util-utf8-browser": "^3.0.0", - "tslib": "^1.11.1" - } - }, - "node_modules/@aws-crypto/util/node_modules/tslib": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", - "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==" - }, - "node_modules/@aws-sdk/client-s3": { - "version": "3.564.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/client-s3/-/client-s3-3.564.0.tgz", - "integrity": "sha512-QvTjjQWC7LB18X7BRvYK6Rc1oK1nToht4KOBR+zXmz4R1TEtMpyC9xgZzzVzp2aocXV1/WuDlg8Mvssx8UmUuQ==", - "dependencies": { - "@aws-crypto/sha1-browser": "3.0.0", - "@aws-crypto/sha256-browser": "3.0.0", - "@aws-crypto/sha256-js": "3.0.0", - "@aws-sdk/core": "3.556.0", - "@aws-sdk/credential-provider-node": "3.564.0", - "@aws-sdk/middleware-bucket-endpoint": "3.535.0", - "@aws-sdk/middleware-expect-continue": "3.535.0", - "@aws-sdk/middleware-flexible-checksums": "3.535.0", - "@aws-sdk/middleware-host-header": "3.535.0", - "@aws-sdk/middleware-location-constraint": "3.535.0", - "@aws-sdk/middleware-logger": "3.535.0", - "@aws-sdk/middleware-recursion-detection": "3.535.0", - "@aws-sdk/middleware-sdk-s3": "3.556.0", - "@aws-sdk/middleware-signing": "3.556.0", - "@aws-sdk/middleware-ssec": "3.537.0", - "@aws-sdk/middleware-user-agent": "3.540.0", - "@aws-sdk/region-config-resolver": "3.535.0", - "@aws-sdk/signature-v4-multi-region": "3.556.0", - "@aws-sdk/types": "3.535.0", - "@aws-sdk/util-endpoints": "3.540.0", - "@aws-sdk/util-user-agent-browser": "3.535.0", - "@aws-sdk/util-user-agent-node": "3.535.0", - "@aws-sdk/xml-builder": "3.535.0", - "@smithy/config-resolver": "^2.2.0", - "@smithy/core": "^1.4.2", - "@smithy/eventstream-serde-browser": "^2.2.0", - "@smithy/eventstream-serde-config-resolver": "^2.2.0", - "@smithy/eventstream-serde-node": "^2.2.0", - "@smithy/fetch-http-handler": "^2.5.0", - "@smithy/hash-blob-browser": "^2.2.0", - "@smithy/hash-node": "^2.2.0", - "@smithy/hash-stream-node": "^2.2.0", - "@smithy/invalid-dependency": "^2.2.0", - "@smithy/md5-js": "^2.2.0", - "@smithy/middleware-content-length": "^2.2.0", - "@smithy/middleware-endpoint": "^2.5.1", - "@smithy/middleware-retry": "^2.3.1", - "@smithy/middleware-serde": "^2.3.0", - "@smithy/middleware-stack": "^2.2.0", - "@smithy/node-config-provider": "^2.3.0", - "@smithy/node-http-handler": "^2.5.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/smithy-client": "^2.5.1", - "@smithy/types": "^2.12.0", - "@smithy/url-parser": "^2.2.0", - "@smithy/util-base64": "^2.3.0", - "@smithy/util-body-length-browser": "^2.2.0", - "@smithy/util-body-length-node": "^2.3.0", - "@smithy/util-defaults-mode-browser": "^2.2.1", - "@smithy/util-defaults-mode-node": "^2.3.1", - "@smithy/util-endpoints": "^1.2.0", - "@smithy/util-retry": "^2.2.0", - "@smithy/util-stream": "^2.2.0", - "@smithy/util-utf8": "^2.3.0", - "@smithy/util-waiter": "^2.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/client-sso": { - "version": "3.556.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/client-sso/-/client-sso-3.556.0.tgz", - "integrity": "sha512-unXdWS7uvHqCcOyC1de+Fr8m3F2vMg2m24GPea0bg7rVGTYmiyn9mhUX11VCt+ozydrw+F50FQwL6OqoqPocmw==", - "dependencies": { - "@aws-crypto/sha256-browser": "3.0.0", - "@aws-crypto/sha256-js": "3.0.0", - "@aws-sdk/core": "3.556.0", - "@aws-sdk/middleware-host-header": "3.535.0", - "@aws-sdk/middleware-logger": "3.535.0", - "@aws-sdk/middleware-recursion-detection": "3.535.0", - "@aws-sdk/middleware-user-agent": "3.540.0", - "@aws-sdk/region-config-resolver": "3.535.0", - "@aws-sdk/types": "3.535.0", - "@aws-sdk/util-endpoints": "3.540.0", - "@aws-sdk/util-user-agent-browser": "3.535.0", - "@aws-sdk/util-user-agent-node": "3.535.0", - "@smithy/config-resolver": "^2.2.0", - "@smithy/core": "^1.4.2", - "@smithy/fetch-http-handler": "^2.5.0", - "@smithy/hash-node": "^2.2.0", - "@smithy/invalid-dependency": "^2.2.0", - "@smithy/middleware-content-length": "^2.2.0", - "@smithy/middleware-endpoint": "^2.5.1", - "@smithy/middleware-retry": "^2.3.1", - "@smithy/middleware-serde": "^2.3.0", - "@smithy/middleware-stack": "^2.2.0", - "@smithy/node-config-provider": "^2.3.0", - "@smithy/node-http-handler": "^2.5.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/smithy-client": "^2.5.1", - "@smithy/types": "^2.12.0", - "@smithy/url-parser": "^2.2.0", - "@smithy/util-base64": "^2.3.0", - "@smithy/util-body-length-browser": "^2.2.0", - "@smithy/util-body-length-node": "^2.3.0", - "@smithy/util-defaults-mode-browser": "^2.2.1", - "@smithy/util-defaults-mode-node": "^2.3.1", - "@smithy/util-endpoints": "^1.2.0", - "@smithy/util-middleware": "^2.2.0", - "@smithy/util-retry": "^2.2.0", - "@smithy/util-utf8": "^2.3.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/client-sso-oidc": { - "version": "3.564.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/client-sso-oidc/-/client-sso-oidc-3.564.0.tgz", - "integrity": "sha512-LWBXiwA0qlGhpJx3fbFQagVEyVPoecGtJh3+5hoc+CTVnT00J7T0jLe3kgemvEI9kjhIyDW+MFkq1jCttrGNJw==", - "dependencies": { - "@aws-crypto/sha256-browser": "3.0.0", - "@aws-crypto/sha256-js": "3.0.0", - "@aws-sdk/core": "3.556.0", - "@aws-sdk/middleware-host-header": "3.535.0", - "@aws-sdk/middleware-logger": "3.535.0", - "@aws-sdk/middleware-recursion-detection": "3.535.0", - "@aws-sdk/middleware-user-agent": "3.540.0", - "@aws-sdk/region-config-resolver": "3.535.0", - "@aws-sdk/types": "3.535.0", - "@aws-sdk/util-endpoints": "3.540.0", - "@aws-sdk/util-user-agent-browser": "3.535.0", - "@aws-sdk/util-user-agent-node": "3.535.0", - "@smithy/config-resolver": "^2.2.0", - "@smithy/core": "^1.4.2", - "@smithy/fetch-http-handler": "^2.5.0", - "@smithy/hash-node": "^2.2.0", - "@smithy/invalid-dependency": "^2.2.0", - "@smithy/middleware-content-length": "^2.2.0", - "@smithy/middleware-endpoint": "^2.5.1", - "@smithy/middleware-retry": "^2.3.1", - "@smithy/middleware-serde": "^2.3.0", - "@smithy/middleware-stack": "^2.2.0", - "@smithy/node-config-provider": "^2.3.0", - "@smithy/node-http-handler": "^2.5.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/smithy-client": "^2.5.1", - "@smithy/types": "^2.12.0", - "@smithy/url-parser": "^2.2.0", - "@smithy/util-base64": "^2.3.0", - "@smithy/util-body-length-browser": "^2.2.0", - "@smithy/util-body-length-node": "^2.3.0", - "@smithy/util-defaults-mode-browser": "^2.2.1", - "@smithy/util-defaults-mode-node": "^2.3.1", - "@smithy/util-endpoints": "^1.2.0", - "@smithy/util-middleware": "^2.2.0", - "@smithy/util-retry": "^2.2.0", - "@smithy/util-utf8": "^2.3.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - }, - "peerDependencies": { - "@aws-sdk/credential-provider-node": "^3.564.0" - } - }, - "node_modules/@aws-sdk/client-sts": { - "version": "3.556.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/client-sts/-/client-sts-3.556.0.tgz", - "integrity": "sha512-TsK3js7Suh9xEmC886aY+bv0KdLLYtzrcmVt6sJ/W6EnDXYQhBuKYFhp03NrN2+vSvMGpqJwR62DyfKe1G0QzQ==", - "dependencies": { - "@aws-crypto/sha256-browser": "3.0.0", - "@aws-crypto/sha256-js": "3.0.0", - "@aws-sdk/core": "3.556.0", - "@aws-sdk/middleware-host-header": "3.535.0", - "@aws-sdk/middleware-logger": "3.535.0", - "@aws-sdk/middleware-recursion-detection": "3.535.0", - "@aws-sdk/middleware-user-agent": "3.540.0", - "@aws-sdk/region-config-resolver": "3.535.0", - "@aws-sdk/types": "3.535.0", - "@aws-sdk/util-endpoints": "3.540.0", - "@aws-sdk/util-user-agent-browser": "3.535.0", - "@aws-sdk/util-user-agent-node": "3.535.0", - "@smithy/config-resolver": "^2.2.0", - "@smithy/core": "^1.4.2", - "@smithy/fetch-http-handler": "^2.5.0", - "@smithy/hash-node": "^2.2.0", - "@smithy/invalid-dependency": "^2.2.0", - "@smithy/middleware-content-length": "^2.2.0", - "@smithy/middleware-endpoint": "^2.5.1", - "@smithy/middleware-retry": "^2.3.1", - "@smithy/middleware-serde": "^2.3.0", - "@smithy/middleware-stack": "^2.2.0", - "@smithy/node-config-provider": "^2.3.0", - "@smithy/node-http-handler": "^2.5.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/smithy-client": "^2.5.1", - "@smithy/types": "^2.12.0", - "@smithy/url-parser": "^2.2.0", - "@smithy/util-base64": "^2.3.0", - "@smithy/util-body-length-browser": "^2.2.0", - "@smithy/util-body-length-node": "^2.3.0", - "@smithy/util-defaults-mode-browser": "^2.2.1", - "@smithy/util-defaults-mode-node": "^2.3.1", - "@smithy/util-endpoints": "^1.2.0", - "@smithy/util-middleware": "^2.2.0", - "@smithy/util-retry": "^2.2.0", - "@smithy/util-utf8": "^2.3.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - }, - "peerDependencies": { - "@aws-sdk/credential-provider-node": "^3.556.0" - } - }, - "node_modules/@aws-sdk/core": { - "version": "3.556.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/core/-/core-3.556.0.tgz", - "integrity": "sha512-vJaSaHw2kPQlo11j/Rzuz0gk1tEaKdz+2ser0f0qZ5vwFlANjt08m/frU17ctnVKC1s58bxpctO/1P894fHLrA==", - "dependencies": { - "@smithy/core": "^1.4.2", - "@smithy/protocol-http": "^3.3.0", - "@smithy/signature-v4": "^2.3.0", - "@smithy/smithy-client": "^2.5.1", - "@smithy/types": "^2.12.0", - "fast-xml-parser": "4.2.5", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/credential-provider-env": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/credential-provider-env/-/credential-provider-env-3.535.0.tgz", - "integrity": "sha512-XppwO8c0GCGSAvdzyJOhbtktSEaShg14VJKg8mpMa1XcgqzmcqqHQjtDWbx5rZheY1VdpXZhpEzJkB6LpQejpA==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/property-provider": "^2.2.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/credential-provider-http": { - "version": "3.552.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/credential-provider-http/-/credential-provider-http-3.552.0.tgz", - "integrity": "sha512-vsmu7Cz1i45pFEqzVb4JcFmAmVnWFNLsGheZc8SCptlqCO5voETrZZILHYIl4cjKkSDk3pblBOf0PhyjqWW6WQ==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/fetch-http-handler": "^2.5.0", - "@smithy/node-http-handler": "^2.5.0", - "@smithy/property-provider": "^2.2.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/smithy-client": "^2.5.1", - "@smithy/types": "^2.12.0", - "@smithy/util-stream": "^2.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/credential-provider-ini": { - "version": "3.564.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/credential-provider-ini/-/credential-provider-ini-3.564.0.tgz", - "integrity": "sha512-kiEfBoKRcbX7I/rjhVGJrTUQ0895ANhPu6KE1GRZW7wc1gIGgKGJ+0tvAqRtQjYX0U9pivEDb0dh16OF9PBFFw==", - "dependencies": { - "@aws-sdk/client-sts": "3.556.0", - "@aws-sdk/credential-provider-env": "3.535.0", - "@aws-sdk/credential-provider-process": "3.535.0", - "@aws-sdk/credential-provider-sso": "3.564.0", - "@aws-sdk/credential-provider-web-identity": "3.556.0", - "@aws-sdk/types": "3.535.0", - "@smithy/credential-provider-imds": "^2.3.0", - "@smithy/property-provider": "^2.2.0", - "@smithy/shared-ini-file-loader": "^2.4.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/credential-provider-node": { - "version": "3.564.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/credential-provider-node/-/credential-provider-node-3.564.0.tgz", - "integrity": "sha512-HXD5ZCXzfcd6cJ/pW8frh8DuYlKaCd/JKmwzuCRUxgxZwbLEeNmyRYvF+D7osETJJZ4VIwgVbpEw1yLqRz1onw==", - "dependencies": { - "@aws-sdk/credential-provider-env": "3.535.0", - "@aws-sdk/credential-provider-http": "3.552.0", - "@aws-sdk/credential-provider-ini": "3.564.0", - "@aws-sdk/credential-provider-process": "3.535.0", - "@aws-sdk/credential-provider-sso": "3.564.0", - "@aws-sdk/credential-provider-web-identity": "3.556.0", - "@aws-sdk/types": "3.535.0", - "@smithy/credential-provider-imds": "^2.3.0", - "@smithy/property-provider": "^2.2.0", - "@smithy/shared-ini-file-loader": "^2.4.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/credential-provider-process": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/credential-provider-process/-/credential-provider-process-3.535.0.tgz", - "integrity": "sha512-9O1OaprGCnlb/kYl8RwmH7Mlg8JREZctB8r9sa1KhSsWFq/SWO0AuJTyowxD7zL5PkeS4eTvzFFHWCa3OO5epA==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/property-provider": "^2.2.0", - "@smithy/shared-ini-file-loader": "^2.4.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/credential-provider-sso": { - "version": "3.564.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/credential-provider-sso/-/credential-provider-sso-3.564.0.tgz", - "integrity": "sha512-Wv0NV8tDwtydEpsp/kVZ22Z+40bsSBDYgYZ1Uxx+KR8a1PvT6B5FnEtccWTJ371sQG/uqLum7dXSbJq1Qqze1w==", - "dependencies": { - "@aws-sdk/client-sso": "3.556.0", - "@aws-sdk/token-providers": "3.564.0", - "@aws-sdk/types": "3.535.0", - "@smithy/property-provider": "^2.2.0", - "@smithy/shared-ini-file-loader": "^2.4.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/credential-provider-web-identity": { - "version": "3.556.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/credential-provider-web-identity/-/credential-provider-web-identity-3.556.0.tgz", - "integrity": "sha512-R/YAL8Uh8i+dzVjzMnbcWLIGeeRi2mioHVGnVF+minmaIkCiQMZg2HPrdlKm49El+RljT28Nl5YHRuiqzEIwMA==", - "dependencies": { - "@aws-sdk/client-sts": "3.556.0", - "@aws-sdk/types": "3.535.0", - "@smithy/property-provider": "^2.2.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/middleware-bucket-endpoint": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/middleware-bucket-endpoint/-/middleware-bucket-endpoint-3.535.0.tgz", - "integrity": "sha512-7sijlfQsc4UO9Fsl11mU26Y5f9E7g6UoNg/iJUBpC5pgvvmdBRO5UEhbB/gnqvOEPsBXyhmfzbstebq23Qdz7A==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@aws-sdk/util-arn-parser": "3.535.0", - "@smithy/node-config-provider": "^2.3.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/types": "^2.12.0", - "@smithy/util-config-provider": "^2.3.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/middleware-expect-continue": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/middleware-expect-continue/-/middleware-expect-continue-3.535.0.tgz", - "integrity": "sha512-hFKyqUBky0NWCVku8iZ9+PACehx0p6vuMw5YnZf8FVgHP0fode0b/NwQY6UY7oor/GftvRsAlRUAWGNFEGUpwA==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/middleware-flexible-checksums": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/middleware-flexible-checksums/-/middleware-flexible-checksums-3.535.0.tgz", - "integrity": "sha512-rBIzldY9jjRATxICDX7t77aW6ctqmVDgnuAOgbVT5xgHftt4o7PGWKoMvl/45hYqoQgxVFnCBof9bxkqSBebVA==", - "dependencies": { - "@aws-crypto/crc32": "3.0.0", - "@aws-crypto/crc32c": "3.0.0", - "@aws-sdk/types": "3.535.0", - "@smithy/is-array-buffer": "^2.2.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/types": "^2.12.0", - "@smithy/util-utf8": "^2.3.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/middleware-host-header": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/middleware-host-header/-/middleware-host-header-3.535.0.tgz", - "integrity": "sha512-0h6TWjBWtDaYwHMQJI9ulafeS4lLaw1vIxRjbpH0svFRt6Eve+Sy8NlVhECfTU2hNz/fLubvrUxsXoThaLBIew==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/middleware-location-constraint": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/middleware-location-constraint/-/middleware-location-constraint-3.535.0.tgz", - "integrity": "sha512-SxfS9wfidUZZ+WnlKRTCRn3h+XTsymXRXPJj8VV6hNRNeOwzNweoG3YhQbTowuuNfXf89m9v6meYkBBtkdacKw==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/middleware-logger": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/middleware-logger/-/middleware-logger-3.535.0.tgz", - "integrity": "sha512-huNHpONOrEDrdRTvSQr1cJiRMNf0S52NDXtaPzdxiubTkP+vni2MohmZANMOai/qT0olmEVX01LhZ0ZAOgmg6A==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/middleware-recursion-detection": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/middleware-recursion-detection/-/middleware-recursion-detection-3.535.0.tgz", - "integrity": "sha512-am2qgGs+gwqmR4wHLWpzlZ8PWhm4ktj5bYSgDrsOfjhdBlWNxvPoID9/pDAz5RWL48+oH7I6SQzMqxXsFDikrw==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/middleware-sdk-s3": { - "version": "3.556.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/middleware-sdk-s3/-/middleware-sdk-s3-3.556.0.tgz", - "integrity": "sha512-4W/dnxqj1B6/uS/5Z+3UHaqDDGjNPgEVlqf5d3ToOFZ31ZfpANwhcCmyX39JklC4aolCEi9renQ5wHnTCC8K8g==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@aws-sdk/util-arn-parser": "3.535.0", - "@smithy/node-config-provider": "^2.3.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/signature-v4": "^2.3.0", - "@smithy/smithy-client": "^2.5.1", - "@smithy/types": "^2.12.0", - "@smithy/util-config-provider": "^2.3.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/middleware-signing": { - "version": "3.556.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/middleware-signing/-/middleware-signing-3.556.0.tgz", - "integrity": "sha512-kWrPmU8qd3gI5qzpuW9LtWFaH80cOz1ZJDavXx6PRpYZJ5JaKdUHghwfDlVTzzFYAeJmVsWIkPcLT5d5mY5ZTQ==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/property-provider": "^2.2.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/signature-v4": "^2.3.0", - "@smithy/types": "^2.12.0", - "@smithy/util-middleware": "^2.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/middleware-ssec": { - "version": "3.537.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/middleware-ssec/-/middleware-ssec-3.537.0.tgz", - "integrity": "sha512-2QWMrbwd5eBy5KCYn9a15JEWBgrK2qFEKQN2lqb/6z0bhtevIOxIRfC99tzvRuPt6nixFQ+ynKuBjcfT4ZFrdQ==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/middleware-user-agent": { - "version": "3.540.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/middleware-user-agent/-/middleware-user-agent-3.540.0.tgz", - "integrity": "sha512-8Rd6wPeXDnOYzWj1XCmOKcx/Q87L0K1/EHqOBocGjLVbN3gmRxBvpmR1pRTjf7IsWfnnzN5btqtcAkfDPYQUMQ==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@aws-sdk/util-endpoints": "3.540.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/region-config-resolver": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/region-config-resolver/-/region-config-resolver-3.535.0.tgz", - "integrity": "sha512-IXOznDiaItBjsQy4Fil0kzX/J3HxIOknEphqHbOfUf+LpA5ugcsxuQQONrbEQusCBnfJyymrldBvBhFmtlU9Wg==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/node-config-provider": "^2.3.0", - "@smithy/types": "^2.12.0", - "@smithy/util-config-provider": "^2.3.0", - "@smithy/util-middleware": "^2.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/signature-v4-multi-region": { - "version": "3.556.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/signature-v4-multi-region/-/signature-v4-multi-region-3.556.0.tgz", - "integrity": "sha512-bWDSK0ggK7QzAOmPZGv29UAIZocL1MNY7XyOvm3P3P1U3tFMoIBilQQBLabXyHoZ9J3Ik0Vv4n95htUhRQ35ow==", - "dependencies": { - "@aws-sdk/middleware-sdk-s3": "3.556.0", - "@aws-sdk/types": "3.535.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/signature-v4": "^2.3.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/token-providers": { - "version": "3.564.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/token-providers/-/token-providers-3.564.0.tgz", - "integrity": "sha512-Kk5ixcl9HjqwzfBJZGQAtsqwKa7Z8P7Mdug837BG8zCJbhf7wwNsmItzXTiAlpVrDZyT8P1yWIxsLOS1YUtmow==", - "dependencies": { - "@aws-sdk/client-sso-oidc": "3.564.0", - "@aws-sdk/types": "3.535.0", - "@smithy/property-provider": "^2.2.0", - "@smithy/shared-ini-file-loader": "^2.4.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/types": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/types/-/types-3.535.0.tgz", - "integrity": "sha512-aY4MYfduNj+sRR37U7XxYR8wemfbKP6lx00ze2M2uubn7mZotuVrWYAafbMSXrdEMSToE5JDhr28vArSOoLcSg==", - "dependencies": { - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/util-arn-parser": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/util-arn-parser/-/util-arn-parser-3.535.0.tgz", - "integrity": "sha512-smVo29nUPAOprp8Z5Y3GHuhiOtw6c8/EtLCm5AVMtRsTPw4V414ZXL2H66tzmb5kEeSzQlbfBSBEdIFZoxO9kg==", - "dependencies": { - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/util-endpoints": { - "version": "3.540.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/util-endpoints/-/util-endpoints-3.540.0.tgz", - "integrity": "sha512-1kMyQFAWx6f8alaI6UT65/5YW/7pDWAKAdNwL6vuJLea03KrZRX3PMoONOSJpAS5m3Ot7HlWZvf3wZDNTLELZw==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/types": "^2.12.0", - "@smithy/util-endpoints": "^1.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/util-locate-window": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/util-locate-window/-/util-locate-window-3.535.0.tgz", - "integrity": "sha512-PHJ3SL6d2jpcgbqdgiPxkXpu7Drc2PYViwxSIqvvMKhDwzSB1W3mMvtpzwKM4IE7zLFodZo0GKjJ9AsoXndXhA==", - "dependencies": { - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@aws-sdk/util-user-agent-browser": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/util-user-agent-browser/-/util-user-agent-browser-3.535.0.tgz", - "integrity": "sha512-RWMcF/xV5n+nhaA/Ff5P3yNP3Kur/I+VNZngog4TEs92oB/nwOdAg/2JL8bVAhUbMrjTjpwm7PItziYFQoqyig==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/types": "^2.12.0", - "bowser": "^2.11.0", - "tslib": "^2.6.2" - } - }, - "node_modules/@aws-sdk/util-user-agent-node": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/util-user-agent-node/-/util-user-agent-node-3.535.0.tgz", - "integrity": "sha512-dRek0zUuIT25wOWJlsRm97nTkUlh1NDcLsQZIN2Y8KxhwoXXWtJs5vaDPT+qAg+OpcNj80i1zLR/CirqlFg/TQ==", - "dependencies": { - "@aws-sdk/types": "3.535.0", - "@smithy/node-config-provider": "^2.3.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - }, - "peerDependencies": { - "aws-crt": ">=1.0.0" - }, - "peerDependenciesMeta": { - "aws-crt": { - "optional": true - } - } - }, - "node_modules/@aws-sdk/util-utf8-browser": { - "version": "3.259.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/util-utf8-browser/-/util-utf8-browser-3.259.0.tgz", - "integrity": "sha512-UvFa/vR+e19XookZF8RzFZBrw2EUkQWxiBW0yYQAhvk3C+QVGl0H3ouca8LDBlBfQKXwmW3huo/59H8rwb1wJw==", - "dependencies": { - "tslib": "^2.3.1" - } - }, - "node_modules/@aws-sdk/xml-builder": { - "version": "3.535.0", - "resolved": "https://registry.npmjs.org/@aws-sdk/xml-builder/-/xml-builder-3.535.0.tgz", - "integrity": "sha512-VXAq/Jz8KIrU84+HqsOJhIKZqG0PNTdi6n6PFQ4xJf44ZQHD/5C7ouH4qCFX5XgZXcgbRIcMVVYGC6Jye0dRng==", - "dependencies": { - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, "node_modules/@esbuild/aix-ppc64": { "version": "0.20.2", "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.20.2.tgz", @@ -1180,648 +383,6 @@ "node": ">=12" } }, - "node_modules/@smithy/abort-controller": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/abort-controller/-/abort-controller-2.2.0.tgz", - "integrity": "sha512-wRlta7GuLWpTqtFfGo+nZyOO1vEvewdNR1R4rTxpC8XU6vG/NDyrFBhwLZsqg1NUoR1noVaXJPC/7ZK47QCySw==", - "dependencies": { - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/chunked-blob-reader": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/chunked-blob-reader/-/chunked-blob-reader-2.2.0.tgz", - "integrity": "sha512-3GJNvRwXBGdkDZZOGiziVYzDpn4j6zfyULHMDKAGIUo72yHALpE9CbhfQp/XcLNVoc1byfMpn6uW5H2BqPjgaQ==", - "dependencies": { - "tslib": "^2.6.2" - } - }, - "node_modules/@smithy/chunked-blob-reader-native": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/chunked-blob-reader-native/-/chunked-blob-reader-native-2.2.0.tgz", - "integrity": "sha512-VNB5+1oCgX3Fzs072yuRsUoC2N4Zg/LJ11DTxX3+Qu+Paa6AmbIF0E9sc2wthz9Psrk/zcOlTCyuposlIhPjZQ==", - "dependencies": { - "@smithy/util-base64": "^2.3.0", - "tslib": "^2.6.2" - } - }, - "node_modules/@smithy/config-resolver": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/config-resolver/-/config-resolver-2.2.0.tgz", - "integrity": "sha512-fsiMgd8toyUba6n1WRmr+qACzXltpdDkPTAaDqc8QqPBUzO+/JKwL6bUBseHVi8tu9l+3JOK+tSf7cay+4B3LA==", - "dependencies": { - "@smithy/node-config-provider": "^2.3.0", - "@smithy/types": "^2.12.0", - "@smithy/util-config-provider": "^2.3.0", - "@smithy/util-middleware": "^2.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/core": { - "version": "1.4.2", - "resolved": "https://registry.npmjs.org/@smithy/core/-/core-1.4.2.tgz", - "integrity": "sha512-2fek3I0KZHWJlRLvRTqxTEri+qV0GRHrJIoLFuBMZB4EMg4WgeBGfF0X6abnrNYpq55KJ6R4D6x4f0vLnhzinA==", - "dependencies": { - "@smithy/middleware-endpoint": "^2.5.1", - "@smithy/middleware-retry": "^2.3.1", - "@smithy/middleware-serde": "^2.3.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/smithy-client": "^2.5.1", - "@smithy/types": "^2.12.0", - "@smithy/util-middleware": "^2.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/credential-provider-imds": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/@smithy/credential-provider-imds/-/credential-provider-imds-2.3.0.tgz", - "integrity": "sha512-BWB9mIukO1wjEOo1Ojgl6LrG4avcaC7T/ZP6ptmAaW4xluhSIPZhY+/PI5YKzlk+jsm+4sQZB45Bt1OfMeQa3w==", - "dependencies": { - "@smithy/node-config-provider": "^2.3.0", - "@smithy/property-provider": "^2.2.0", - "@smithy/types": "^2.12.0", - "@smithy/url-parser": "^2.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/eventstream-codec": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/eventstream-codec/-/eventstream-codec-2.2.0.tgz", - "integrity": "sha512-8janZoJw85nJmQZc4L8TuePp2pk1nxLgkxIR0TUjKJ5Dkj5oelB9WtiSSGXCQvNsJl0VSTvK/2ueMXxvpa9GVw==", - "dependencies": { - "@aws-crypto/crc32": "3.0.0", - "@smithy/types": "^2.12.0", - "@smithy/util-hex-encoding": "^2.2.0", - "tslib": "^2.6.2" - } - }, - "node_modules/@smithy/eventstream-serde-browser": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/eventstream-serde-browser/-/eventstream-serde-browser-2.2.0.tgz", - "integrity": "sha512-UaPf8jKbcP71BGiO0CdeLmlg+RhWnlN8ipsMSdwvqBFigl5nil3rHOI/5GE3tfiuX8LvY5Z9N0meuU7Rab7jWw==", - "dependencies": { - "@smithy/eventstream-serde-universal": "^2.2.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/eventstream-serde-config-resolver": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/eventstream-serde-config-resolver/-/eventstream-serde-config-resolver-2.2.0.tgz", - "integrity": "sha512-RHhbTw/JW3+r8QQH7PrganjNCiuiEZmpi6fYUAetFfPLfZ6EkiA08uN3EFfcyKubXQxOwTeJRZSQmDDCdUshaA==", - "dependencies": { - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/eventstream-serde-node": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/eventstream-serde-node/-/eventstream-serde-node-2.2.0.tgz", - "integrity": "sha512-zpQMtJVqCUMn+pCSFcl9K/RPNtQE0NuMh8sKpCdEHafhwRsjP50Oq/4kMmvxSRy6d8Jslqd8BLvDngrUtmN9iA==", - "dependencies": { - "@smithy/eventstream-serde-universal": "^2.2.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/eventstream-serde-universal": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/eventstream-serde-universal/-/eventstream-serde-universal-2.2.0.tgz", - "integrity": "sha512-pvoe/vvJY0mOpuF84BEtyZoYfbehiFj8KKWk1ds2AT0mTLYFVs+7sBJZmioOFdBXKd48lfrx1vumdPdmGlCLxA==", - "dependencies": { - "@smithy/eventstream-codec": "^2.2.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/fetch-http-handler": { - "version": "2.5.0", - "resolved": "https://registry.npmjs.org/@smithy/fetch-http-handler/-/fetch-http-handler-2.5.0.tgz", - "integrity": "sha512-BOWEBeppWhLn/no/JxUL/ghTfANTjT7kg3Ww2rPqTUY9R4yHPXxJ9JhMe3Z03LN3aPwiwlpDIUcVw1xDyHqEhw==", - "dependencies": { - "@smithy/protocol-http": "^3.3.0", - "@smithy/querystring-builder": "^2.2.0", - "@smithy/types": "^2.12.0", - "@smithy/util-base64": "^2.3.0", - "tslib": "^2.6.2" - } - }, - "node_modules/@smithy/hash-blob-browser": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/hash-blob-browser/-/hash-blob-browser-2.2.0.tgz", - "integrity": "sha512-SGPoVH8mdXBqrkVCJ1Hd1X7vh1zDXojNN1yZyZTZsCno99hVue9+IYzWDjq/EQDDXxmITB0gBmuyPh8oAZSTcg==", - "dependencies": { - "@smithy/chunked-blob-reader": "^2.2.0", - "@smithy/chunked-blob-reader-native": "^2.2.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - } - }, - "node_modules/@smithy/hash-node": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/hash-node/-/hash-node-2.2.0.tgz", - "integrity": "sha512-zLWaC/5aWpMrHKpoDF6nqpNtBhlAYKF/7+9yMN7GpdR8CzohnWfGtMznPybnwSS8saaXBMxIGwJqR4HmRp6b3g==", - "dependencies": { - "@smithy/types": "^2.12.0", - "@smithy/util-buffer-from": "^2.2.0", - "@smithy/util-utf8": "^2.3.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/hash-stream-node": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/hash-stream-node/-/hash-stream-node-2.2.0.tgz", - "integrity": "sha512-aT+HCATOSRMGpPI7bi7NSsTNVZE/La9IaxLXWoVAYMxHT5hGO3ZOGEMZQg8A6nNL+pdFGtZQtND1eoY084HgHQ==", - "dependencies": { - "@smithy/types": "^2.12.0", - "@smithy/util-utf8": "^2.3.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/invalid-dependency": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/invalid-dependency/-/invalid-dependency-2.2.0.tgz", - "integrity": "sha512-nEDASdbKFKPXN2O6lOlTgrEEOO9NHIeO+HVvZnkqc8h5U9g3BIhWsvzFo+UcUbliMHvKNPD/zVxDrkP1Sbgp8Q==", - "dependencies": { - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - } - }, - "node_modules/@smithy/is-array-buffer": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/is-array-buffer/-/is-array-buffer-2.2.0.tgz", - "integrity": "sha512-GGP3O9QFD24uGeAXYUjwSTXARoqpZykHadOmA8G5vfJPK0/DC67qa//0qvqrJzL1xc8WQWX7/yc7fwudjPHPhA==", - "dependencies": { - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/md5-js": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/md5-js/-/md5-js-2.2.0.tgz", - "integrity": "sha512-M26XTtt9IIusVMOWEAhIvFIr9jYj4ISPPGJROqw6vXngO3IYJCnVVSMFn4Tx1rUTG5BiKJNg9u2nxmBiZC5IlQ==", - "dependencies": { - "@smithy/types": "^2.12.0", - "@smithy/util-utf8": "^2.3.0", - "tslib": "^2.6.2" - } - }, - "node_modules/@smithy/middleware-content-length": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/middleware-content-length/-/middleware-content-length-2.2.0.tgz", - "integrity": "sha512-5bl2LG1Ah/7E5cMSC+q+h3IpVHMeOkG0yLRyQT1p2aMJkSrZG7RlXHPuAgb7EyaFeidKEnnd/fNaLLaKlHGzDQ==", - "dependencies": { - "@smithy/protocol-http": "^3.3.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/middleware-endpoint": { - "version": "2.5.1", - "resolved": "https://registry.npmjs.org/@smithy/middleware-endpoint/-/middleware-endpoint-2.5.1.tgz", - "integrity": "sha512-1/8kFp6Fl4OsSIVTWHnNjLnTL8IqpIb/D3sTSczrKFnrE9VMNWxnrRKNvpUHOJ6zpGD5f62TPm7+17ilTJpiCQ==", - "dependencies": { - "@smithy/middleware-serde": "^2.3.0", - "@smithy/node-config-provider": "^2.3.0", - "@smithy/shared-ini-file-loader": "^2.4.0", - "@smithy/types": "^2.12.0", - "@smithy/url-parser": "^2.2.0", - "@smithy/util-middleware": "^2.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/middleware-retry": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/@smithy/middleware-retry/-/middleware-retry-2.3.1.tgz", - "integrity": "sha512-P2bGufFpFdYcWvqpyqqmalRtwFUNUA8vHjJR5iGqbfR6mp65qKOLcUd6lTr4S9Gn/enynSrSf3p3FVgVAf6bXA==", - "dependencies": { - "@smithy/node-config-provider": "^2.3.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/service-error-classification": "^2.1.5", - "@smithy/smithy-client": "^2.5.1", - "@smithy/types": "^2.12.0", - "@smithy/util-middleware": "^2.2.0", - "@smithy/util-retry": "^2.2.0", - "tslib": "^2.6.2", - "uuid": "^9.0.1" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/middleware-serde": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/@smithy/middleware-serde/-/middleware-serde-2.3.0.tgz", - "integrity": "sha512-sIADe7ojwqTyvEQBe1nc/GXB9wdHhi9UwyX0lTyttmUWDJLP655ZYE1WngnNyXREme8I27KCaUhyhZWRXL0q7Q==", - "dependencies": { - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/middleware-stack": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/middleware-stack/-/middleware-stack-2.2.0.tgz", - "integrity": "sha512-Qntc3jrtwwrsAC+X8wms8zhrTr0sFXnyEGhZd9sLtsJ/6gGQKFzNB+wWbOcpJd7BR8ThNCoKt76BuQahfMvpeA==", - "dependencies": { - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/node-config-provider": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/@smithy/node-config-provider/-/node-config-provider-2.3.0.tgz", - "integrity": "sha512-0elK5/03a1JPWMDPaS726Iw6LpQg80gFut1tNpPfxFuChEEklo2yL823V94SpTZTxmKlXFtFgsP55uh3dErnIg==", - "dependencies": { - "@smithy/property-provider": "^2.2.0", - "@smithy/shared-ini-file-loader": "^2.4.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/node-http-handler": { - "version": "2.5.0", - "resolved": "https://registry.npmjs.org/@smithy/node-http-handler/-/node-http-handler-2.5.0.tgz", - "integrity": "sha512-mVGyPBzkkGQsPoxQUbxlEfRjrj6FPyA3u3u2VXGr9hT8wilsoQdZdvKpMBFMB8Crfhv5dNkKHIW0Yyuc7eABqA==", - "dependencies": { - "@smithy/abort-controller": "^2.2.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/querystring-builder": "^2.2.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/property-provider": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/property-provider/-/property-provider-2.2.0.tgz", - "integrity": "sha512-+xiil2lFhtTRzXkx8F053AV46QnIw6e7MV8od5Mi68E1ICOjCeCHw2XfLnDEUHnT9WGUIkwcqavXjfwuJbGlpg==", - "dependencies": { - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/protocol-http": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/@smithy/protocol-http/-/protocol-http-3.3.0.tgz", - "integrity": "sha512-Xy5XK1AFWW2nlY/biWZXu6/krgbaf2dg0q492D8M5qthsnU2H+UgFeZLbM76FnH7s6RO/xhQRkj+T6KBO3JzgQ==", - "dependencies": { - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/querystring-builder": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/querystring-builder/-/querystring-builder-2.2.0.tgz", - "integrity": "sha512-L1kSeviUWL+emq3CUVSgdogoM/D9QMFaqxL/dd0X7PCNWmPXqt+ExtrBjqT0V7HLN03Vs9SuiLrG3zy3JGnE5A==", - "dependencies": { - "@smithy/types": "^2.12.0", - "@smithy/util-uri-escape": "^2.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/querystring-parser": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/querystring-parser/-/querystring-parser-2.2.0.tgz", - "integrity": "sha512-BvHCDrKfbG5Yhbpj4vsbuPV2GgcpHiAkLeIlcA1LtfpMz3jrqizP1+OguSNSj1MwBHEiN+jwNisXLGdajGDQJA==", - "dependencies": { - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/service-error-classification": { - "version": "2.1.5", - "resolved": "https://registry.npmjs.org/@smithy/service-error-classification/-/service-error-classification-2.1.5.tgz", - "integrity": "sha512-uBDTIBBEdAQryvHdc5W8sS5YX7RQzF683XrHePVdFmAgKiMofU15FLSM0/HU03hKTnazdNRFa0YHS7+ArwoUSQ==", - "dependencies": { - "@smithy/types": "^2.12.0" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/shared-ini-file-loader": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@smithy/shared-ini-file-loader/-/shared-ini-file-loader-2.4.0.tgz", - "integrity": "sha512-WyujUJL8e1B6Z4PBfAqC/aGY1+C7T0w20Gih3yrvJSk97gpiVfB+y7c46T4Nunk+ZngLq0rOIdeVeIklk0R3OA==", - "dependencies": { - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/signature-v4": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/@smithy/signature-v4/-/signature-v4-2.3.0.tgz", - "integrity": "sha512-ui/NlpILU+6HAQBfJX8BBsDXuKSNrjTSuOYArRblcrErwKFutjrCNb/OExfVRyj9+26F9J+ZmfWT+fKWuDrH3Q==", - "dependencies": { - "@smithy/is-array-buffer": "^2.2.0", - "@smithy/types": "^2.12.0", - "@smithy/util-hex-encoding": "^2.2.0", - "@smithy/util-middleware": "^2.2.0", - "@smithy/util-uri-escape": "^2.2.0", - "@smithy/util-utf8": "^2.3.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/smithy-client": { - "version": "2.5.1", - "resolved": "https://registry.npmjs.org/@smithy/smithy-client/-/smithy-client-2.5.1.tgz", - "integrity": "sha512-jrbSQrYCho0yDaaf92qWgd+7nAeap5LtHTI51KXqmpIFCceKU3K9+vIVTUH72bOJngBMqa4kyu1VJhRcSrk/CQ==", - "dependencies": { - "@smithy/middleware-endpoint": "^2.5.1", - "@smithy/middleware-stack": "^2.2.0", - "@smithy/protocol-http": "^3.3.0", - "@smithy/types": "^2.12.0", - "@smithy/util-stream": "^2.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/types": { - "version": "2.12.0", - "resolved": "https://registry.npmjs.org/@smithy/types/-/types-2.12.0.tgz", - "integrity": "sha512-QwYgloJ0sVNBeBuBs65cIkTbfzV/Q6ZNPCJ99EICFEdJYG50nGIY/uYXp+TbsdJReIuPr0a0kXmCvren3MbRRw==", - "dependencies": { - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/url-parser": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/url-parser/-/url-parser-2.2.0.tgz", - "integrity": "sha512-hoA4zm61q1mNTpksiSWp2nEl1dt3j726HdRhiNgVJQMj7mLp7dprtF57mOB6JvEk/x9d2bsuL5hlqZbBuHQylQ==", - "dependencies": { - "@smithy/querystring-parser": "^2.2.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - } - }, - "node_modules/@smithy/util-base64": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/@smithy/util-base64/-/util-base64-2.3.0.tgz", - "integrity": "sha512-s3+eVwNeJuXUwuMbusncZNViuhv2LjVJ1nMwTqSA0XAC7gjKhqqxRdJPhR8+YrkoZ9IiIbFk/yK6ACe/xlF+hw==", - "dependencies": { - "@smithy/util-buffer-from": "^2.2.0", - "@smithy/util-utf8": "^2.3.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/util-body-length-browser": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/util-body-length-browser/-/util-body-length-browser-2.2.0.tgz", - "integrity": "sha512-dtpw9uQP7W+n3vOtx0CfBD5EWd7EPdIdsQnWTDoFf77e3VUf05uA7R7TGipIo8e4WL2kuPdnsr3hMQn9ziYj5w==", - "dependencies": { - "tslib": "^2.6.2" - } - }, - "node_modules/@smithy/util-body-length-node": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/@smithy/util-body-length-node/-/util-body-length-node-2.3.0.tgz", - "integrity": "sha512-ITWT1Wqjubf2CJthb0BuT9+bpzBfXeMokH/AAa5EJQgbv9aPMVfnM76iFIZVFf50hYXGbtiV71BHAthNWd6+dw==", - "dependencies": { - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/util-buffer-from": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/util-buffer-from/-/util-buffer-from-2.2.0.tgz", - "integrity": "sha512-IJdWBbTcMQ6DA0gdNhh/BwrLkDR+ADW5Kr1aZmd4k3DIF6ezMV4R2NIAmT08wQJ3yUK82thHWmC/TnK/wpMMIA==", - "dependencies": { - "@smithy/is-array-buffer": "^2.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/util-config-provider": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/@smithy/util-config-provider/-/util-config-provider-2.3.0.tgz", - "integrity": "sha512-HZkzrRcuFN1k70RLqlNK4FnPXKOpkik1+4JaBoHNJn+RnJGYqaa3c5/+XtLOXhlKzlRgNvyaLieHTW2VwGN0VQ==", - "dependencies": { - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/util-defaults-mode-browser": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/@smithy/util-defaults-mode-browser/-/util-defaults-mode-browser-2.2.1.tgz", - "integrity": "sha512-RtKW+8j8skk17SYowucwRUjeh4mCtnm5odCL0Lm2NtHQBsYKrNW0od9Rhopu9wF1gHMfHeWF7i90NwBz/U22Kw==", - "dependencies": { - "@smithy/property-provider": "^2.2.0", - "@smithy/smithy-client": "^2.5.1", - "@smithy/types": "^2.12.0", - "bowser": "^2.11.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">= 10.0.0" - } - }, - "node_modules/@smithy/util-defaults-mode-node": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/@smithy/util-defaults-mode-node/-/util-defaults-mode-node-2.3.1.tgz", - "integrity": "sha512-vkMXHQ0BcLFysBMWgSBLSk3+leMpFSyyFj8zQtv5ZyUBx8/owVh1/pPEkzmW/DR/Gy/5c8vjLDD9gZjXNKbrpA==", - "dependencies": { - "@smithy/config-resolver": "^2.2.0", - "@smithy/credential-provider-imds": "^2.3.0", - "@smithy/node-config-provider": "^2.3.0", - "@smithy/property-provider": "^2.2.0", - "@smithy/smithy-client": "^2.5.1", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">= 10.0.0" - } - }, - "node_modules/@smithy/util-endpoints": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/@smithy/util-endpoints/-/util-endpoints-1.2.0.tgz", - "integrity": "sha512-BuDHv8zRjsE5zXd3PxFXFknzBG3owCpjq8G3FcsXW3CykYXuEqM3nTSsmLzw5q+T12ZYuDlVUZKBdpNbhVtlrQ==", - "dependencies": { - "@smithy/node-config-provider": "^2.3.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">= 14.0.0" - } - }, - "node_modules/@smithy/util-hex-encoding": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/util-hex-encoding/-/util-hex-encoding-2.2.0.tgz", - "integrity": "sha512-7iKXR+/4TpLK194pVjKiasIyqMtTYJsgKgM242Y9uzt5dhHnUDvMNb+3xIhRJ9QhvqGii/5cRUt4fJn3dtXNHQ==", - "dependencies": { - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/util-middleware": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/util-middleware/-/util-middleware-2.2.0.tgz", - "integrity": "sha512-L1qpleXf9QD6LwLCJ5jddGkgWyuSvWBkJwWAZ6kFkdifdso+sk3L3O1HdmPvCdnCK3IS4qWyPxev01QMnfHSBw==", - "dependencies": { - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/util-retry": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/util-retry/-/util-retry-2.2.0.tgz", - "integrity": "sha512-q9+pAFPTfftHXRytmZ7GzLFFrEGavqapFc06XxzZFcSIGERXMerXxCitjOG1prVDR9QdjqotF40SWvbqcCpf8g==", - "dependencies": { - "@smithy/service-error-classification": "^2.1.5", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">= 14.0.0" - } - }, - "node_modules/@smithy/util-stream": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/util-stream/-/util-stream-2.2.0.tgz", - "integrity": "sha512-17faEXbYWIRst1aU9SvPZyMdWmqIrduZjVOqCPMIsWFNxs5yQQgFrJL6b2SdiCzyW9mJoDjFtgi53xx7EH+BXA==", - "dependencies": { - "@smithy/fetch-http-handler": "^2.5.0", - "@smithy/node-http-handler": "^2.5.0", - "@smithy/types": "^2.12.0", - "@smithy/util-base64": "^2.3.0", - "@smithy/util-buffer-from": "^2.2.0", - "@smithy/util-hex-encoding": "^2.2.0", - "@smithy/util-utf8": "^2.3.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/util-uri-escape": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/util-uri-escape/-/util-uri-escape-2.2.0.tgz", - "integrity": "sha512-jtmJMyt1xMD/d8OtbVJ2gFZOSKc+ueYJZPW20ULW1GOp/q/YIM0wNh+u8ZFao9UaIGz4WoPW8hC64qlWLIfoDA==", - "dependencies": { - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/util-utf8": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/@smithy/util-utf8/-/util-utf8-2.3.0.tgz", - "integrity": "sha512-R8Rdn8Hy72KKcebgLiv8jQcQkXoLMOGGv5uI1/k0l+snqkOzQ1R0ChUBCxWMlBsFMekWjq0wRudIweFs7sKT5A==", - "dependencies": { - "@smithy/util-buffer-from": "^2.2.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/@smithy/util-waiter": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@smithy/util-waiter/-/util-waiter-2.2.0.tgz", - "integrity": "sha512-IHk53BVw6MPMi2Gsn+hCng8rFA3ZmR3Rk7GllxDUW9qFJl/hiSvskn7XldkECapQVkIg/1dHpMAxI9xSTaLLSA==", - "dependencies": { - "@smithy/abort-controller": "^2.2.0", - "@smithy/types": "^2.12.0", - "tslib": "^2.6.2" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/bowser": { - "version": "2.11.0", - "resolved": "https://registry.npmjs.org/bowser/-/bowser-2.11.0.tgz", - "integrity": "sha512-AlcaJBi/pqqJBIQ8U9Mcpc9i8Aqxn88Skv5d+xBX006BY5u8N3mGLHa5Lgppa7L/HfwgwLgZ6NYs+Ag6uUmJRA==" - }, "node_modules/esbuild": { "version": "0.20.2", "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.20.2.tgz", @@ -1860,36 +421,10 @@ "@esbuild/win32-x64": "0.20.2" } }, - "node_modules/fast-xml-parser": { - "version": "4.2.5", - "resolved": "https://registry.npmjs.org/fast-xml-parser/-/fast-xml-parser-4.2.5.tgz", - "integrity": "sha512-B9/wizE4WngqQftFPmdaMYlXoJlJOYxGQOanC77fq9k8+Z0v5dDSVh+3glErdIROP//s/jgb7ZuxKfB8nVyo0g==", - "funding": [ - { - "type": "paypal", - "url": "https://paypal.me/naturalintelligence" - }, - { - "type": "github", - "url": "https://github.com/sponsors/NaturalIntelligence" - } - ], - "dependencies": { - "strnum": "^1.0.5" - }, - "bin": { - "fxparser": "src/cli/cli.js" - } - }, - "node_modules/strnum": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/strnum/-/strnum-1.0.5.tgz", - "integrity": "sha512-J8bbNyKKXl5qYcR36TIO8W3mVGVHrmmxsd5PAItGkmyzwJvybiw2IVq5nqd0i4LSNSkB/sx9VHllbfFdr9k1JA==" - }, - "node_modules/tslib": { - "version": "2.6.2", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", - "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==" + "node_modules/rambda": { + "version": "9.2.0", + "resolved": "https://registry.npmjs.org/rambda/-/rambda-9.2.0.tgz", + "integrity": "sha512-RjM8TBNPR+iSvWLqbBpFveDfEf2RPRKHuwBHjQdXsYFDwn3MIvgmJiqVVC1CIQKnOwzeDQd44zqDFgSKQ7RT1Q==" }, "node_modules/typescript": { "version": "5.4.5", @@ -1903,18 +438,6 @@ "engines": { "node": ">=14.17" } - }, - "node_modules/uuid": { - "version": "9.0.1", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-9.0.1.tgz", - "integrity": "sha512-b+1eJOlsR9K8HJpow9Ok3fiWOWSIcIzXodvv0rQjVoOVNpWMpxf1wZNpt4y9h10odCNrqnYp1OBzRktckBe3sA==", - "funding": [ - "https://github.com/sponsors/broofa", - "https://github.com/sponsors/ctavan" - ], - "bin": { - "uuid": "dist/bin/uuid" - } } } } diff --git a/__tests__/__fixtures__/examples/basic/package.json b/__tests__/__fixtures__/examples/basic/package.json index d8fd25f..f9d21ed 100644 --- a/__tests__/__fixtures__/examples/basic/package.json +++ b/__tests__/__fixtures__/examples/basic/package.json @@ -3,7 +3,7 @@ "version": "1.0.0", "description": "test", "dependencies": { - "@aws-sdk/client-s3": "^3.556.0" + "rambda": "^9.2.0" }, "devDependencies": { "esbuild": "^0.20.2", diff --git a/__tests__/__fixtures__/examples/basic/src/index.ts b/__tests__/__fixtures__/examples/basic/src/index.ts index 33fc58f..6a9b4f6 100644 --- a/__tests__/__fixtures__/examples/basic/src/index.ts +++ b/__tests__/__fixtures__/examples/basic/src/index.ts @@ -1,13 +1,196 @@ -import { PutObjectCommand, S3Client } from "@aws-sdk/client-s3"; +import * as console from "node:console"; -const s3 = new S3Client(); +import { compose, map, filter } from 'rambda' +const composed = compose( + map((x: number) => x * 2), + filter((x: number) => x > 2) +); export const handler = async (event: any) => { - const result = await s3.send( - new PutObjectCommand({ - Bucket: "my-bucket", - Key: "my-key", - }), - ); - return result; + console.log(composed([1, 2, 3, 4])); + console.log([ + { + "_id": "6636e04374026d875e3a14f6", + "index": 0, + "guid": "fbdf37d0-aaad-4b0f-b143-28666927fa56", + "isActive": true, + "balance": "$2,337.22", + "picture": "http://placehold.it/32x32", + "age": 40, + "eyeColor": "blue", + "name": "Moody Duncan", + "gender": "male", + "company": "SULTRAXIN", + "email": "moodyduncan@sultraxin.com", + "phone": "+1 (948) 509-3889", + "address": "100 Clermont Avenue, Glenbrook, Florida, 3611", + "about": "Sunt minim sunt qui irure laborum pariatur nostrud laborum aliquip. Qui quis in laboris eu non enim nisi magna. Excepteur est ipsum nostrud pariatur. Officia esse consectetur est culpa reprehenderit aute et veniam sit.\r\n", + "registered": "2015-02-14T11:49:26 -09:00", + "latitude": 54.979732, + "longitude": 86.310027, + "tags": [ + "irure", + "cupidatat", + "sunt", + "sunt", + "dolore", + "incididunt", + "voluptate" + ], + "friends": [ + { + "id": 0, + "name": "Blanca Blake" + }, + { + "id": 1, + "name": "Stafford Gallagher" + }, + { + "id": 2, + "name": "Odessa Figueroa" + } + ], + "greeting": "Hello, Moody Duncan! You have 9 unread messages.", + "favoriteFruit": "banana" + }, + { + "_id": "6636e0438aa0e021cfd86611", + "index": 2, + "guid": "1d6e9bda-0a31-4864-ad70-2fed16999380", + "isActive": true, + "balance": "$1,910.08", + "picture": "http://placehold.it/32x32", + "age": 39, + "eyeColor": "blue", + "name": "Carole Wyatt", + "gender": "female", + "company": "SNACKTION", + "email": "carolewyatt@snacktion.com", + "phone": "+1 (904) 474-3559", + "address": "383 Nixon Court, Belvoir, Illinois, 7525", + "about": "Non cupidatat culpa duis incididunt mollit. Est irure duis ut quis officia ea sit reprehenderit proident ad nulla. Tempor nisi laborum quis non eu occaecat aliquip. Dolore anim consequat ea laboris do dolore laboris ex dolore officia tempor nisi irure do.\r\n", + "registered": "2017-12-13T02:18:04 -09:00", + "latitude": -19.106743, + "longitude": -15.102964, + "tags": [ + "voluptate", + "cillum", + "ullamco", + "elit", + "eiusmod", + "quis", + "labore" + ], + "friends": [ + { + "id": 0, + "name": "Patterson Callahan" + }, + { + "id": 1, + "name": "Tanisha Key" + }, + { + "id": 2, + "name": "Kathie Carroll" + } + ], + "greeting": "Hello, Carole Wyatt! You have 1 unread messages.", + "favoriteFruit": "banana" + }, + { + "_id": "6636e04313862a26fc0407fb", + "index": 4, + "guid": "dacacda2-4a4a-496d-9b5a-fabd5c0c600d", + "isActive": true, + "balance": "$2,754.82", + "picture": "http://placehold.it/32x32", + "age": 30, + "eyeColor": "brown", + "name": "Castro Stevenson", + "gender": "male", + "company": "PANZENT", + "email": "castrostevenson@panzent.com", + "phone": "+1 (972) 542-2441", + "address": "516 Aster Court, Taycheedah, North Dakota, 9377", + "about": "Et nostrud tempor id et occaecat commodo ad fugiat enim magna velit qui ex nostrud. Minim commodo in voluptate consequat duis occaecat velit consequat laboris et. Sunt sit ullamco dolor enim dolore esse deserunt voluptate eiusmod aliqua. Aliqua dolor consequat consequat et commodo aute amet cillum proident velit magna. Labore esse officia proident et ullamco nulla. Dolore proident velit labore ad cupidatat. Adipisicing velit aliqua velit cillum excepteur ullamco eiusmod laborum.\r\n", + "registered": "2023-04-25T09:50:40 -09:00", + "latitude": 3.775112, + "longitude": -170.248202, + "tags": [ + "dolore", + "in", + "id", + "id", + "laboris", + "in", + "consequat" + ], + "friends": [ + { + "id": 0, + "name": "Elaine Roach" + }, + { + "id": 1, + "name": "Allyson Whitaker" + }, + { + "id": 2, + "name": "Juanita Solomon" + } + ], + "greeting": "Hello, Castro Stevenson! You have 10 unread messages.", + "favoriteFruit": "apple" + }, + { + "_id": "6636e043240e1670126a03b6", + "index": 5, + "guid": "3a20ab87-df6c-49a7-ab44-dd299439d733", + "isActive": false, + "balance": "$3,457.86", + "picture": "http://placehold.it/32x32", + "age": 35, + "eyeColor": "brown", + "name": "Suarez Nunez", + "gender": "male", + "company": "INRT", + "email": "suareznunez@inrt.com", + "phone": "+1 (984) 555-3946", + "address": "874 Cumberland Walk, Dunbar, Minnesota, 8376", + "about": "Cupidatat cillum enim velit mollit non cupidatat ullamco ex voluptate est officia. Ea id voluptate excepteur irure deserunt magna sit ipsum nulla. Id in cillum anim minim duis laboris proident. Excepteur cupidatat ea adipisicing consectetur in non voluptate eu. Reprehenderit anim consequat eu pariatur consectetur aliqua ipsum ad pariatur proident minim aliqua amet ullamco. Officia magna anim minim esse mollit minim deserunt.\r\n", + "registered": "2021-09-17T08:54:45 -09:00", + "latitude": 16.307274, + "longitude": 121.547327, + "tags": [ + "amet", + "irure", + "ipsum", + "cillum", + "ad", + "eu", + "aliqua" + ], + "friends": [ + { + "id": 0, + "name": "Robbie Mckenzie" + }, + { + "id": 1, + "name": "Bryant Barry" + }, + { + "id": 2, + "name": "Eve Hatfield" + } + ], + "greeting": "Hello, Suarez Nunez! You have 6 unread messages.", + "favoriteFruit": "strawberry" + } + ]) + return { + + }; }; From e27bc12fc2271ccfee347151f0901953b4cfdc72 Mon Sep 17 00:00:00 2001 From: exoego Date: Mon, 6 May 2024 22:35:18 +0900 Subject: [PATCH 4/4] Exclude test from tsc --- tsconfig.json | 1 - 1 file changed, 1 deletion(-) diff --git a/tsconfig.json b/tsconfig.json index a691702..7ab2ed8 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -18,6 +18,5 @@ }, "include": [ "src", - "__tests__" ] }