├── .gitignore ├── README.md ├── cover.pdf ├── fe ├── cover.html ├── exact-page-num.html ├── last-page.html ├── pdf-content.html └── second-content-page.html ├── final.pdf ├── last-page.pdf ├── news.pdf ├── package-lock.json ├── package.json └── server ├── header-footer-template.mjs ├── index.mjs ├── koa-server.mjs ├── logo.png └── merge-pdf.mjs /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # PDF 生成 2 | 3 | 一套纯前端的 PDF 生成方案,100% 的 UI 还原度,复杂样式也完全不在话下;让 PDF 生成业务变成普通的 Web 开发。 4 | 5 | **欢迎 Star** 6 | 7 | # 配套技术博客 8 | 9 | - [PDF 生成(1)— 开篇](https://github.com/liyongning/blog/issues/42) 中讲解了 PDF 生成的技术背景、方案选型和决策,以及整个方案的技术架构图,所以后面的几篇一直都是在实现整套技术架构 10 | - [PDF 生成(2)— 生成 PDF 文件](https://github.com/liyongning/blog/issues/43) 中我们通过 puppeteer 来生成 PDF 文件,并讲了自定义页眉、页脚的使用和其中的**坑**。本文结束之后 puppeteer 在 PDF 文件生成场景下的能力也基本到头了,所以,接下来的内容就全是基于 puppeteer 的增量开发了,也是整套架构的**核心**和**难点** 11 | - [PDF 生成(3)— 封面、尾页](https://github.com/liyongning/blog/issues/44) 通过 PDF 文件合并技术让一份 PDF 文件包含封面、内容页和尾页三部分。 12 | - [PDF 生成(4)— 目录页](https://github.com/liyongning/blog/issues/45) 通过在内容页的开始位置动态插入 HTML 锚点、页面缩放、锚点元素高度计算、换页高度补偿等技术让 PDF 文件拥有了包含准确页码 + 页面跳转能力的目录页 13 | - [PDF 生成(5)— 内容页支持由多页面组成](https://github.com/liyongning/blog/issues/46) 通过多页面合并技术 + 样式沙箱解决了用户在复杂 PDF 场景下前端代码维护问题,让用户的开发更自由、更符合业务逻辑 14 | - [PDF 生成(6)— 服务化、配置化](https://github.com/liyongning/blog/issues/47) 就是本文了,本系列的最后一篇,以服务化的方式对外提供 PDF 生成能力,通过配置服务来维护接入方的信息,通过队列来做并发控制和任务分类 -------------------------------------------------------------------------------- /cover.pdf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/liyongning/generate-pdf/c3ed8e71b07f071b866b9c2c3f99510f633ac4d9/cover.pdf -------------------------------------------------------------------------------- /fe/cover.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | Document 7 | 17 | 18 | 19 |

我是封面

20 | 21 | -------------------------------------------------------------------------------- /fe/exact-page-num.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 目录项页码准确性 7 | 30 | 31 | 32 |
33 |

锚点 1

34 |
35 |
36 |

锚点 2

37 |
38 | 39 | -------------------------------------------------------------------------------- /fe/last-page.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | Document 7 | 17 | 18 | 19 |

我是尾页

20 | 21 | -------------------------------------------------------------------------------- /fe/pdf-content.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | PDF 生成服务 7 | 8 | 9 | 10 | 11 | -------------------------------------------------------------------------------- /fe/second-content-page.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 第二个内容页 7 | 32 | 33 | 34 |
35 |

第二个内容页 —— 锚点 1

36 |
37 |
38 |

第二个内容页 —— 锚点 2

39 |
40 | 41 | -------------------------------------------------------------------------------- /final.pdf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/liyongning/generate-pdf/c3ed8e71b07f071b866b9c2c3f99510f633ac4d9/final.pdf -------------------------------------------------------------------------------- /last-page.pdf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/liyongning/generate-pdf/c3ed8e71b07f071b866b9c2c3f99510f633ac4d9/last-page.pdf -------------------------------------------------------------------------------- /news.pdf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/liyongning/generate-pdf/c3ed8e71b07f071b866b9c2c3f99510f633ac4d9/news.pdf -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "generate-pdf", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "generate-pdf", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "@koa/router": "^12.0.1", 13 | "axios": "^1.6.7", 14 | "koa": "^2.15.0", 15 | "pdf-lib": "^1.17.1", 16 | "puppeteer": "^21.6.0" 17 | } 18 | }, 19 | "node_modules/@babel/code-frame": { 20 | "version": "7.23.5", 21 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz", 22 | "integrity": "sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA==", 23 | "dependencies": { 24 | "@babel/highlight": "^7.23.4", 25 | "chalk": "^2.4.2" 26 | }, 27 | "engines": { 28 | "node": ">=6.9.0" 29 | } 30 | }, 31 | "node_modules/@babel/helper-validator-identifier": { 32 | "version": "7.22.20", 33 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", 34 | "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", 35 | "engines": { 36 | "node": ">=6.9.0" 37 | } 38 | }, 39 | "node_modules/@babel/highlight": { 40 | "version": "7.23.4", 41 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz", 42 | "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==", 43 | "dependencies": { 44 | "@babel/helper-validator-identifier": "^7.22.20", 45 | "chalk": "^2.4.2", 46 | "js-tokens": "^4.0.0" 47 | }, 48 | "engines": { 49 | "node": ">=6.9.0" 50 | } 51 | }, 52 | "node_modules/@koa/router": { 53 | "version": "12.0.1", 54 | "resolved": "https://registry.npmjs.org/@koa/router/-/router-12.0.1.tgz", 55 | "integrity": "sha512-ribfPYfHb+Uw3b27Eiw6NPqjhIhTpVFzEWLwyc/1Xp+DCdwRRyIlAUODX+9bPARF6aQtUu1+/PHzdNvRzcs/+Q==", 56 | "dependencies": { 57 | "debug": "^4.3.4", 58 | "http-errors": "^2.0.0", 59 | "koa-compose": "^4.1.0", 60 | "methods": "^1.1.2", 61 | "path-to-regexp": "^6.2.1" 62 | }, 63 | "engines": { 64 | "node": ">= 12" 65 | } 66 | }, 67 | "node_modules/@koa/router/node_modules/http-errors": { 68 | "version": "2.0.0", 69 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 70 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 71 | "dependencies": { 72 | "depd": "2.0.0", 73 | "inherits": "2.0.4", 74 | "setprototypeof": "1.2.0", 75 | "statuses": "2.0.1", 76 | "toidentifier": "1.0.1" 77 | }, 78 | "engines": { 79 | "node": ">= 0.8" 80 | } 81 | }, 82 | "node_modules/@koa/router/node_modules/statuses": { 83 | "version": "2.0.1", 84 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 85 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 86 | "engines": { 87 | "node": ">= 0.8" 88 | } 89 | }, 90 | "node_modules/@pdf-lib/standard-fonts": { 91 | "version": "1.0.0", 92 | "resolved": "https://registry.npmjs.org/@pdf-lib/standard-fonts/-/standard-fonts-1.0.0.tgz", 93 | "integrity": "sha512-hU30BK9IUN/su0Mn9VdlVKsWBS6GyhVfqjwl1FjZN4TxP6cCw0jP2w7V3Hf5uX7M0AZJ16vey9yE0ny7Sa59ZA==", 94 | "dependencies": { 95 | "pako": "^1.0.6" 96 | } 97 | }, 98 | "node_modules/@pdf-lib/upng": { 99 | "version": "1.0.1", 100 | "resolved": "https://registry.npmjs.org/@pdf-lib/upng/-/upng-1.0.1.tgz", 101 | "integrity": "sha512-dQK2FUMQtowVP00mtIksrlZhdFXQZPC+taih1q4CvPZ5vqdxR/LKBaFg0oAfzd1GlHZXXSPdQfzQnt+ViGvEIQ==", 102 | "dependencies": { 103 | "pako": "^1.0.10" 104 | } 105 | }, 106 | "node_modules/@puppeteer/browsers": { 107 | "version": "1.9.0", 108 | "resolved": "https://registry.npmjs.org/@puppeteer/browsers/-/browsers-1.9.0.tgz", 109 | "integrity": "sha512-QwguOLy44YBGC8vuPP2nmpX4MUN2FzWbsnvZJtiCzecU3lHmVZkaC1tq6rToi9a200m8RzlVtDyxCS0UIDrxUg==", 110 | "dependencies": { 111 | "debug": "4.3.4", 112 | "extract-zip": "2.0.1", 113 | "progress": "2.0.3", 114 | "proxy-agent": "6.3.1", 115 | "tar-fs": "3.0.4", 116 | "unbzip2-stream": "1.4.3", 117 | "yargs": "17.7.2" 118 | }, 119 | "bin": { 120 | "browsers": "lib/cjs/main-cli.js" 121 | }, 122 | "engines": { 123 | "node": ">=16.3.0" 124 | } 125 | }, 126 | "node_modules/@tootallnate/quickjs-emscripten": { 127 | "version": "0.23.0", 128 | "resolved": "https://registry.npmjs.org/@tootallnate/quickjs-emscripten/-/quickjs-emscripten-0.23.0.tgz", 129 | "integrity": "sha512-C5Mc6rdnsaJDjO3UpGW/CQTHtCKaYlScZTly4JIu97Jxo/odCiH0ITnDXSJPTOrEKk/ycSZ0AOgTmkDtkOsvIA==" 130 | }, 131 | "node_modules/@types/node": { 132 | "version": "20.10.4", 133 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.10.4.tgz", 134 | "integrity": "sha512-D08YG6rr8X90YB56tSIuBaddy/UXAA9RKJoFvrsnogAum/0pmjkgi4+2nx96A330FmioegBWmEYQ+syqCFaveg==", 135 | "optional": true, 136 | "dependencies": { 137 | "undici-types": "~5.26.4" 138 | } 139 | }, 140 | "node_modules/@types/yauzl": { 141 | "version": "2.10.3", 142 | "resolved": "https://registry.npmjs.org/@types/yauzl/-/yauzl-2.10.3.tgz", 143 | "integrity": "sha512-oJoftv0LSuaDZE3Le4DbKX+KS9G36NzOeSap90UIK0yMA/NhKJhqlSGtNDORNRaIbQfzjXDrQa0ytJ6mNRGz/Q==", 144 | "optional": true, 145 | "dependencies": { 146 | "@types/node": "*" 147 | } 148 | }, 149 | "node_modules/accepts": { 150 | "version": "1.3.8", 151 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 152 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 153 | "dependencies": { 154 | "mime-types": "~2.1.34", 155 | "negotiator": "0.6.3" 156 | }, 157 | "engines": { 158 | "node": ">= 0.6" 159 | } 160 | }, 161 | "node_modules/agent-base": { 162 | "version": "7.1.0", 163 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.0.tgz", 164 | "integrity": "sha512-o/zjMZRhJxny7OyEF+Op8X+efiELC7k7yOjMzgfzVqOzXqkBkWI79YoTdOtsuWd5BWhAGAuOY/Xa6xpiaWXiNg==", 165 | "dependencies": { 166 | "debug": "^4.3.4" 167 | }, 168 | "engines": { 169 | "node": ">= 14" 170 | } 171 | }, 172 | "node_modules/ansi-regex": { 173 | "version": "5.0.1", 174 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 175 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 176 | "engines": { 177 | "node": ">=8" 178 | } 179 | }, 180 | "node_modules/ansi-styles": { 181 | "version": "3.2.1", 182 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 183 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 184 | "dependencies": { 185 | "color-convert": "^1.9.0" 186 | }, 187 | "engines": { 188 | "node": ">=4" 189 | } 190 | }, 191 | "node_modules/argparse": { 192 | "version": "2.0.1", 193 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 194 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==" 195 | }, 196 | "node_modules/ast-types": { 197 | "version": "0.13.4", 198 | "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.13.4.tgz", 199 | "integrity": "sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w==", 200 | "dependencies": { 201 | "tslib": "^2.0.1" 202 | }, 203 | "engines": { 204 | "node": ">=4" 205 | } 206 | }, 207 | "node_modules/asynckit": { 208 | "version": "0.4.0", 209 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 210 | "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" 211 | }, 212 | "node_modules/axios": { 213 | "version": "1.6.7", 214 | "resolved": "https://registry.npmjs.org/axios/-/axios-1.6.7.tgz", 215 | "integrity": "sha512-/hDJGff6/c7u0hDkvkGxR/oy6CbCs8ziCsC7SqmhjfozqiJGc8Z11wrv9z9lYfY4K8l+H9TpjcMDX0xOZmx+RA==", 216 | "dependencies": { 217 | "follow-redirects": "^1.15.4", 218 | "form-data": "^4.0.0", 219 | "proxy-from-env": "^1.1.0" 220 | } 221 | }, 222 | "node_modules/b4a": { 223 | "version": "1.6.4", 224 | "resolved": "https://registry.npmjs.org/b4a/-/b4a-1.6.4.tgz", 225 | "integrity": "sha512-fpWrvyVHEKyeEvbKZTVOeZF3VSKKWtJxFIxX/jaVPf+cLbGUSitjb49pHLqPV2BUNNZ0LcoeEGfE/YCpyDYHIw==" 226 | }, 227 | "node_modules/base64-js": { 228 | "version": "1.5.1", 229 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 230 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 231 | "funding": [ 232 | { 233 | "type": "github", 234 | "url": "https://github.com/sponsors/feross" 235 | }, 236 | { 237 | "type": "patreon", 238 | "url": "https://www.patreon.com/feross" 239 | }, 240 | { 241 | "type": "consulting", 242 | "url": "https://feross.org/support" 243 | } 244 | ] 245 | }, 246 | "node_modules/basic-ftp": { 247 | "version": "5.0.3", 248 | "resolved": "https://registry.npmjs.org/basic-ftp/-/basic-ftp-5.0.3.tgz", 249 | "integrity": "sha512-QHX8HLlncOLpy54mh+k/sWIFd0ThmRqwe9ZjELybGZK+tZ8rUb9VO0saKJUROTbE+KhzDUT7xziGpGrW8Kmd+g==", 250 | "engines": { 251 | "node": ">=10.0.0" 252 | } 253 | }, 254 | "node_modules/buffer": { 255 | "version": "5.7.1", 256 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", 257 | "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", 258 | "funding": [ 259 | { 260 | "type": "github", 261 | "url": "https://github.com/sponsors/feross" 262 | }, 263 | { 264 | "type": "patreon", 265 | "url": "https://www.patreon.com/feross" 266 | }, 267 | { 268 | "type": "consulting", 269 | "url": "https://feross.org/support" 270 | } 271 | ], 272 | "dependencies": { 273 | "base64-js": "^1.3.1", 274 | "ieee754": "^1.1.13" 275 | } 276 | }, 277 | "node_modules/buffer-crc32": { 278 | "version": "0.2.13", 279 | "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", 280 | "integrity": "sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==", 281 | "engines": { 282 | "node": "*" 283 | } 284 | }, 285 | "node_modules/cache-content-type": { 286 | "version": "1.0.1", 287 | "resolved": "https://registry.npmjs.org/cache-content-type/-/cache-content-type-1.0.1.tgz", 288 | "integrity": "sha512-IKufZ1o4Ut42YUrZSo8+qnMTrFuKkvyoLXUywKz9GJ5BrhOFGhLdkx9sG4KAnVvbY6kEcSFjLQul+DVmBm2bgA==", 289 | "dependencies": { 290 | "mime-types": "^2.1.18", 291 | "ylru": "^1.2.0" 292 | }, 293 | "engines": { 294 | "node": ">= 6.0.0" 295 | } 296 | }, 297 | "node_modules/callsites": { 298 | "version": "3.1.0", 299 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 300 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 301 | "engines": { 302 | "node": ">=6" 303 | } 304 | }, 305 | "node_modules/chalk": { 306 | "version": "2.4.2", 307 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 308 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 309 | "dependencies": { 310 | "ansi-styles": "^3.2.1", 311 | "escape-string-regexp": "^1.0.5", 312 | "supports-color": "^5.3.0" 313 | }, 314 | "engines": { 315 | "node": ">=4" 316 | } 317 | }, 318 | "node_modules/chromium-bidi": { 319 | "version": "0.5.1", 320 | "resolved": "https://registry.npmjs.org/chromium-bidi/-/chromium-bidi-0.5.1.tgz", 321 | "integrity": "sha512-dcCqOgq9fHKExc2R4JZs/oKbOghWpUNFAJODS8WKRtLhp3avtIH5UDCBrutdqZdh3pARogH8y1ObXm87emwb3g==", 322 | "dependencies": { 323 | "mitt": "3.0.1", 324 | "urlpattern-polyfill": "9.0.0" 325 | }, 326 | "peerDependencies": { 327 | "devtools-protocol": "*" 328 | } 329 | }, 330 | "node_modules/cliui": { 331 | "version": "8.0.1", 332 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", 333 | "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", 334 | "dependencies": { 335 | "string-width": "^4.2.0", 336 | "strip-ansi": "^6.0.1", 337 | "wrap-ansi": "^7.0.0" 338 | }, 339 | "engines": { 340 | "node": ">=12" 341 | } 342 | }, 343 | "node_modules/co": { 344 | "version": "4.6.0", 345 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 346 | "integrity": "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==", 347 | "engines": { 348 | "iojs": ">= 1.0.0", 349 | "node": ">= 0.12.0" 350 | } 351 | }, 352 | "node_modules/color-convert": { 353 | "version": "1.9.3", 354 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 355 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 356 | "dependencies": { 357 | "color-name": "1.1.3" 358 | } 359 | }, 360 | "node_modules/color-name": { 361 | "version": "1.1.3", 362 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 363 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==" 364 | }, 365 | "node_modules/combined-stream": { 366 | "version": "1.0.8", 367 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 368 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 369 | "dependencies": { 370 | "delayed-stream": "~1.0.0" 371 | }, 372 | "engines": { 373 | "node": ">= 0.8" 374 | } 375 | }, 376 | "node_modules/content-disposition": { 377 | "version": "0.5.4", 378 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 379 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 380 | "dependencies": { 381 | "safe-buffer": "5.2.1" 382 | }, 383 | "engines": { 384 | "node": ">= 0.6" 385 | } 386 | }, 387 | "node_modules/content-type": { 388 | "version": "1.0.5", 389 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 390 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 391 | "engines": { 392 | "node": ">= 0.6" 393 | } 394 | }, 395 | "node_modules/cookies": { 396 | "version": "0.9.1", 397 | "resolved": "https://registry.npmjs.org/cookies/-/cookies-0.9.1.tgz", 398 | "integrity": "sha512-TG2hpqe4ELx54QER/S3HQ9SRVnQnGBtKUz5bLQWtYAQ+o6GpgMs6sYUvaiJjVxb+UXwhRhAEP3m7LbsIZ77Hmw==", 399 | "dependencies": { 400 | "depd": "~2.0.0", 401 | "keygrip": "~1.1.0" 402 | }, 403 | "engines": { 404 | "node": ">= 0.8" 405 | } 406 | }, 407 | "node_modules/cosmiconfig": { 408 | "version": "8.3.6", 409 | "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-8.3.6.tgz", 410 | "integrity": "sha512-kcZ6+W5QzcJ3P1Mt+83OUv/oHFqZHIx8DuxG6eZ5RGMERoLqp4BuGjhHLYGK+Kf5XVkQvqBSmAy/nGWN3qDgEA==", 411 | "dependencies": { 412 | "import-fresh": "^3.3.0", 413 | "js-yaml": "^4.1.0", 414 | "parse-json": "^5.2.0", 415 | "path-type": "^4.0.0" 416 | }, 417 | "engines": { 418 | "node": ">=14" 419 | }, 420 | "funding": { 421 | "url": "https://github.com/sponsors/d-fischer" 422 | }, 423 | "peerDependencies": { 424 | "typescript": ">=4.9.5" 425 | }, 426 | "peerDependenciesMeta": { 427 | "typescript": { 428 | "optional": true 429 | } 430 | } 431 | }, 432 | "node_modules/cross-fetch": { 433 | "version": "4.0.0", 434 | "resolved": "https://registry.npmjs.org/cross-fetch/-/cross-fetch-4.0.0.tgz", 435 | "integrity": "sha512-e4a5N8lVvuLgAWgnCrLr2PP0YyDOTHa9H/Rj54dirp61qXnNq46m82bRhNqIA5VccJtWBvPTFRV3TtvHUKPB1g==", 436 | "dependencies": { 437 | "node-fetch": "^2.6.12" 438 | } 439 | }, 440 | "node_modules/data-uri-to-buffer": { 441 | "version": "6.0.1", 442 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-6.0.1.tgz", 443 | "integrity": "sha512-MZd3VlchQkp8rdend6vrx7MmVDJzSNTBvghvKjirLkD+WTChA3KUf0jkE68Q4UyctNqI11zZO9/x2Yx+ub5Cvg==", 444 | "engines": { 445 | "node": ">= 14" 446 | } 447 | }, 448 | "node_modules/debug": { 449 | "version": "4.3.4", 450 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 451 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 452 | "dependencies": { 453 | "ms": "2.1.2" 454 | }, 455 | "engines": { 456 | "node": ">=6.0" 457 | }, 458 | "peerDependenciesMeta": { 459 | "supports-color": { 460 | "optional": true 461 | } 462 | } 463 | }, 464 | "node_modules/deep-equal": { 465 | "version": "1.0.1", 466 | "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.0.1.tgz", 467 | "integrity": "sha512-bHtC0iYvWhyaTzvV3CZgPeZQqCOBGyGsVV7v4eevpdkLHfiSrXUdBG+qAuSz4RI70sszvjQ1QSZ98An1yNwpSw==" 468 | }, 469 | "node_modules/degenerator": { 470 | "version": "5.0.1", 471 | "resolved": "https://registry.npmjs.org/degenerator/-/degenerator-5.0.1.tgz", 472 | "integrity": "sha512-TllpMR/t0M5sqCXfj85i4XaAzxmS5tVA16dqvdkMwGmzI+dXLXnw3J+3Vdv7VKw+ThlTMboK6i9rnZ6Nntj5CQ==", 473 | "dependencies": { 474 | "ast-types": "^0.13.4", 475 | "escodegen": "^2.1.0", 476 | "esprima": "^4.0.1" 477 | }, 478 | "engines": { 479 | "node": ">= 14" 480 | } 481 | }, 482 | "node_modules/delayed-stream": { 483 | "version": "1.0.0", 484 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 485 | "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", 486 | "engines": { 487 | "node": ">=0.4.0" 488 | } 489 | }, 490 | "node_modules/delegates": { 491 | "version": "1.0.0", 492 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 493 | "integrity": "sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ==" 494 | }, 495 | "node_modules/depd": { 496 | "version": "2.0.0", 497 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 498 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 499 | "engines": { 500 | "node": ">= 0.8" 501 | } 502 | }, 503 | "node_modules/destroy": { 504 | "version": "1.2.0", 505 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 506 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 507 | "engines": { 508 | "node": ">= 0.8", 509 | "npm": "1.2.8000 || >= 1.4.16" 510 | } 511 | }, 512 | "node_modules/devtools-protocol": { 513 | "version": "0.0.1203626", 514 | "resolved": "https://registry.npmjs.org/devtools-protocol/-/devtools-protocol-0.0.1203626.tgz", 515 | "integrity": "sha512-nEzHZteIUZfGCZtTiS1fRpC8UZmsfD1SiyPvaUNvS13dvKf666OAm8YTi0+Ca3n1nLEyu49Cy4+dPWpaHFJk9g==" 516 | }, 517 | "node_modules/ee-first": { 518 | "version": "1.1.1", 519 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 520 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 521 | }, 522 | "node_modules/emoji-regex": { 523 | "version": "8.0.0", 524 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 525 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 526 | }, 527 | "node_modules/encodeurl": { 528 | "version": "1.0.2", 529 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 530 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 531 | "engines": { 532 | "node": ">= 0.8" 533 | } 534 | }, 535 | "node_modules/end-of-stream": { 536 | "version": "1.4.4", 537 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 538 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 539 | "dependencies": { 540 | "once": "^1.4.0" 541 | } 542 | }, 543 | "node_modules/error-ex": { 544 | "version": "1.3.2", 545 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 546 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 547 | "dependencies": { 548 | "is-arrayish": "^0.2.1" 549 | } 550 | }, 551 | "node_modules/escalade": { 552 | "version": "3.1.1", 553 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 554 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 555 | "engines": { 556 | "node": ">=6" 557 | } 558 | }, 559 | "node_modules/escape-html": { 560 | "version": "1.0.3", 561 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 562 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 563 | }, 564 | "node_modules/escape-string-regexp": { 565 | "version": "1.0.5", 566 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 567 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 568 | "engines": { 569 | "node": ">=0.8.0" 570 | } 571 | }, 572 | "node_modules/escodegen": { 573 | "version": "2.1.0", 574 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-2.1.0.tgz", 575 | "integrity": "sha512-2NlIDTwUWJN0mRPQOdtQBzbUHvdGY2P1VXSyU83Q3xKxM7WHX2Ql8dKq782Q9TgQUNOLEzEYu9bzLNj1q88I5w==", 576 | "dependencies": { 577 | "esprima": "^4.0.1", 578 | "estraverse": "^5.2.0", 579 | "esutils": "^2.0.2" 580 | }, 581 | "bin": { 582 | "escodegen": "bin/escodegen.js", 583 | "esgenerate": "bin/esgenerate.js" 584 | }, 585 | "engines": { 586 | "node": ">=6.0" 587 | }, 588 | "optionalDependencies": { 589 | "source-map": "~0.6.1" 590 | } 591 | }, 592 | "node_modules/esprima": { 593 | "version": "4.0.1", 594 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 595 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 596 | "bin": { 597 | "esparse": "bin/esparse.js", 598 | "esvalidate": "bin/esvalidate.js" 599 | }, 600 | "engines": { 601 | "node": ">=4" 602 | } 603 | }, 604 | "node_modules/estraverse": { 605 | "version": "5.3.0", 606 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 607 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 608 | "engines": { 609 | "node": ">=4.0" 610 | } 611 | }, 612 | "node_modules/esutils": { 613 | "version": "2.0.3", 614 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 615 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 616 | "engines": { 617 | "node": ">=0.10.0" 618 | } 619 | }, 620 | "node_modules/extract-zip": { 621 | "version": "2.0.1", 622 | "resolved": "https://registry.npmjs.org/extract-zip/-/extract-zip-2.0.1.tgz", 623 | "integrity": "sha512-GDhU9ntwuKyGXdZBUgTIe+vXnWj0fppUEtMDL0+idd5Sta8TGpHssn/eusA9mrPr9qNDym6SxAYZjNvCn/9RBg==", 624 | "dependencies": { 625 | "debug": "^4.1.1", 626 | "get-stream": "^5.1.0", 627 | "yauzl": "^2.10.0" 628 | }, 629 | "bin": { 630 | "extract-zip": "cli.js" 631 | }, 632 | "engines": { 633 | "node": ">= 10.17.0" 634 | }, 635 | "optionalDependencies": { 636 | "@types/yauzl": "^2.9.1" 637 | } 638 | }, 639 | "node_modules/fast-fifo": { 640 | "version": "1.3.2", 641 | "resolved": "https://registry.npmjs.org/fast-fifo/-/fast-fifo-1.3.2.tgz", 642 | "integrity": "sha512-/d9sfos4yxzpwkDkuN7k2SqFKtYNmCTzgfEpz82x34IM9/zc8KGxQoXg1liNC/izpRM/MBdt44Nmx41ZWqk+FQ==" 643 | }, 644 | "node_modules/fd-slicer": { 645 | "version": "1.1.0", 646 | "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", 647 | "integrity": "sha512-cE1qsB/VwyQozZ+q1dGxR8LBYNZeofhEdUNGSMbQD3Gw2lAzX9Zb3uIU6Ebc/Fmyjo9AWWfnn0AUCHqtevs/8g==", 648 | "dependencies": { 649 | "pend": "~1.2.0" 650 | } 651 | }, 652 | "node_modules/follow-redirects": { 653 | "version": "1.15.5", 654 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.5.tgz", 655 | "integrity": "sha512-vSFWUON1B+yAw1VN4xMfxgn5fTUiaOzAJCKBwIIgT/+7CuGy9+r+5gITvP62j3RmaD5Ph65UaERdOSRGUzZtgw==", 656 | "funding": [ 657 | { 658 | "type": "individual", 659 | "url": "https://github.com/sponsors/RubenVerborgh" 660 | } 661 | ], 662 | "engines": { 663 | "node": ">=4.0" 664 | }, 665 | "peerDependenciesMeta": { 666 | "debug": { 667 | "optional": true 668 | } 669 | } 670 | }, 671 | "node_modules/form-data": { 672 | "version": "4.0.0", 673 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", 674 | "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", 675 | "dependencies": { 676 | "asynckit": "^0.4.0", 677 | "combined-stream": "^1.0.8", 678 | "mime-types": "^2.1.12" 679 | }, 680 | "engines": { 681 | "node": ">= 6" 682 | } 683 | }, 684 | "node_modules/fresh": { 685 | "version": "0.5.2", 686 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 687 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 688 | "engines": { 689 | "node": ">= 0.6" 690 | } 691 | }, 692 | "node_modules/fs-extra": { 693 | "version": "8.1.0", 694 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", 695 | "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", 696 | "dependencies": { 697 | "graceful-fs": "^4.2.0", 698 | "jsonfile": "^4.0.0", 699 | "universalify": "^0.1.0" 700 | }, 701 | "engines": { 702 | "node": ">=6 <7 || >=8" 703 | } 704 | }, 705 | "node_modules/get-caller-file": { 706 | "version": "2.0.5", 707 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 708 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 709 | "engines": { 710 | "node": "6.* || 8.* || >= 10.*" 711 | } 712 | }, 713 | "node_modules/get-stream": { 714 | "version": "5.2.0", 715 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", 716 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", 717 | "dependencies": { 718 | "pump": "^3.0.0" 719 | }, 720 | "engines": { 721 | "node": ">=8" 722 | }, 723 | "funding": { 724 | "url": "https://github.com/sponsors/sindresorhus" 725 | } 726 | }, 727 | "node_modules/get-uri": { 728 | "version": "6.0.2", 729 | "resolved": "https://registry.npmjs.org/get-uri/-/get-uri-6.0.2.tgz", 730 | "integrity": "sha512-5KLucCJobh8vBY1K07EFV4+cPZH3mrV9YeAruUseCQKHB58SGjjT2l9/eA9LD082IiuMjSlFJEcdJ27TXvbZNw==", 731 | "dependencies": { 732 | "basic-ftp": "^5.0.2", 733 | "data-uri-to-buffer": "^6.0.0", 734 | "debug": "^4.3.4", 735 | "fs-extra": "^8.1.0" 736 | }, 737 | "engines": { 738 | "node": ">= 14" 739 | } 740 | }, 741 | "node_modules/graceful-fs": { 742 | "version": "4.2.11", 743 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 744 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==" 745 | }, 746 | "node_modules/has-flag": { 747 | "version": "3.0.0", 748 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 749 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 750 | "engines": { 751 | "node": ">=4" 752 | } 753 | }, 754 | "node_modules/has-symbols": { 755 | "version": "1.0.3", 756 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 757 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 758 | "engines": { 759 | "node": ">= 0.4" 760 | }, 761 | "funding": { 762 | "url": "https://github.com/sponsors/ljharb" 763 | } 764 | }, 765 | "node_modules/has-tostringtag": { 766 | "version": "1.0.2", 767 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", 768 | "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", 769 | "dependencies": { 770 | "has-symbols": "^1.0.3" 771 | }, 772 | "engines": { 773 | "node": ">= 0.4" 774 | }, 775 | "funding": { 776 | "url": "https://github.com/sponsors/ljharb" 777 | } 778 | }, 779 | "node_modules/http-assert": { 780 | "version": "1.5.0", 781 | "resolved": "https://registry.npmjs.org/http-assert/-/http-assert-1.5.0.tgz", 782 | "integrity": "sha512-uPpH7OKX4H25hBmU6G1jWNaqJGpTXxey+YOUizJUAgu0AjLUeC8D73hTrhvDS5D+GJN1DN1+hhc/eF/wpxtp0w==", 783 | "dependencies": { 784 | "deep-equal": "~1.0.1", 785 | "http-errors": "~1.8.0" 786 | }, 787 | "engines": { 788 | "node": ">= 0.8" 789 | } 790 | }, 791 | "node_modules/http-errors": { 792 | "version": "1.8.1", 793 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz", 794 | "integrity": "sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g==", 795 | "dependencies": { 796 | "depd": "~1.1.2", 797 | "inherits": "2.0.4", 798 | "setprototypeof": "1.2.0", 799 | "statuses": ">= 1.5.0 < 2", 800 | "toidentifier": "1.0.1" 801 | }, 802 | "engines": { 803 | "node": ">= 0.6" 804 | } 805 | }, 806 | "node_modules/http-errors/node_modules/depd": { 807 | "version": "1.1.2", 808 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 809 | "integrity": "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==", 810 | "engines": { 811 | "node": ">= 0.6" 812 | } 813 | }, 814 | "node_modules/http-proxy-agent": { 815 | "version": "7.0.0", 816 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.0.tgz", 817 | "integrity": "sha512-+ZT+iBxVUQ1asugqnD6oWoRiS25AkjNfG085dKJGtGxkdwLQrMKU5wJr2bOOFAXzKcTuqq+7fZlTMgG3SRfIYQ==", 818 | "dependencies": { 819 | "agent-base": "^7.1.0", 820 | "debug": "^4.3.4" 821 | }, 822 | "engines": { 823 | "node": ">= 14" 824 | } 825 | }, 826 | "node_modules/https-proxy-agent": { 827 | "version": "7.0.2", 828 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-7.0.2.tgz", 829 | "integrity": "sha512-NmLNjm6ucYwtcUmL7JQC1ZQ57LmHP4lT15FQ8D61nak1rO6DH+fz5qNK2Ap5UN4ZapYICE3/0KodcLYSPsPbaA==", 830 | "dependencies": { 831 | "agent-base": "^7.0.2", 832 | "debug": "4" 833 | }, 834 | "engines": { 835 | "node": ">= 14" 836 | } 837 | }, 838 | "node_modules/ieee754": { 839 | "version": "1.2.1", 840 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 841 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", 842 | "funding": [ 843 | { 844 | "type": "github", 845 | "url": "https://github.com/sponsors/feross" 846 | }, 847 | { 848 | "type": "patreon", 849 | "url": "https://www.patreon.com/feross" 850 | }, 851 | { 852 | "type": "consulting", 853 | "url": "https://feross.org/support" 854 | } 855 | ] 856 | }, 857 | "node_modules/import-fresh": { 858 | "version": "3.3.0", 859 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 860 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 861 | "dependencies": { 862 | "parent-module": "^1.0.0", 863 | "resolve-from": "^4.0.0" 864 | }, 865 | "engines": { 866 | "node": ">=6" 867 | }, 868 | "funding": { 869 | "url": "https://github.com/sponsors/sindresorhus" 870 | } 871 | }, 872 | "node_modules/inherits": { 873 | "version": "2.0.4", 874 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 875 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 876 | }, 877 | "node_modules/ip": { 878 | "version": "1.1.8", 879 | "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.8.tgz", 880 | "integrity": "sha512-PuExPYUiu6qMBQb4l06ecm6T6ujzhmh+MeJcW9wa89PoAz5pvd4zPgN5WJV104mb6S2T1AwNIAaB70JNrLQWhg==" 881 | }, 882 | "node_modules/is-arrayish": { 883 | "version": "0.2.1", 884 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 885 | "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==" 886 | }, 887 | "node_modules/is-fullwidth-code-point": { 888 | "version": "3.0.0", 889 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 890 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 891 | "engines": { 892 | "node": ">=8" 893 | } 894 | }, 895 | "node_modules/is-generator-function": { 896 | "version": "1.0.10", 897 | "resolved": "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz", 898 | "integrity": "sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==", 899 | "dependencies": { 900 | "has-tostringtag": "^1.0.0" 901 | }, 902 | "engines": { 903 | "node": ">= 0.4" 904 | }, 905 | "funding": { 906 | "url": "https://github.com/sponsors/ljharb" 907 | } 908 | }, 909 | "node_modules/js-tokens": { 910 | "version": "4.0.0", 911 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 912 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 913 | }, 914 | "node_modules/js-yaml": { 915 | "version": "4.1.0", 916 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 917 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 918 | "dependencies": { 919 | "argparse": "^2.0.1" 920 | }, 921 | "bin": { 922 | "js-yaml": "bin/js-yaml.js" 923 | } 924 | }, 925 | "node_modules/json-parse-even-better-errors": { 926 | "version": "2.3.1", 927 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", 928 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==" 929 | }, 930 | "node_modules/jsonfile": { 931 | "version": "4.0.0", 932 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 933 | "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==", 934 | "optionalDependencies": { 935 | "graceful-fs": "^4.1.6" 936 | } 937 | }, 938 | "node_modules/keygrip": { 939 | "version": "1.1.0", 940 | "resolved": "https://registry.npmjs.org/keygrip/-/keygrip-1.1.0.tgz", 941 | "integrity": "sha512-iYSchDJ+liQ8iwbSI2QqsQOvqv58eJCEanyJPJi+Khyu8smkcKSFUCbPwzFcL7YVtZ6eONjqRX/38caJ7QjRAQ==", 942 | "dependencies": { 943 | "tsscmp": "1.0.6" 944 | }, 945 | "engines": { 946 | "node": ">= 0.6" 947 | } 948 | }, 949 | "node_modules/koa": { 950 | "version": "2.15.0", 951 | "resolved": "https://registry.npmjs.org/koa/-/koa-2.15.0.tgz", 952 | "integrity": "sha512-KEL/vU1knsoUvfP4MC4/GthpQrY/p6dzwaaGI6Rt4NQuFqkw3qrvsdYF5pz3wOfi7IGTvMPHC9aZIcUKYFNxsw==", 953 | "dependencies": { 954 | "accepts": "^1.3.5", 955 | "cache-content-type": "^1.0.0", 956 | "content-disposition": "~0.5.2", 957 | "content-type": "^1.0.4", 958 | "cookies": "~0.9.0", 959 | "debug": "^4.3.2", 960 | "delegates": "^1.0.0", 961 | "depd": "^2.0.0", 962 | "destroy": "^1.0.4", 963 | "encodeurl": "^1.0.2", 964 | "escape-html": "^1.0.3", 965 | "fresh": "~0.5.2", 966 | "http-assert": "^1.3.0", 967 | "http-errors": "^1.6.3", 968 | "is-generator-function": "^1.0.7", 969 | "koa-compose": "^4.1.0", 970 | "koa-convert": "^2.0.0", 971 | "on-finished": "^2.3.0", 972 | "only": "~0.0.2", 973 | "parseurl": "^1.3.2", 974 | "statuses": "^1.5.0", 975 | "type-is": "^1.6.16", 976 | "vary": "^1.1.2" 977 | }, 978 | "engines": { 979 | "node": "^4.8.4 || ^6.10.1 || ^7.10.1 || >= 8.1.4" 980 | } 981 | }, 982 | "node_modules/koa-compose": { 983 | "version": "4.1.0", 984 | "resolved": "https://registry.npmjs.org/koa-compose/-/koa-compose-4.1.0.tgz", 985 | "integrity": "sha512-8ODW8TrDuMYvXRwra/Kh7/rJo9BtOfPc6qO8eAfC80CnCvSjSl0bkRM24X6/XBBEyj0v1nRUQ1LyOy3dbqOWXw==" 986 | }, 987 | "node_modules/koa-convert": { 988 | "version": "2.0.0", 989 | "resolved": "https://registry.npmjs.org/koa-convert/-/koa-convert-2.0.0.tgz", 990 | "integrity": "sha512-asOvN6bFlSnxewce2e/DK3p4tltyfC4VM7ZwuTuepI7dEQVcvpyFuBcEARu1+Hxg8DIwytce2n7jrZtRlPrARA==", 991 | "dependencies": { 992 | "co": "^4.6.0", 993 | "koa-compose": "^4.1.0" 994 | }, 995 | "engines": { 996 | "node": ">= 10" 997 | } 998 | }, 999 | "node_modules/lines-and-columns": { 1000 | "version": "1.2.4", 1001 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", 1002 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==" 1003 | }, 1004 | "node_modules/lru-cache": { 1005 | "version": "7.18.3", 1006 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.18.3.tgz", 1007 | "integrity": "sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA==", 1008 | "engines": { 1009 | "node": ">=12" 1010 | } 1011 | }, 1012 | "node_modules/media-typer": { 1013 | "version": "0.3.0", 1014 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1015 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 1016 | "engines": { 1017 | "node": ">= 0.6" 1018 | } 1019 | }, 1020 | "node_modules/methods": { 1021 | "version": "1.1.2", 1022 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1023 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", 1024 | "engines": { 1025 | "node": ">= 0.6" 1026 | } 1027 | }, 1028 | "node_modules/mime-db": { 1029 | "version": "1.52.0", 1030 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1031 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 1032 | "engines": { 1033 | "node": ">= 0.6" 1034 | } 1035 | }, 1036 | "node_modules/mime-types": { 1037 | "version": "2.1.35", 1038 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1039 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1040 | "dependencies": { 1041 | "mime-db": "1.52.0" 1042 | }, 1043 | "engines": { 1044 | "node": ">= 0.6" 1045 | } 1046 | }, 1047 | "node_modules/mitt": { 1048 | "version": "3.0.1", 1049 | "resolved": "https://registry.npmjs.org/mitt/-/mitt-3.0.1.tgz", 1050 | "integrity": "sha512-vKivATfr97l2/QBCYAkXYDbrIWPM2IIKEl7YPhjCvKlG3kE2gm+uBo6nEXK3M5/Ffh/FLpKExzOQ3JJoJGFKBw==" 1051 | }, 1052 | "node_modules/mkdirp-classic": { 1053 | "version": "0.5.3", 1054 | "resolved": "https://registry.npmjs.org/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz", 1055 | "integrity": "sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A==" 1056 | }, 1057 | "node_modules/ms": { 1058 | "version": "2.1.2", 1059 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1060 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1061 | }, 1062 | "node_modules/negotiator": { 1063 | "version": "0.6.3", 1064 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1065 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 1066 | "engines": { 1067 | "node": ">= 0.6" 1068 | } 1069 | }, 1070 | "node_modules/netmask": { 1071 | "version": "2.0.2", 1072 | "resolved": "https://registry.npmjs.org/netmask/-/netmask-2.0.2.tgz", 1073 | "integrity": "sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg==", 1074 | "engines": { 1075 | "node": ">= 0.4.0" 1076 | } 1077 | }, 1078 | "node_modules/node-fetch": { 1079 | "version": "2.7.0", 1080 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.7.0.tgz", 1081 | "integrity": "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==", 1082 | "dependencies": { 1083 | "whatwg-url": "^5.0.0" 1084 | }, 1085 | "engines": { 1086 | "node": "4.x || >=6.0.0" 1087 | }, 1088 | "peerDependencies": { 1089 | "encoding": "^0.1.0" 1090 | }, 1091 | "peerDependenciesMeta": { 1092 | "encoding": { 1093 | "optional": true 1094 | } 1095 | } 1096 | }, 1097 | "node_modules/on-finished": { 1098 | "version": "2.4.1", 1099 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 1100 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 1101 | "dependencies": { 1102 | "ee-first": "1.1.1" 1103 | }, 1104 | "engines": { 1105 | "node": ">= 0.8" 1106 | } 1107 | }, 1108 | "node_modules/once": { 1109 | "version": "1.4.0", 1110 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1111 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1112 | "dependencies": { 1113 | "wrappy": "1" 1114 | } 1115 | }, 1116 | "node_modules/only": { 1117 | "version": "0.0.2", 1118 | "resolved": "https://registry.npmjs.org/only/-/only-0.0.2.tgz", 1119 | "integrity": "sha512-Fvw+Jemq5fjjyWz6CpKx6w9s7xxqo3+JCyM0WXWeCSOboZ8ABkyvP8ID4CZuChA/wxSx+XSJmdOm8rGVyJ1hdQ==" 1120 | }, 1121 | "node_modules/pac-proxy-agent": { 1122 | "version": "7.0.1", 1123 | "resolved": "https://registry.npmjs.org/pac-proxy-agent/-/pac-proxy-agent-7.0.1.tgz", 1124 | "integrity": "sha512-ASV8yU4LLKBAjqIPMbrgtaKIvxQri/yh2OpI+S6hVa9JRkUI3Y3NPFbfngDtY7oFtSMD3w31Xns89mDa3Feo5A==", 1125 | "dependencies": { 1126 | "@tootallnate/quickjs-emscripten": "^0.23.0", 1127 | "agent-base": "^7.0.2", 1128 | "debug": "^4.3.4", 1129 | "get-uri": "^6.0.1", 1130 | "http-proxy-agent": "^7.0.0", 1131 | "https-proxy-agent": "^7.0.2", 1132 | "pac-resolver": "^7.0.0", 1133 | "socks-proxy-agent": "^8.0.2" 1134 | }, 1135 | "engines": { 1136 | "node": ">= 14" 1137 | } 1138 | }, 1139 | "node_modules/pac-resolver": { 1140 | "version": "7.0.0", 1141 | "resolved": "https://registry.npmjs.org/pac-resolver/-/pac-resolver-7.0.0.tgz", 1142 | "integrity": "sha512-Fd9lT9vJbHYRACT8OhCbZBbxr6KRSawSovFpy8nDGshaK99S/EBhVIHp9+crhxrsZOuvLpgL1n23iyPg6Rl2hg==", 1143 | "dependencies": { 1144 | "degenerator": "^5.0.0", 1145 | "ip": "^1.1.8", 1146 | "netmask": "^2.0.2" 1147 | }, 1148 | "engines": { 1149 | "node": ">= 14" 1150 | } 1151 | }, 1152 | "node_modules/pako": { 1153 | "version": "1.0.11", 1154 | "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.11.tgz", 1155 | "integrity": "sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==" 1156 | }, 1157 | "node_modules/parent-module": { 1158 | "version": "1.0.1", 1159 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1160 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1161 | "dependencies": { 1162 | "callsites": "^3.0.0" 1163 | }, 1164 | "engines": { 1165 | "node": ">=6" 1166 | } 1167 | }, 1168 | "node_modules/parse-json": { 1169 | "version": "5.2.0", 1170 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", 1171 | "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", 1172 | "dependencies": { 1173 | "@babel/code-frame": "^7.0.0", 1174 | "error-ex": "^1.3.1", 1175 | "json-parse-even-better-errors": "^2.3.0", 1176 | "lines-and-columns": "^1.1.6" 1177 | }, 1178 | "engines": { 1179 | "node": ">=8" 1180 | }, 1181 | "funding": { 1182 | "url": "https://github.com/sponsors/sindresorhus" 1183 | } 1184 | }, 1185 | "node_modules/parseurl": { 1186 | "version": "1.3.3", 1187 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1188 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1189 | "engines": { 1190 | "node": ">= 0.8" 1191 | } 1192 | }, 1193 | "node_modules/path-to-regexp": { 1194 | "version": "6.2.1", 1195 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz", 1196 | "integrity": "sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw==" 1197 | }, 1198 | "node_modules/path-type": { 1199 | "version": "4.0.0", 1200 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 1201 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 1202 | "engines": { 1203 | "node": ">=8" 1204 | } 1205 | }, 1206 | "node_modules/pdf-lib": { 1207 | "version": "1.17.1", 1208 | "resolved": "https://registry.npmjs.org/pdf-lib/-/pdf-lib-1.17.1.tgz", 1209 | "integrity": "sha512-V/mpyJAoTsN4cnP31vc0wfNA1+p20evqqnap0KLoRUN0Yk/p3wN52DOEsL4oBFcLdb76hlpKPtzJIgo67j/XLw==", 1210 | "dependencies": { 1211 | "@pdf-lib/standard-fonts": "^1.0.0", 1212 | "@pdf-lib/upng": "^1.0.1", 1213 | "pako": "^1.0.11", 1214 | "tslib": "^1.11.1" 1215 | } 1216 | }, 1217 | "node_modules/pdf-lib/node_modules/tslib": { 1218 | "version": "1.14.1", 1219 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 1220 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==" 1221 | }, 1222 | "node_modules/pend": { 1223 | "version": "1.2.0", 1224 | "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", 1225 | "integrity": "sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg==" 1226 | }, 1227 | "node_modules/progress": { 1228 | "version": "2.0.3", 1229 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1230 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1231 | "engines": { 1232 | "node": ">=0.4.0" 1233 | } 1234 | }, 1235 | "node_modules/proxy-agent": { 1236 | "version": "6.3.1", 1237 | "resolved": "https://registry.npmjs.org/proxy-agent/-/proxy-agent-6.3.1.tgz", 1238 | "integrity": "sha512-Rb5RVBy1iyqOtNl15Cw/llpeLH8bsb37gM1FUfKQ+Wck6xHlbAhWGUFiTRHtkjqGTA5pSHz6+0hrPW/oECihPQ==", 1239 | "dependencies": { 1240 | "agent-base": "^7.0.2", 1241 | "debug": "^4.3.4", 1242 | "http-proxy-agent": "^7.0.0", 1243 | "https-proxy-agent": "^7.0.2", 1244 | "lru-cache": "^7.14.1", 1245 | "pac-proxy-agent": "^7.0.1", 1246 | "proxy-from-env": "^1.1.0", 1247 | "socks-proxy-agent": "^8.0.2" 1248 | }, 1249 | "engines": { 1250 | "node": ">= 14" 1251 | } 1252 | }, 1253 | "node_modules/proxy-from-env": { 1254 | "version": "1.1.0", 1255 | "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", 1256 | "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" 1257 | }, 1258 | "node_modules/pump": { 1259 | "version": "3.0.0", 1260 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1261 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1262 | "dependencies": { 1263 | "end-of-stream": "^1.1.0", 1264 | "once": "^1.3.1" 1265 | } 1266 | }, 1267 | "node_modules/puppeteer": { 1268 | "version": "21.6.0", 1269 | "resolved": "https://registry.npmjs.org/puppeteer/-/puppeteer-21.6.0.tgz", 1270 | "integrity": "sha512-u6JhSF7xaPYZ2gd3tvhYI8MwVAjLc3Cazj7UWvMV95A07/y7cIjBwYUiMU9/jm4z0FSUORriLX/RZRaiASNWPw==", 1271 | "hasInstallScript": true, 1272 | "dependencies": { 1273 | "@puppeteer/browsers": "1.9.0", 1274 | "cosmiconfig": "8.3.6", 1275 | "puppeteer-core": "21.6.0" 1276 | }, 1277 | "bin": { 1278 | "puppeteer": "lib/esm/puppeteer/node/cli.js" 1279 | }, 1280 | "engines": { 1281 | "node": ">=16.13.2" 1282 | } 1283 | }, 1284 | "node_modules/puppeteer-core": { 1285 | "version": "21.6.0", 1286 | "resolved": "https://registry.npmjs.org/puppeteer-core/-/puppeteer-core-21.6.0.tgz", 1287 | "integrity": "sha512-1vrzbp2E1JpBwtIIrriWkN+A0afUxkqRuFTC3uASc5ql6iuK9ppOdIU/CPGKwOyB4YFIQ16mRbK0PK19mbXnaQ==", 1288 | "dependencies": { 1289 | "@puppeteer/browsers": "1.9.0", 1290 | "chromium-bidi": "0.5.1", 1291 | "cross-fetch": "4.0.0", 1292 | "debug": "4.3.4", 1293 | "devtools-protocol": "0.0.1203626", 1294 | "ws": "8.14.2" 1295 | }, 1296 | "engines": { 1297 | "node": ">=16.13.2" 1298 | } 1299 | }, 1300 | "node_modules/queue-tick": { 1301 | "version": "1.0.1", 1302 | "resolved": "https://registry.npmjs.org/queue-tick/-/queue-tick-1.0.1.tgz", 1303 | "integrity": "sha512-kJt5qhMxoszgU/62PLP1CJytzd2NKetjSRnyuj31fDd3Rlcz3fzlFdFLD1SItunPwyqEOkca6GbV612BWfaBag==" 1304 | }, 1305 | "node_modules/require-directory": { 1306 | "version": "2.1.1", 1307 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1308 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 1309 | "engines": { 1310 | "node": ">=0.10.0" 1311 | } 1312 | }, 1313 | "node_modules/resolve-from": { 1314 | "version": "4.0.0", 1315 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1316 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1317 | "engines": { 1318 | "node": ">=4" 1319 | } 1320 | }, 1321 | "node_modules/safe-buffer": { 1322 | "version": "5.2.1", 1323 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1324 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1325 | "funding": [ 1326 | { 1327 | "type": "github", 1328 | "url": "https://github.com/sponsors/feross" 1329 | }, 1330 | { 1331 | "type": "patreon", 1332 | "url": "https://www.patreon.com/feross" 1333 | }, 1334 | { 1335 | "type": "consulting", 1336 | "url": "https://feross.org/support" 1337 | } 1338 | ] 1339 | }, 1340 | "node_modules/setprototypeof": { 1341 | "version": "1.2.0", 1342 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1343 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1344 | }, 1345 | "node_modules/smart-buffer": { 1346 | "version": "4.2.0", 1347 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 1348 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==", 1349 | "engines": { 1350 | "node": ">= 6.0.0", 1351 | "npm": ">= 3.0.0" 1352 | } 1353 | }, 1354 | "node_modules/socks": { 1355 | "version": "2.7.1", 1356 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.7.1.tgz", 1357 | "integrity": "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==", 1358 | "dependencies": { 1359 | "ip": "^2.0.0", 1360 | "smart-buffer": "^4.2.0" 1361 | }, 1362 | "engines": { 1363 | "node": ">= 10.13.0", 1364 | "npm": ">= 3.0.0" 1365 | } 1366 | }, 1367 | "node_modules/socks-proxy-agent": { 1368 | "version": "8.0.2", 1369 | "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-8.0.2.tgz", 1370 | "integrity": "sha512-8zuqoLv1aP/66PHF5TqwJ7Czm3Yv32urJQHrVyhD7mmA6d61Zv8cIXQYPTWwmg6qlupnPvs/QKDmfa4P/qct2g==", 1371 | "dependencies": { 1372 | "agent-base": "^7.0.2", 1373 | "debug": "^4.3.4", 1374 | "socks": "^2.7.1" 1375 | }, 1376 | "engines": { 1377 | "node": ">= 14" 1378 | } 1379 | }, 1380 | "node_modules/socks/node_modules/ip": { 1381 | "version": "2.0.0", 1382 | "resolved": "https://registry.npmjs.org/ip/-/ip-2.0.0.tgz", 1383 | "integrity": "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==" 1384 | }, 1385 | "node_modules/source-map": { 1386 | "version": "0.6.1", 1387 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1388 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1389 | "optional": true, 1390 | "engines": { 1391 | "node": ">=0.10.0" 1392 | } 1393 | }, 1394 | "node_modules/statuses": { 1395 | "version": "1.5.0", 1396 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1397 | "integrity": "sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==", 1398 | "engines": { 1399 | "node": ">= 0.6" 1400 | } 1401 | }, 1402 | "node_modules/streamx": { 1403 | "version": "2.15.5", 1404 | "resolved": "https://registry.npmjs.org/streamx/-/streamx-2.15.5.tgz", 1405 | "integrity": "sha512-9thPGMkKC2GctCzyCUjME3yR03x2xNo0GPKGkRw2UMYN+gqWa9uqpyNWhmsNCutU5zHmkUum0LsCRQTXUgUCAg==", 1406 | "dependencies": { 1407 | "fast-fifo": "^1.1.0", 1408 | "queue-tick": "^1.0.1" 1409 | } 1410 | }, 1411 | "node_modules/string-width": { 1412 | "version": "4.2.3", 1413 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1414 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1415 | "dependencies": { 1416 | "emoji-regex": "^8.0.0", 1417 | "is-fullwidth-code-point": "^3.0.0", 1418 | "strip-ansi": "^6.0.1" 1419 | }, 1420 | "engines": { 1421 | "node": ">=8" 1422 | } 1423 | }, 1424 | "node_modules/strip-ansi": { 1425 | "version": "6.0.1", 1426 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1427 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1428 | "dependencies": { 1429 | "ansi-regex": "^5.0.1" 1430 | }, 1431 | "engines": { 1432 | "node": ">=8" 1433 | } 1434 | }, 1435 | "node_modules/supports-color": { 1436 | "version": "5.5.0", 1437 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1438 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1439 | "dependencies": { 1440 | "has-flag": "^3.0.0" 1441 | }, 1442 | "engines": { 1443 | "node": ">=4" 1444 | } 1445 | }, 1446 | "node_modules/tar-fs": { 1447 | "version": "3.0.4", 1448 | "resolved": "https://registry.npmjs.org/tar-fs/-/tar-fs-3.0.4.tgz", 1449 | "integrity": "sha512-5AFQU8b9qLfZCX9zp2duONhPmZv0hGYiBPJsyUdqMjzq/mqVpy/rEUSeHk1+YitmxugaptgBh5oDGU3VsAJq4w==", 1450 | "dependencies": { 1451 | "mkdirp-classic": "^0.5.2", 1452 | "pump": "^3.0.0", 1453 | "tar-stream": "^3.1.5" 1454 | } 1455 | }, 1456 | "node_modules/tar-stream": { 1457 | "version": "3.1.6", 1458 | "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-3.1.6.tgz", 1459 | "integrity": "sha512-B/UyjYwPpMBv+PaFSWAmtYjwdrlEaZQEhMIBFNC5oEG8lpiW8XjcSdmEaClj28ArfKScKHs2nshz3k2le6crsg==", 1460 | "dependencies": { 1461 | "b4a": "^1.6.4", 1462 | "fast-fifo": "^1.2.0", 1463 | "streamx": "^2.15.0" 1464 | } 1465 | }, 1466 | "node_modules/through": { 1467 | "version": "2.3.8", 1468 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1469 | "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==" 1470 | }, 1471 | "node_modules/toidentifier": { 1472 | "version": "1.0.1", 1473 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1474 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1475 | "engines": { 1476 | "node": ">=0.6" 1477 | } 1478 | }, 1479 | "node_modules/tr46": { 1480 | "version": "0.0.3", 1481 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 1482 | "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" 1483 | }, 1484 | "node_modules/tslib": { 1485 | "version": "2.6.2", 1486 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", 1487 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==" 1488 | }, 1489 | "node_modules/tsscmp": { 1490 | "version": "1.0.6", 1491 | "resolved": "https://registry.npmjs.org/tsscmp/-/tsscmp-1.0.6.tgz", 1492 | "integrity": "sha512-LxhtAkPDTkVCMQjt2h6eBVY28KCjikZqZfMcC15YBeNjkgUpdCfBu5HoiOTDu86v6smE8yOjyEktJ8hlbANHQA==", 1493 | "engines": { 1494 | "node": ">=0.6.x" 1495 | } 1496 | }, 1497 | "node_modules/type-is": { 1498 | "version": "1.6.18", 1499 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1500 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1501 | "dependencies": { 1502 | "media-typer": "0.3.0", 1503 | "mime-types": "~2.1.24" 1504 | }, 1505 | "engines": { 1506 | "node": ">= 0.6" 1507 | } 1508 | }, 1509 | "node_modules/unbzip2-stream": { 1510 | "version": "1.4.3", 1511 | "resolved": "https://registry.npmjs.org/unbzip2-stream/-/unbzip2-stream-1.4.3.tgz", 1512 | "integrity": "sha512-mlExGW4w71ebDJviH16lQLtZS32VKqsSfk80GCfUlwT/4/hNRFsoscrF/c++9xinkMzECL1uL9DDwXqFWkruPg==", 1513 | "dependencies": { 1514 | "buffer": "^5.2.1", 1515 | "through": "^2.3.8" 1516 | } 1517 | }, 1518 | "node_modules/undici-types": { 1519 | "version": "5.26.5", 1520 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", 1521 | "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", 1522 | "optional": true 1523 | }, 1524 | "node_modules/universalify": { 1525 | "version": "0.1.2", 1526 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 1527 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", 1528 | "engines": { 1529 | "node": ">= 4.0.0" 1530 | } 1531 | }, 1532 | "node_modules/urlpattern-polyfill": { 1533 | "version": "9.0.0", 1534 | "resolved": "https://registry.npmjs.org/urlpattern-polyfill/-/urlpattern-polyfill-9.0.0.tgz", 1535 | "integrity": "sha512-WHN8KDQblxd32odxeIgo83rdVDE2bvdkb86it7bMhYZwWKJz0+O0RK/eZiHYnM+zgt/U7hAHOlCQGfjjvSkw2g==" 1536 | }, 1537 | "node_modules/vary": { 1538 | "version": "1.1.2", 1539 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1540 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", 1541 | "engines": { 1542 | "node": ">= 0.8" 1543 | } 1544 | }, 1545 | "node_modules/webidl-conversions": { 1546 | "version": "3.0.1", 1547 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 1548 | "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" 1549 | }, 1550 | "node_modules/whatwg-url": { 1551 | "version": "5.0.0", 1552 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 1553 | "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", 1554 | "dependencies": { 1555 | "tr46": "~0.0.3", 1556 | "webidl-conversions": "^3.0.0" 1557 | } 1558 | }, 1559 | "node_modules/wrap-ansi": { 1560 | "version": "7.0.0", 1561 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1562 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1563 | "dependencies": { 1564 | "ansi-styles": "^4.0.0", 1565 | "string-width": "^4.1.0", 1566 | "strip-ansi": "^6.0.0" 1567 | }, 1568 | "engines": { 1569 | "node": ">=10" 1570 | }, 1571 | "funding": { 1572 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 1573 | } 1574 | }, 1575 | "node_modules/wrap-ansi/node_modules/ansi-styles": { 1576 | "version": "4.3.0", 1577 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1578 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1579 | "dependencies": { 1580 | "color-convert": "^2.0.1" 1581 | }, 1582 | "engines": { 1583 | "node": ">=8" 1584 | }, 1585 | "funding": { 1586 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1587 | } 1588 | }, 1589 | "node_modules/wrap-ansi/node_modules/color-convert": { 1590 | "version": "2.0.1", 1591 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1592 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1593 | "dependencies": { 1594 | "color-name": "~1.1.4" 1595 | }, 1596 | "engines": { 1597 | "node": ">=7.0.0" 1598 | } 1599 | }, 1600 | "node_modules/wrap-ansi/node_modules/color-name": { 1601 | "version": "1.1.4", 1602 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1603 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 1604 | }, 1605 | "node_modules/wrappy": { 1606 | "version": "1.0.2", 1607 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1608 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" 1609 | }, 1610 | "node_modules/ws": { 1611 | "version": "8.14.2", 1612 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.14.2.tgz", 1613 | "integrity": "sha512-wEBG1ftX4jcglPxgFCMJmZ2PLtSbJ2Peg6TmpJFTbe9GZYOQCDPdMYu/Tm0/bGZkw8paZnJY45J4K2PZrLYq8g==", 1614 | "engines": { 1615 | "node": ">=10.0.0" 1616 | }, 1617 | "peerDependencies": { 1618 | "bufferutil": "^4.0.1", 1619 | "utf-8-validate": ">=5.0.2" 1620 | }, 1621 | "peerDependenciesMeta": { 1622 | "bufferutil": { 1623 | "optional": true 1624 | }, 1625 | "utf-8-validate": { 1626 | "optional": true 1627 | } 1628 | } 1629 | }, 1630 | "node_modules/y18n": { 1631 | "version": "5.0.8", 1632 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1633 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1634 | "engines": { 1635 | "node": ">=10" 1636 | } 1637 | }, 1638 | "node_modules/yargs": { 1639 | "version": "17.7.2", 1640 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", 1641 | "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", 1642 | "dependencies": { 1643 | "cliui": "^8.0.1", 1644 | "escalade": "^3.1.1", 1645 | "get-caller-file": "^2.0.5", 1646 | "require-directory": "^2.1.1", 1647 | "string-width": "^4.2.3", 1648 | "y18n": "^5.0.5", 1649 | "yargs-parser": "^21.1.1" 1650 | }, 1651 | "engines": { 1652 | "node": ">=12" 1653 | } 1654 | }, 1655 | "node_modules/yargs-parser": { 1656 | "version": "21.1.1", 1657 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", 1658 | "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", 1659 | "engines": { 1660 | "node": ">=12" 1661 | } 1662 | }, 1663 | "node_modules/yauzl": { 1664 | "version": "2.10.0", 1665 | "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz", 1666 | "integrity": "sha512-p4a9I6X6nu6IhoGmBqAcbJy1mlC4j27vEPZX9F4L4/vZT3Lyq1VkFHw/V/PUcB9Buo+DG3iHkT0x3Qya58zc3g==", 1667 | "dependencies": { 1668 | "buffer-crc32": "~0.2.3", 1669 | "fd-slicer": "~1.1.0" 1670 | } 1671 | }, 1672 | "node_modules/ylru": { 1673 | "version": "1.3.2", 1674 | "resolved": "https://registry.npmjs.org/ylru/-/ylru-1.3.2.tgz", 1675 | "integrity": "sha512-RXRJzMiK6U2ye0BlGGZnmpwJDPgakn6aNQ0A7gHRbD4I0uvK4TW6UqkK1V0pp9jskjJBAXd3dRrbzWkqJ+6cxA==", 1676 | "engines": { 1677 | "node": ">= 4.0.0" 1678 | } 1679 | } 1680 | }, 1681 | "dependencies": { 1682 | "@babel/code-frame": { 1683 | "version": "7.23.5", 1684 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz", 1685 | "integrity": "sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA==", 1686 | "requires": { 1687 | "@babel/highlight": "^7.23.4", 1688 | "chalk": "^2.4.2" 1689 | } 1690 | }, 1691 | "@babel/helper-validator-identifier": { 1692 | "version": "7.22.20", 1693 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", 1694 | "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==" 1695 | }, 1696 | "@babel/highlight": { 1697 | "version": "7.23.4", 1698 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz", 1699 | "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==", 1700 | "requires": { 1701 | "@babel/helper-validator-identifier": "^7.22.20", 1702 | "chalk": "^2.4.2", 1703 | "js-tokens": "^4.0.0" 1704 | } 1705 | }, 1706 | "@koa/router": { 1707 | "version": "12.0.1", 1708 | "resolved": "https://registry.npmjs.org/@koa/router/-/router-12.0.1.tgz", 1709 | "integrity": "sha512-ribfPYfHb+Uw3b27Eiw6NPqjhIhTpVFzEWLwyc/1Xp+DCdwRRyIlAUODX+9bPARF6aQtUu1+/PHzdNvRzcs/+Q==", 1710 | "requires": { 1711 | "debug": "^4.3.4", 1712 | "http-errors": "^2.0.0", 1713 | "koa-compose": "^4.1.0", 1714 | "methods": "^1.1.2", 1715 | "path-to-regexp": "^6.2.1" 1716 | }, 1717 | "dependencies": { 1718 | "http-errors": { 1719 | "version": "2.0.0", 1720 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 1721 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 1722 | "requires": { 1723 | "depd": "2.0.0", 1724 | "inherits": "2.0.4", 1725 | "setprototypeof": "1.2.0", 1726 | "statuses": "2.0.1", 1727 | "toidentifier": "1.0.1" 1728 | } 1729 | }, 1730 | "statuses": { 1731 | "version": "2.0.1", 1732 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 1733 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==" 1734 | } 1735 | } 1736 | }, 1737 | "@pdf-lib/standard-fonts": { 1738 | "version": "1.0.0", 1739 | "resolved": "https://registry.npmjs.org/@pdf-lib/standard-fonts/-/standard-fonts-1.0.0.tgz", 1740 | "integrity": "sha512-hU30BK9IUN/su0Mn9VdlVKsWBS6GyhVfqjwl1FjZN4TxP6cCw0jP2w7V3Hf5uX7M0AZJ16vey9yE0ny7Sa59ZA==", 1741 | "requires": { 1742 | "pako": "^1.0.6" 1743 | } 1744 | }, 1745 | "@pdf-lib/upng": { 1746 | "version": "1.0.1", 1747 | "resolved": "https://registry.npmjs.org/@pdf-lib/upng/-/upng-1.0.1.tgz", 1748 | "integrity": "sha512-dQK2FUMQtowVP00mtIksrlZhdFXQZPC+taih1q4CvPZ5vqdxR/LKBaFg0oAfzd1GlHZXXSPdQfzQnt+ViGvEIQ==", 1749 | "requires": { 1750 | "pako": "^1.0.10" 1751 | } 1752 | }, 1753 | "@puppeteer/browsers": { 1754 | "version": "1.9.0", 1755 | "resolved": "https://registry.npmjs.org/@puppeteer/browsers/-/browsers-1.9.0.tgz", 1756 | "integrity": "sha512-QwguOLy44YBGC8vuPP2nmpX4MUN2FzWbsnvZJtiCzecU3lHmVZkaC1tq6rToi9a200m8RzlVtDyxCS0UIDrxUg==", 1757 | "requires": { 1758 | "debug": "4.3.4", 1759 | "extract-zip": "2.0.1", 1760 | "progress": "2.0.3", 1761 | "proxy-agent": "6.3.1", 1762 | "tar-fs": "3.0.4", 1763 | "unbzip2-stream": "1.4.3", 1764 | "yargs": "17.7.2" 1765 | } 1766 | }, 1767 | "@tootallnate/quickjs-emscripten": { 1768 | "version": "0.23.0", 1769 | "resolved": "https://registry.npmjs.org/@tootallnate/quickjs-emscripten/-/quickjs-emscripten-0.23.0.tgz", 1770 | "integrity": "sha512-C5Mc6rdnsaJDjO3UpGW/CQTHtCKaYlScZTly4JIu97Jxo/odCiH0ITnDXSJPTOrEKk/ycSZ0AOgTmkDtkOsvIA==" 1771 | }, 1772 | "@types/node": { 1773 | "version": "20.10.4", 1774 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.10.4.tgz", 1775 | "integrity": "sha512-D08YG6rr8X90YB56tSIuBaddy/UXAA9RKJoFvrsnogAum/0pmjkgi4+2nx96A330FmioegBWmEYQ+syqCFaveg==", 1776 | "optional": true, 1777 | "requires": { 1778 | "undici-types": "~5.26.4" 1779 | } 1780 | }, 1781 | "@types/yauzl": { 1782 | "version": "2.10.3", 1783 | "resolved": "https://registry.npmjs.org/@types/yauzl/-/yauzl-2.10.3.tgz", 1784 | "integrity": "sha512-oJoftv0LSuaDZE3Le4DbKX+KS9G36NzOeSap90UIK0yMA/NhKJhqlSGtNDORNRaIbQfzjXDrQa0ytJ6mNRGz/Q==", 1785 | "optional": true, 1786 | "requires": { 1787 | "@types/node": "*" 1788 | } 1789 | }, 1790 | "accepts": { 1791 | "version": "1.3.8", 1792 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 1793 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 1794 | "requires": { 1795 | "mime-types": "~2.1.34", 1796 | "negotiator": "0.6.3" 1797 | } 1798 | }, 1799 | "agent-base": { 1800 | "version": "7.1.0", 1801 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.0.tgz", 1802 | "integrity": "sha512-o/zjMZRhJxny7OyEF+Op8X+efiELC7k7yOjMzgfzVqOzXqkBkWI79YoTdOtsuWd5BWhAGAuOY/Xa6xpiaWXiNg==", 1803 | "requires": { 1804 | "debug": "^4.3.4" 1805 | } 1806 | }, 1807 | "ansi-regex": { 1808 | "version": "5.0.1", 1809 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1810 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==" 1811 | }, 1812 | "ansi-styles": { 1813 | "version": "3.2.1", 1814 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1815 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1816 | "requires": { 1817 | "color-convert": "^1.9.0" 1818 | } 1819 | }, 1820 | "argparse": { 1821 | "version": "2.0.1", 1822 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1823 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==" 1824 | }, 1825 | "ast-types": { 1826 | "version": "0.13.4", 1827 | "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.13.4.tgz", 1828 | "integrity": "sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w==", 1829 | "requires": { 1830 | "tslib": "^2.0.1" 1831 | } 1832 | }, 1833 | "asynckit": { 1834 | "version": "0.4.0", 1835 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 1836 | "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" 1837 | }, 1838 | "axios": { 1839 | "version": "1.6.7", 1840 | "resolved": "https://registry.npmjs.org/axios/-/axios-1.6.7.tgz", 1841 | "integrity": "sha512-/hDJGff6/c7u0hDkvkGxR/oy6CbCs8ziCsC7SqmhjfozqiJGc8Z11wrv9z9lYfY4K8l+H9TpjcMDX0xOZmx+RA==", 1842 | "requires": { 1843 | "follow-redirects": "^1.15.4", 1844 | "form-data": "^4.0.0", 1845 | "proxy-from-env": "^1.1.0" 1846 | } 1847 | }, 1848 | "b4a": { 1849 | "version": "1.6.4", 1850 | "resolved": "https://registry.npmjs.org/b4a/-/b4a-1.6.4.tgz", 1851 | "integrity": "sha512-fpWrvyVHEKyeEvbKZTVOeZF3VSKKWtJxFIxX/jaVPf+cLbGUSitjb49pHLqPV2BUNNZ0LcoeEGfE/YCpyDYHIw==" 1852 | }, 1853 | "base64-js": { 1854 | "version": "1.5.1", 1855 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 1856 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==" 1857 | }, 1858 | "basic-ftp": { 1859 | "version": "5.0.3", 1860 | "resolved": "https://registry.npmjs.org/basic-ftp/-/basic-ftp-5.0.3.tgz", 1861 | "integrity": "sha512-QHX8HLlncOLpy54mh+k/sWIFd0ThmRqwe9ZjELybGZK+tZ8rUb9VO0saKJUROTbE+KhzDUT7xziGpGrW8Kmd+g==" 1862 | }, 1863 | "buffer": { 1864 | "version": "5.7.1", 1865 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", 1866 | "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", 1867 | "requires": { 1868 | "base64-js": "^1.3.1", 1869 | "ieee754": "^1.1.13" 1870 | } 1871 | }, 1872 | "buffer-crc32": { 1873 | "version": "0.2.13", 1874 | "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", 1875 | "integrity": "sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==" 1876 | }, 1877 | "cache-content-type": { 1878 | "version": "1.0.1", 1879 | "resolved": "https://registry.npmjs.org/cache-content-type/-/cache-content-type-1.0.1.tgz", 1880 | "integrity": "sha512-IKufZ1o4Ut42YUrZSo8+qnMTrFuKkvyoLXUywKz9GJ5BrhOFGhLdkx9sG4KAnVvbY6kEcSFjLQul+DVmBm2bgA==", 1881 | "requires": { 1882 | "mime-types": "^2.1.18", 1883 | "ylru": "^1.2.0" 1884 | } 1885 | }, 1886 | "callsites": { 1887 | "version": "3.1.0", 1888 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1889 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==" 1890 | }, 1891 | "chalk": { 1892 | "version": "2.4.2", 1893 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1894 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1895 | "requires": { 1896 | "ansi-styles": "^3.2.1", 1897 | "escape-string-regexp": "^1.0.5", 1898 | "supports-color": "^5.3.0" 1899 | } 1900 | }, 1901 | "chromium-bidi": { 1902 | "version": "0.5.1", 1903 | "resolved": "https://registry.npmjs.org/chromium-bidi/-/chromium-bidi-0.5.1.tgz", 1904 | "integrity": "sha512-dcCqOgq9fHKExc2R4JZs/oKbOghWpUNFAJODS8WKRtLhp3avtIH5UDCBrutdqZdh3pARogH8y1ObXm87emwb3g==", 1905 | "requires": { 1906 | "mitt": "3.0.1", 1907 | "urlpattern-polyfill": "9.0.0" 1908 | } 1909 | }, 1910 | "cliui": { 1911 | "version": "8.0.1", 1912 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", 1913 | "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", 1914 | "requires": { 1915 | "string-width": "^4.2.0", 1916 | "strip-ansi": "^6.0.1", 1917 | "wrap-ansi": "^7.0.0" 1918 | } 1919 | }, 1920 | "co": { 1921 | "version": "4.6.0", 1922 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 1923 | "integrity": "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==" 1924 | }, 1925 | "color-convert": { 1926 | "version": "1.9.3", 1927 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1928 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1929 | "requires": { 1930 | "color-name": "1.1.3" 1931 | } 1932 | }, 1933 | "color-name": { 1934 | "version": "1.1.3", 1935 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1936 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==" 1937 | }, 1938 | "combined-stream": { 1939 | "version": "1.0.8", 1940 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 1941 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 1942 | "requires": { 1943 | "delayed-stream": "~1.0.0" 1944 | } 1945 | }, 1946 | "content-disposition": { 1947 | "version": "0.5.4", 1948 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 1949 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 1950 | "requires": { 1951 | "safe-buffer": "5.2.1" 1952 | } 1953 | }, 1954 | "content-type": { 1955 | "version": "1.0.5", 1956 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 1957 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==" 1958 | }, 1959 | "cookies": { 1960 | "version": "0.9.1", 1961 | "resolved": "https://registry.npmjs.org/cookies/-/cookies-0.9.1.tgz", 1962 | "integrity": "sha512-TG2hpqe4ELx54QER/S3HQ9SRVnQnGBtKUz5bLQWtYAQ+o6GpgMs6sYUvaiJjVxb+UXwhRhAEP3m7LbsIZ77Hmw==", 1963 | "requires": { 1964 | "depd": "~2.0.0", 1965 | "keygrip": "~1.1.0" 1966 | } 1967 | }, 1968 | "cosmiconfig": { 1969 | "version": "8.3.6", 1970 | "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-8.3.6.tgz", 1971 | "integrity": "sha512-kcZ6+W5QzcJ3P1Mt+83OUv/oHFqZHIx8DuxG6eZ5RGMERoLqp4BuGjhHLYGK+Kf5XVkQvqBSmAy/nGWN3qDgEA==", 1972 | "requires": { 1973 | "import-fresh": "^3.3.0", 1974 | "js-yaml": "^4.1.0", 1975 | "parse-json": "^5.2.0", 1976 | "path-type": "^4.0.0" 1977 | } 1978 | }, 1979 | "cross-fetch": { 1980 | "version": "4.0.0", 1981 | "resolved": "https://registry.npmjs.org/cross-fetch/-/cross-fetch-4.0.0.tgz", 1982 | "integrity": "sha512-e4a5N8lVvuLgAWgnCrLr2PP0YyDOTHa9H/Rj54dirp61qXnNq46m82bRhNqIA5VccJtWBvPTFRV3TtvHUKPB1g==", 1983 | "requires": { 1984 | "node-fetch": "^2.6.12" 1985 | } 1986 | }, 1987 | "data-uri-to-buffer": { 1988 | "version": "6.0.1", 1989 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-6.0.1.tgz", 1990 | "integrity": "sha512-MZd3VlchQkp8rdend6vrx7MmVDJzSNTBvghvKjirLkD+WTChA3KUf0jkE68Q4UyctNqI11zZO9/x2Yx+ub5Cvg==" 1991 | }, 1992 | "debug": { 1993 | "version": "4.3.4", 1994 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1995 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1996 | "requires": { 1997 | "ms": "2.1.2" 1998 | } 1999 | }, 2000 | "deep-equal": { 2001 | "version": "1.0.1", 2002 | "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.0.1.tgz", 2003 | "integrity": "sha512-bHtC0iYvWhyaTzvV3CZgPeZQqCOBGyGsVV7v4eevpdkLHfiSrXUdBG+qAuSz4RI70sszvjQ1QSZ98An1yNwpSw==" 2004 | }, 2005 | "degenerator": { 2006 | "version": "5.0.1", 2007 | "resolved": "https://registry.npmjs.org/degenerator/-/degenerator-5.0.1.tgz", 2008 | "integrity": "sha512-TllpMR/t0M5sqCXfj85i4XaAzxmS5tVA16dqvdkMwGmzI+dXLXnw3J+3Vdv7VKw+ThlTMboK6i9rnZ6Nntj5CQ==", 2009 | "requires": { 2010 | "ast-types": "^0.13.4", 2011 | "escodegen": "^2.1.0", 2012 | "esprima": "^4.0.1" 2013 | } 2014 | }, 2015 | "delayed-stream": { 2016 | "version": "1.0.0", 2017 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 2018 | "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==" 2019 | }, 2020 | "delegates": { 2021 | "version": "1.0.0", 2022 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 2023 | "integrity": "sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ==" 2024 | }, 2025 | "depd": { 2026 | "version": "2.0.0", 2027 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 2028 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==" 2029 | }, 2030 | "destroy": { 2031 | "version": "1.2.0", 2032 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 2033 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==" 2034 | }, 2035 | "devtools-protocol": { 2036 | "version": "0.0.1203626", 2037 | "resolved": "https://registry.npmjs.org/devtools-protocol/-/devtools-protocol-0.0.1203626.tgz", 2038 | "integrity": "sha512-nEzHZteIUZfGCZtTiS1fRpC8UZmsfD1SiyPvaUNvS13dvKf666OAm8YTi0+Ca3n1nLEyu49Cy4+dPWpaHFJk9g==" 2039 | }, 2040 | "ee-first": { 2041 | "version": "1.1.1", 2042 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 2043 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 2044 | }, 2045 | "emoji-regex": { 2046 | "version": "8.0.0", 2047 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2048 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 2049 | }, 2050 | "encodeurl": { 2051 | "version": "1.0.2", 2052 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 2053 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==" 2054 | }, 2055 | "end-of-stream": { 2056 | "version": "1.4.4", 2057 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 2058 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 2059 | "requires": { 2060 | "once": "^1.4.0" 2061 | } 2062 | }, 2063 | "error-ex": { 2064 | "version": "1.3.2", 2065 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 2066 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 2067 | "requires": { 2068 | "is-arrayish": "^0.2.1" 2069 | } 2070 | }, 2071 | "escalade": { 2072 | "version": "3.1.1", 2073 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 2074 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==" 2075 | }, 2076 | "escape-html": { 2077 | "version": "1.0.3", 2078 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 2079 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 2080 | }, 2081 | "escape-string-regexp": { 2082 | "version": "1.0.5", 2083 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 2084 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==" 2085 | }, 2086 | "escodegen": { 2087 | "version": "2.1.0", 2088 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-2.1.0.tgz", 2089 | "integrity": "sha512-2NlIDTwUWJN0mRPQOdtQBzbUHvdGY2P1VXSyU83Q3xKxM7WHX2Ql8dKq782Q9TgQUNOLEzEYu9bzLNj1q88I5w==", 2090 | "requires": { 2091 | "esprima": "^4.0.1", 2092 | "estraverse": "^5.2.0", 2093 | "esutils": "^2.0.2", 2094 | "source-map": "~0.6.1" 2095 | } 2096 | }, 2097 | "esprima": { 2098 | "version": "4.0.1", 2099 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 2100 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" 2101 | }, 2102 | "estraverse": { 2103 | "version": "5.3.0", 2104 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2105 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==" 2106 | }, 2107 | "esutils": { 2108 | "version": "2.0.3", 2109 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2110 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==" 2111 | }, 2112 | "extract-zip": { 2113 | "version": "2.0.1", 2114 | "resolved": "https://registry.npmjs.org/extract-zip/-/extract-zip-2.0.1.tgz", 2115 | "integrity": "sha512-GDhU9ntwuKyGXdZBUgTIe+vXnWj0fppUEtMDL0+idd5Sta8TGpHssn/eusA9mrPr9qNDym6SxAYZjNvCn/9RBg==", 2116 | "requires": { 2117 | "@types/yauzl": "^2.9.1", 2118 | "debug": "^4.1.1", 2119 | "get-stream": "^5.1.0", 2120 | "yauzl": "^2.10.0" 2121 | } 2122 | }, 2123 | "fast-fifo": { 2124 | "version": "1.3.2", 2125 | "resolved": "https://registry.npmjs.org/fast-fifo/-/fast-fifo-1.3.2.tgz", 2126 | "integrity": "sha512-/d9sfos4yxzpwkDkuN7k2SqFKtYNmCTzgfEpz82x34IM9/zc8KGxQoXg1liNC/izpRM/MBdt44Nmx41ZWqk+FQ==" 2127 | }, 2128 | "fd-slicer": { 2129 | "version": "1.1.0", 2130 | "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", 2131 | "integrity": "sha512-cE1qsB/VwyQozZ+q1dGxR8LBYNZeofhEdUNGSMbQD3Gw2lAzX9Zb3uIU6Ebc/Fmyjo9AWWfnn0AUCHqtevs/8g==", 2132 | "requires": { 2133 | "pend": "~1.2.0" 2134 | } 2135 | }, 2136 | "follow-redirects": { 2137 | "version": "1.15.5", 2138 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.5.tgz", 2139 | "integrity": "sha512-vSFWUON1B+yAw1VN4xMfxgn5fTUiaOzAJCKBwIIgT/+7CuGy9+r+5gITvP62j3RmaD5Ph65UaERdOSRGUzZtgw==" 2140 | }, 2141 | "form-data": { 2142 | "version": "4.0.0", 2143 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", 2144 | "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", 2145 | "requires": { 2146 | "asynckit": "^0.4.0", 2147 | "combined-stream": "^1.0.8", 2148 | "mime-types": "^2.1.12" 2149 | } 2150 | }, 2151 | "fresh": { 2152 | "version": "0.5.2", 2153 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 2154 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==" 2155 | }, 2156 | "fs-extra": { 2157 | "version": "8.1.0", 2158 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", 2159 | "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", 2160 | "requires": { 2161 | "graceful-fs": "^4.2.0", 2162 | "jsonfile": "^4.0.0", 2163 | "universalify": "^0.1.0" 2164 | } 2165 | }, 2166 | "get-caller-file": { 2167 | "version": "2.0.5", 2168 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2169 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==" 2170 | }, 2171 | "get-stream": { 2172 | "version": "5.2.0", 2173 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", 2174 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", 2175 | "requires": { 2176 | "pump": "^3.0.0" 2177 | } 2178 | }, 2179 | "get-uri": { 2180 | "version": "6.0.2", 2181 | "resolved": "https://registry.npmjs.org/get-uri/-/get-uri-6.0.2.tgz", 2182 | "integrity": "sha512-5KLucCJobh8vBY1K07EFV4+cPZH3mrV9YeAruUseCQKHB58SGjjT2l9/eA9LD082IiuMjSlFJEcdJ27TXvbZNw==", 2183 | "requires": { 2184 | "basic-ftp": "^5.0.2", 2185 | "data-uri-to-buffer": "^6.0.0", 2186 | "debug": "^4.3.4", 2187 | "fs-extra": "^8.1.0" 2188 | } 2189 | }, 2190 | "graceful-fs": { 2191 | "version": "4.2.11", 2192 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 2193 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==" 2194 | }, 2195 | "has-flag": { 2196 | "version": "3.0.0", 2197 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2198 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==" 2199 | }, 2200 | "has-symbols": { 2201 | "version": "1.0.3", 2202 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 2203 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==" 2204 | }, 2205 | "has-tostringtag": { 2206 | "version": "1.0.2", 2207 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", 2208 | "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", 2209 | "requires": { 2210 | "has-symbols": "^1.0.3" 2211 | } 2212 | }, 2213 | "http-assert": { 2214 | "version": "1.5.0", 2215 | "resolved": "https://registry.npmjs.org/http-assert/-/http-assert-1.5.0.tgz", 2216 | "integrity": "sha512-uPpH7OKX4H25hBmU6G1jWNaqJGpTXxey+YOUizJUAgu0AjLUeC8D73hTrhvDS5D+GJN1DN1+hhc/eF/wpxtp0w==", 2217 | "requires": { 2218 | "deep-equal": "~1.0.1", 2219 | "http-errors": "~1.8.0" 2220 | } 2221 | }, 2222 | "http-errors": { 2223 | "version": "1.8.1", 2224 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz", 2225 | "integrity": "sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g==", 2226 | "requires": { 2227 | "depd": "~1.1.2", 2228 | "inherits": "2.0.4", 2229 | "setprototypeof": "1.2.0", 2230 | "statuses": ">= 1.5.0 < 2", 2231 | "toidentifier": "1.0.1" 2232 | }, 2233 | "dependencies": { 2234 | "depd": { 2235 | "version": "1.1.2", 2236 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 2237 | "integrity": "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==" 2238 | } 2239 | } 2240 | }, 2241 | "http-proxy-agent": { 2242 | "version": "7.0.0", 2243 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.0.tgz", 2244 | "integrity": "sha512-+ZT+iBxVUQ1asugqnD6oWoRiS25AkjNfG085dKJGtGxkdwLQrMKU5wJr2bOOFAXzKcTuqq+7fZlTMgG3SRfIYQ==", 2245 | "requires": { 2246 | "agent-base": "^7.1.0", 2247 | "debug": "^4.3.4" 2248 | } 2249 | }, 2250 | "https-proxy-agent": { 2251 | "version": "7.0.2", 2252 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-7.0.2.tgz", 2253 | "integrity": "sha512-NmLNjm6ucYwtcUmL7JQC1ZQ57LmHP4lT15FQ8D61nak1rO6DH+fz5qNK2Ap5UN4ZapYICE3/0KodcLYSPsPbaA==", 2254 | "requires": { 2255 | "agent-base": "^7.0.2", 2256 | "debug": "4" 2257 | } 2258 | }, 2259 | "ieee754": { 2260 | "version": "1.2.1", 2261 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 2262 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==" 2263 | }, 2264 | "import-fresh": { 2265 | "version": "3.3.0", 2266 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2267 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2268 | "requires": { 2269 | "parent-module": "^1.0.0", 2270 | "resolve-from": "^4.0.0" 2271 | } 2272 | }, 2273 | "inherits": { 2274 | "version": "2.0.4", 2275 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2276 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 2277 | }, 2278 | "ip": { 2279 | "version": "1.1.8", 2280 | "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.8.tgz", 2281 | "integrity": "sha512-PuExPYUiu6qMBQb4l06ecm6T6ujzhmh+MeJcW9wa89PoAz5pvd4zPgN5WJV104mb6S2T1AwNIAaB70JNrLQWhg==" 2282 | }, 2283 | "is-arrayish": { 2284 | "version": "0.2.1", 2285 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 2286 | "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==" 2287 | }, 2288 | "is-fullwidth-code-point": { 2289 | "version": "3.0.0", 2290 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2291 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" 2292 | }, 2293 | "is-generator-function": { 2294 | "version": "1.0.10", 2295 | "resolved": "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz", 2296 | "integrity": "sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==", 2297 | "requires": { 2298 | "has-tostringtag": "^1.0.0" 2299 | } 2300 | }, 2301 | "js-tokens": { 2302 | "version": "4.0.0", 2303 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2304 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 2305 | }, 2306 | "js-yaml": { 2307 | "version": "4.1.0", 2308 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2309 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2310 | "requires": { 2311 | "argparse": "^2.0.1" 2312 | } 2313 | }, 2314 | "json-parse-even-better-errors": { 2315 | "version": "2.3.1", 2316 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", 2317 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==" 2318 | }, 2319 | "jsonfile": { 2320 | "version": "4.0.0", 2321 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 2322 | "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==", 2323 | "requires": { 2324 | "graceful-fs": "^4.1.6" 2325 | } 2326 | }, 2327 | "keygrip": { 2328 | "version": "1.1.0", 2329 | "resolved": "https://registry.npmjs.org/keygrip/-/keygrip-1.1.0.tgz", 2330 | "integrity": "sha512-iYSchDJ+liQ8iwbSI2QqsQOvqv58eJCEanyJPJi+Khyu8smkcKSFUCbPwzFcL7YVtZ6eONjqRX/38caJ7QjRAQ==", 2331 | "requires": { 2332 | "tsscmp": "1.0.6" 2333 | } 2334 | }, 2335 | "koa": { 2336 | "version": "2.15.0", 2337 | "resolved": "https://registry.npmjs.org/koa/-/koa-2.15.0.tgz", 2338 | "integrity": "sha512-KEL/vU1knsoUvfP4MC4/GthpQrY/p6dzwaaGI6Rt4NQuFqkw3qrvsdYF5pz3wOfi7IGTvMPHC9aZIcUKYFNxsw==", 2339 | "requires": { 2340 | "accepts": "^1.3.5", 2341 | "cache-content-type": "^1.0.0", 2342 | "content-disposition": "~0.5.2", 2343 | "content-type": "^1.0.4", 2344 | "cookies": "~0.9.0", 2345 | "debug": "^4.3.2", 2346 | "delegates": "^1.0.0", 2347 | "depd": "^2.0.0", 2348 | "destroy": "^1.0.4", 2349 | "encodeurl": "^1.0.2", 2350 | "escape-html": "^1.0.3", 2351 | "fresh": "~0.5.2", 2352 | "http-assert": "^1.3.0", 2353 | "http-errors": "^1.6.3", 2354 | "is-generator-function": "^1.0.7", 2355 | "koa-compose": "^4.1.0", 2356 | "koa-convert": "^2.0.0", 2357 | "on-finished": "^2.3.0", 2358 | "only": "~0.0.2", 2359 | "parseurl": "^1.3.2", 2360 | "statuses": "^1.5.0", 2361 | "type-is": "^1.6.16", 2362 | "vary": "^1.1.2" 2363 | } 2364 | }, 2365 | "koa-compose": { 2366 | "version": "4.1.0", 2367 | "resolved": "https://registry.npmjs.org/koa-compose/-/koa-compose-4.1.0.tgz", 2368 | "integrity": "sha512-8ODW8TrDuMYvXRwra/Kh7/rJo9BtOfPc6qO8eAfC80CnCvSjSl0bkRM24X6/XBBEyj0v1nRUQ1LyOy3dbqOWXw==" 2369 | }, 2370 | "koa-convert": { 2371 | "version": "2.0.0", 2372 | "resolved": "https://registry.npmjs.org/koa-convert/-/koa-convert-2.0.0.tgz", 2373 | "integrity": "sha512-asOvN6bFlSnxewce2e/DK3p4tltyfC4VM7ZwuTuepI7dEQVcvpyFuBcEARu1+Hxg8DIwytce2n7jrZtRlPrARA==", 2374 | "requires": { 2375 | "co": "^4.6.0", 2376 | "koa-compose": "^4.1.0" 2377 | } 2378 | }, 2379 | "lines-and-columns": { 2380 | "version": "1.2.4", 2381 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", 2382 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==" 2383 | }, 2384 | "lru-cache": { 2385 | "version": "7.18.3", 2386 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.18.3.tgz", 2387 | "integrity": "sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA==" 2388 | }, 2389 | "media-typer": { 2390 | "version": "0.3.0", 2391 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 2392 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==" 2393 | }, 2394 | "methods": { 2395 | "version": "1.1.2", 2396 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 2397 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==" 2398 | }, 2399 | "mime-db": { 2400 | "version": "1.52.0", 2401 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 2402 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" 2403 | }, 2404 | "mime-types": { 2405 | "version": "2.1.35", 2406 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 2407 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 2408 | "requires": { 2409 | "mime-db": "1.52.0" 2410 | } 2411 | }, 2412 | "mitt": { 2413 | "version": "3.0.1", 2414 | "resolved": "https://registry.npmjs.org/mitt/-/mitt-3.0.1.tgz", 2415 | "integrity": "sha512-vKivATfr97l2/QBCYAkXYDbrIWPM2IIKEl7YPhjCvKlG3kE2gm+uBo6nEXK3M5/Ffh/FLpKExzOQ3JJoJGFKBw==" 2416 | }, 2417 | "mkdirp-classic": { 2418 | "version": "0.5.3", 2419 | "resolved": "https://registry.npmjs.org/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz", 2420 | "integrity": "sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A==" 2421 | }, 2422 | "ms": { 2423 | "version": "2.1.2", 2424 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2425 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2426 | }, 2427 | "negotiator": { 2428 | "version": "0.6.3", 2429 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 2430 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==" 2431 | }, 2432 | "netmask": { 2433 | "version": "2.0.2", 2434 | "resolved": "https://registry.npmjs.org/netmask/-/netmask-2.0.2.tgz", 2435 | "integrity": "sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg==" 2436 | }, 2437 | "node-fetch": { 2438 | "version": "2.7.0", 2439 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.7.0.tgz", 2440 | "integrity": "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==", 2441 | "requires": { 2442 | "whatwg-url": "^5.0.0" 2443 | } 2444 | }, 2445 | "on-finished": { 2446 | "version": "2.4.1", 2447 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 2448 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 2449 | "requires": { 2450 | "ee-first": "1.1.1" 2451 | } 2452 | }, 2453 | "once": { 2454 | "version": "1.4.0", 2455 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2456 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2457 | "requires": { 2458 | "wrappy": "1" 2459 | } 2460 | }, 2461 | "only": { 2462 | "version": "0.0.2", 2463 | "resolved": "https://registry.npmjs.org/only/-/only-0.0.2.tgz", 2464 | "integrity": "sha512-Fvw+Jemq5fjjyWz6CpKx6w9s7xxqo3+JCyM0WXWeCSOboZ8ABkyvP8ID4CZuChA/wxSx+XSJmdOm8rGVyJ1hdQ==" 2465 | }, 2466 | "pac-proxy-agent": { 2467 | "version": "7.0.1", 2468 | "resolved": "https://registry.npmjs.org/pac-proxy-agent/-/pac-proxy-agent-7.0.1.tgz", 2469 | "integrity": "sha512-ASV8yU4LLKBAjqIPMbrgtaKIvxQri/yh2OpI+S6hVa9JRkUI3Y3NPFbfngDtY7oFtSMD3w31Xns89mDa3Feo5A==", 2470 | "requires": { 2471 | "@tootallnate/quickjs-emscripten": "^0.23.0", 2472 | "agent-base": "^7.0.2", 2473 | "debug": "^4.3.4", 2474 | "get-uri": "^6.0.1", 2475 | "http-proxy-agent": "^7.0.0", 2476 | "https-proxy-agent": "^7.0.2", 2477 | "pac-resolver": "^7.0.0", 2478 | "socks-proxy-agent": "^8.0.2" 2479 | } 2480 | }, 2481 | "pac-resolver": { 2482 | "version": "7.0.0", 2483 | "resolved": "https://registry.npmjs.org/pac-resolver/-/pac-resolver-7.0.0.tgz", 2484 | "integrity": "sha512-Fd9lT9vJbHYRACT8OhCbZBbxr6KRSawSovFpy8nDGshaK99S/EBhVIHp9+crhxrsZOuvLpgL1n23iyPg6Rl2hg==", 2485 | "requires": { 2486 | "degenerator": "^5.0.0", 2487 | "ip": "^1.1.8", 2488 | "netmask": "^2.0.2" 2489 | } 2490 | }, 2491 | "pako": { 2492 | "version": "1.0.11", 2493 | "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.11.tgz", 2494 | "integrity": "sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==" 2495 | }, 2496 | "parent-module": { 2497 | "version": "1.0.1", 2498 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2499 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2500 | "requires": { 2501 | "callsites": "^3.0.0" 2502 | } 2503 | }, 2504 | "parse-json": { 2505 | "version": "5.2.0", 2506 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", 2507 | "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", 2508 | "requires": { 2509 | "@babel/code-frame": "^7.0.0", 2510 | "error-ex": "^1.3.1", 2511 | "json-parse-even-better-errors": "^2.3.0", 2512 | "lines-and-columns": "^1.1.6" 2513 | } 2514 | }, 2515 | "parseurl": { 2516 | "version": "1.3.3", 2517 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 2518 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 2519 | }, 2520 | "path-to-regexp": { 2521 | "version": "6.2.1", 2522 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz", 2523 | "integrity": "sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw==" 2524 | }, 2525 | "path-type": { 2526 | "version": "4.0.0", 2527 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 2528 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==" 2529 | }, 2530 | "pdf-lib": { 2531 | "version": "1.17.1", 2532 | "resolved": "https://registry.npmjs.org/pdf-lib/-/pdf-lib-1.17.1.tgz", 2533 | "integrity": "sha512-V/mpyJAoTsN4cnP31vc0wfNA1+p20evqqnap0KLoRUN0Yk/p3wN52DOEsL4oBFcLdb76hlpKPtzJIgo67j/XLw==", 2534 | "requires": { 2535 | "@pdf-lib/standard-fonts": "^1.0.0", 2536 | "@pdf-lib/upng": "^1.0.1", 2537 | "pako": "^1.0.11", 2538 | "tslib": "^1.11.1" 2539 | }, 2540 | "dependencies": { 2541 | "tslib": { 2542 | "version": "1.14.1", 2543 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 2544 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==" 2545 | } 2546 | } 2547 | }, 2548 | "pend": { 2549 | "version": "1.2.0", 2550 | "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", 2551 | "integrity": "sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg==" 2552 | }, 2553 | "progress": { 2554 | "version": "2.0.3", 2555 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2556 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==" 2557 | }, 2558 | "proxy-agent": { 2559 | "version": "6.3.1", 2560 | "resolved": "https://registry.npmjs.org/proxy-agent/-/proxy-agent-6.3.1.tgz", 2561 | "integrity": "sha512-Rb5RVBy1iyqOtNl15Cw/llpeLH8bsb37gM1FUfKQ+Wck6xHlbAhWGUFiTRHtkjqGTA5pSHz6+0hrPW/oECihPQ==", 2562 | "requires": { 2563 | "agent-base": "^7.0.2", 2564 | "debug": "^4.3.4", 2565 | "http-proxy-agent": "^7.0.0", 2566 | "https-proxy-agent": "^7.0.2", 2567 | "lru-cache": "^7.14.1", 2568 | "pac-proxy-agent": "^7.0.1", 2569 | "proxy-from-env": "^1.1.0", 2570 | "socks-proxy-agent": "^8.0.2" 2571 | } 2572 | }, 2573 | "proxy-from-env": { 2574 | "version": "1.1.0", 2575 | "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", 2576 | "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" 2577 | }, 2578 | "pump": { 2579 | "version": "3.0.0", 2580 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 2581 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 2582 | "requires": { 2583 | "end-of-stream": "^1.1.0", 2584 | "once": "^1.3.1" 2585 | } 2586 | }, 2587 | "puppeteer": { 2588 | "version": "21.6.0", 2589 | "resolved": "https://registry.npmjs.org/puppeteer/-/puppeteer-21.6.0.tgz", 2590 | "integrity": "sha512-u6JhSF7xaPYZ2gd3tvhYI8MwVAjLc3Cazj7UWvMV95A07/y7cIjBwYUiMU9/jm4z0FSUORriLX/RZRaiASNWPw==", 2591 | "requires": { 2592 | "@puppeteer/browsers": "1.9.0", 2593 | "cosmiconfig": "8.3.6", 2594 | "puppeteer-core": "21.6.0" 2595 | } 2596 | }, 2597 | "puppeteer-core": { 2598 | "version": "21.6.0", 2599 | "resolved": "https://registry.npmjs.org/puppeteer-core/-/puppeteer-core-21.6.0.tgz", 2600 | "integrity": "sha512-1vrzbp2E1JpBwtIIrriWkN+A0afUxkqRuFTC3uASc5ql6iuK9ppOdIU/CPGKwOyB4YFIQ16mRbK0PK19mbXnaQ==", 2601 | "requires": { 2602 | "@puppeteer/browsers": "1.9.0", 2603 | "chromium-bidi": "0.5.1", 2604 | "cross-fetch": "4.0.0", 2605 | "debug": "4.3.4", 2606 | "devtools-protocol": "0.0.1203626", 2607 | "ws": "8.14.2" 2608 | } 2609 | }, 2610 | "queue-tick": { 2611 | "version": "1.0.1", 2612 | "resolved": "https://registry.npmjs.org/queue-tick/-/queue-tick-1.0.1.tgz", 2613 | "integrity": "sha512-kJt5qhMxoszgU/62PLP1CJytzd2NKetjSRnyuj31fDd3Rlcz3fzlFdFLD1SItunPwyqEOkca6GbV612BWfaBag==" 2614 | }, 2615 | "require-directory": { 2616 | "version": "2.1.1", 2617 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2618 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==" 2619 | }, 2620 | "resolve-from": { 2621 | "version": "4.0.0", 2622 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2623 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==" 2624 | }, 2625 | "safe-buffer": { 2626 | "version": "5.2.1", 2627 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2628 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 2629 | }, 2630 | "setprototypeof": { 2631 | "version": "1.2.0", 2632 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 2633 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 2634 | }, 2635 | "smart-buffer": { 2636 | "version": "4.2.0", 2637 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 2638 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==" 2639 | }, 2640 | "socks": { 2641 | "version": "2.7.1", 2642 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.7.1.tgz", 2643 | "integrity": "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==", 2644 | "requires": { 2645 | "ip": "^2.0.0", 2646 | "smart-buffer": "^4.2.0" 2647 | }, 2648 | "dependencies": { 2649 | "ip": { 2650 | "version": "2.0.0", 2651 | "resolved": "https://registry.npmjs.org/ip/-/ip-2.0.0.tgz", 2652 | "integrity": "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==" 2653 | } 2654 | } 2655 | }, 2656 | "socks-proxy-agent": { 2657 | "version": "8.0.2", 2658 | "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-8.0.2.tgz", 2659 | "integrity": "sha512-8zuqoLv1aP/66PHF5TqwJ7Czm3Yv32urJQHrVyhD7mmA6d61Zv8cIXQYPTWwmg6qlupnPvs/QKDmfa4P/qct2g==", 2660 | "requires": { 2661 | "agent-base": "^7.0.2", 2662 | "debug": "^4.3.4", 2663 | "socks": "^2.7.1" 2664 | } 2665 | }, 2666 | "source-map": { 2667 | "version": "0.6.1", 2668 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2669 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2670 | "optional": true 2671 | }, 2672 | "statuses": { 2673 | "version": "1.5.0", 2674 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 2675 | "integrity": "sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==" 2676 | }, 2677 | "streamx": { 2678 | "version": "2.15.5", 2679 | "resolved": "https://registry.npmjs.org/streamx/-/streamx-2.15.5.tgz", 2680 | "integrity": "sha512-9thPGMkKC2GctCzyCUjME3yR03x2xNo0GPKGkRw2UMYN+gqWa9uqpyNWhmsNCutU5zHmkUum0LsCRQTXUgUCAg==", 2681 | "requires": { 2682 | "fast-fifo": "^1.1.0", 2683 | "queue-tick": "^1.0.1" 2684 | } 2685 | }, 2686 | "string-width": { 2687 | "version": "4.2.3", 2688 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2689 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2690 | "requires": { 2691 | "emoji-regex": "^8.0.0", 2692 | "is-fullwidth-code-point": "^3.0.0", 2693 | "strip-ansi": "^6.0.1" 2694 | } 2695 | }, 2696 | "strip-ansi": { 2697 | "version": "6.0.1", 2698 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2699 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2700 | "requires": { 2701 | "ansi-regex": "^5.0.1" 2702 | } 2703 | }, 2704 | "supports-color": { 2705 | "version": "5.5.0", 2706 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2707 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2708 | "requires": { 2709 | "has-flag": "^3.0.0" 2710 | } 2711 | }, 2712 | "tar-fs": { 2713 | "version": "3.0.4", 2714 | "resolved": "https://registry.npmjs.org/tar-fs/-/tar-fs-3.0.4.tgz", 2715 | "integrity": "sha512-5AFQU8b9qLfZCX9zp2duONhPmZv0hGYiBPJsyUdqMjzq/mqVpy/rEUSeHk1+YitmxugaptgBh5oDGU3VsAJq4w==", 2716 | "requires": { 2717 | "mkdirp-classic": "^0.5.2", 2718 | "pump": "^3.0.0", 2719 | "tar-stream": "^3.1.5" 2720 | } 2721 | }, 2722 | "tar-stream": { 2723 | "version": "3.1.6", 2724 | "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-3.1.6.tgz", 2725 | "integrity": "sha512-B/UyjYwPpMBv+PaFSWAmtYjwdrlEaZQEhMIBFNC5oEG8lpiW8XjcSdmEaClj28ArfKScKHs2nshz3k2le6crsg==", 2726 | "requires": { 2727 | "b4a": "^1.6.4", 2728 | "fast-fifo": "^1.2.0", 2729 | "streamx": "^2.15.0" 2730 | } 2731 | }, 2732 | "through": { 2733 | "version": "2.3.8", 2734 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2735 | "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==" 2736 | }, 2737 | "toidentifier": { 2738 | "version": "1.0.1", 2739 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 2740 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==" 2741 | }, 2742 | "tr46": { 2743 | "version": "0.0.3", 2744 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 2745 | "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" 2746 | }, 2747 | "tslib": { 2748 | "version": "2.6.2", 2749 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", 2750 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==" 2751 | }, 2752 | "tsscmp": { 2753 | "version": "1.0.6", 2754 | "resolved": "https://registry.npmjs.org/tsscmp/-/tsscmp-1.0.6.tgz", 2755 | "integrity": "sha512-LxhtAkPDTkVCMQjt2h6eBVY28KCjikZqZfMcC15YBeNjkgUpdCfBu5HoiOTDu86v6smE8yOjyEktJ8hlbANHQA==" 2756 | }, 2757 | "type-is": { 2758 | "version": "1.6.18", 2759 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2760 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2761 | "requires": { 2762 | "media-typer": "0.3.0", 2763 | "mime-types": "~2.1.24" 2764 | } 2765 | }, 2766 | "unbzip2-stream": { 2767 | "version": "1.4.3", 2768 | "resolved": "https://registry.npmjs.org/unbzip2-stream/-/unbzip2-stream-1.4.3.tgz", 2769 | "integrity": "sha512-mlExGW4w71ebDJviH16lQLtZS32VKqsSfk80GCfUlwT/4/hNRFsoscrF/c++9xinkMzECL1uL9DDwXqFWkruPg==", 2770 | "requires": { 2771 | "buffer": "^5.2.1", 2772 | "through": "^2.3.8" 2773 | } 2774 | }, 2775 | "undici-types": { 2776 | "version": "5.26.5", 2777 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", 2778 | "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", 2779 | "optional": true 2780 | }, 2781 | "universalify": { 2782 | "version": "0.1.2", 2783 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 2784 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==" 2785 | }, 2786 | "urlpattern-polyfill": { 2787 | "version": "9.0.0", 2788 | "resolved": "https://registry.npmjs.org/urlpattern-polyfill/-/urlpattern-polyfill-9.0.0.tgz", 2789 | "integrity": "sha512-WHN8KDQblxd32odxeIgo83rdVDE2bvdkb86it7bMhYZwWKJz0+O0RK/eZiHYnM+zgt/U7hAHOlCQGfjjvSkw2g==" 2790 | }, 2791 | "vary": { 2792 | "version": "1.1.2", 2793 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2794 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==" 2795 | }, 2796 | "webidl-conversions": { 2797 | "version": "3.0.1", 2798 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 2799 | "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" 2800 | }, 2801 | "whatwg-url": { 2802 | "version": "5.0.0", 2803 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 2804 | "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", 2805 | "requires": { 2806 | "tr46": "~0.0.3", 2807 | "webidl-conversions": "^3.0.0" 2808 | } 2809 | }, 2810 | "wrap-ansi": { 2811 | "version": "7.0.0", 2812 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2813 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2814 | "requires": { 2815 | "ansi-styles": "^4.0.0", 2816 | "string-width": "^4.1.0", 2817 | "strip-ansi": "^6.0.0" 2818 | }, 2819 | "dependencies": { 2820 | "ansi-styles": { 2821 | "version": "4.3.0", 2822 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2823 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2824 | "requires": { 2825 | "color-convert": "^2.0.1" 2826 | } 2827 | }, 2828 | "color-convert": { 2829 | "version": "2.0.1", 2830 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2831 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2832 | "requires": { 2833 | "color-name": "~1.1.4" 2834 | } 2835 | }, 2836 | "color-name": { 2837 | "version": "1.1.4", 2838 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2839 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 2840 | } 2841 | } 2842 | }, 2843 | "wrappy": { 2844 | "version": "1.0.2", 2845 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2846 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" 2847 | }, 2848 | "ws": { 2849 | "version": "8.14.2", 2850 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.14.2.tgz", 2851 | "integrity": "sha512-wEBG1ftX4jcglPxgFCMJmZ2PLtSbJ2Peg6TmpJFTbe9GZYOQCDPdMYu/Tm0/bGZkw8paZnJY45J4K2PZrLYq8g==", 2852 | "requires": {} 2853 | }, 2854 | "y18n": { 2855 | "version": "5.0.8", 2856 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 2857 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==" 2858 | }, 2859 | "yargs": { 2860 | "version": "17.7.2", 2861 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", 2862 | "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", 2863 | "requires": { 2864 | "cliui": "^8.0.1", 2865 | "escalade": "^3.1.1", 2866 | "get-caller-file": "^2.0.5", 2867 | "require-directory": "^2.1.1", 2868 | "string-width": "^4.2.3", 2869 | "y18n": "^5.0.5", 2870 | "yargs-parser": "^21.1.1" 2871 | } 2872 | }, 2873 | "yargs-parser": { 2874 | "version": "21.1.1", 2875 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", 2876 | "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==" 2877 | }, 2878 | "yauzl": { 2879 | "version": "2.10.0", 2880 | "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz", 2881 | "integrity": "sha512-p4a9I6X6nu6IhoGmBqAcbJy1mlC4j27vEPZX9F4L4/vZT3Lyq1VkFHw/V/PUcB9Buo+DG3iHkT0x3Qya58zc3g==", 2882 | "requires": { 2883 | "buffer-crc32": "~0.2.3", 2884 | "fd-slicer": "~1.1.0" 2885 | } 2886 | }, 2887 | "ylru": { 2888 | "version": "1.3.2", 2889 | "resolved": "https://registry.npmjs.org/ylru/-/ylru-1.3.2.tgz", 2890 | "integrity": "sha512-RXRJzMiK6U2ye0BlGGZnmpwJDPgakn6aNQ0A7gHRbD4I0uvK4TW6UqkK1V0pp9jskjJBAXd3dRrbzWkqJ+6cxA==" 2891 | } 2892 | } 2893 | } 2894 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "generate-pdf", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "keywords": [], 10 | "author": "", 11 | "license": "ISC", 12 | "dependencies": { 13 | "@koa/router": "^12.0.1", 14 | "axios": "^1.6.7", 15 | "koa": "^2.15.0", 16 | "pdf-lib": "^1.17.1", 17 | "puppeteer": "^21.6.0" 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /server/header-footer-template.mjs: -------------------------------------------------------------------------------- 1 | /** 2 | * 页眉页脚 3 | * 需要注意的点: 4 | * 1. 所有内容都需要放在模版字符串中,不能从外部引入,比如 CSS、图片,可以看到 img 的 src 值是 base64 之后的内容 5 | * 2. 页眉天生会有 20px 的上边距,需要处理掉。如果不知道的话,会发现无法很难做到垂直居中,甚至看到页眉页脚空白 6 | * 3. 页脚天生会有 18px 的下边距,需要处理掉 7 | */ 8 | import crypto from 'crypto' 9 | 10 | // 页眉 11 | export function headerTemplate() { 12 | return `
13 | 14 |
` 15 | } 16 | 17 | // 页脚 18 | export function footerTemplate() { 19 | return `
20 |
${crypto.randomUUID()}
21 |
22 |
23 |
24 |
25 |
` 26 | } 27 | -------------------------------------------------------------------------------- /server/index.mjs: -------------------------------------------------------------------------------- 1 | import puppeteer from "puppeteer"; 2 | import { footerTemplate, headerTemplate } from "./header-footer-template.mjs"; 3 | import mergePDF from "./merge-pdf.mjs"; 4 | import { writeFileSync } from 'fs' 5 | import crypto from 'crypto' 6 | 7 | /** 8 | * 延时函数 9 | * @param { number } milliseconds 毫秒数 10 | * @returns Promise 11 | */ 12 | function delay(milliseconds) { 13 | return new Promise(resolve => setTimeout(resolve, milliseconds)) 14 | } 15 | 16 | /** 17 | * 生成 PDF 文件 18 | */ 19 | export async function generatePDF(configData) { 20 | const { dir, pageInfo } = configData 21 | // 启动浏览器。为了演示效果,暂时关闭无头模式,以浏览器界面形式运行 22 | const browser = await puppeteer.launch({ headless: false, devtools: true }) 23 | // 打开一个新的 Tab 页 24 | const page = await browser.newPage() 25 | // 让当前 Tab 页始终处于前台 26 | await page.bringToFront() 27 | // 页面缩放比例 28 | const scale = 1123 / 1684 29 | // 内容页 URL 列表 30 | const contentPages = pageInfo.content 31 | // 保存每个内容页的 HTML 字符串,每个元素格式为 { cssPrefix: 'sandbox-uuid', content: 'html字符串' } 32 | const pdfContentPages = [] 33 | // 遍历内容页列表,分别打开这些页面,并获取页面的 HTML 文档 34 | for (let i = 0; i < contentPages.length; i++) { 35 | // 打开内容页 36 | await page.goto(contentPages[i], { waitUntil: ['load', 'networkidle0'] }) 37 | // 滚动页面,加载完整内容。evaluate 的回调函数会在浏览器中执行,evalaute 方法的返回值是回调函数的返回值 38 | await page.evaluate(function () { 39 | return new Promise(resolve => { 40 | // 通过递归来滚动页面 41 | function scrollPage() { 42 | // { 浏览器窗口可视区域的高度,页面的总高度,已滚动的高度 } 43 | const { clientHeight, scrollHeight, scrollTop } = document.documentElement 44 | // 如果滚动高度 + 视口高度 < 总高度,则继续滚动,否则就任务滚动到底部了 45 | if (scrollTop + clientHeight < scrollHeight) { 46 | document.documentElement.scrollTo(0, scrollTop + clientHeight) 47 | // 加一个 setTimeout 来保证滚动的稳定性 48 | setTimeout(() => { 49 | scrollPage() 50 | }, 500) 51 | } else { 52 | // 滚动回顶部,不然计算目录项的页码会有问题 53 | document.documentElement.scrollTo(0, 0) 54 | resolve() 55 | } 56 | } 57 | scrollPage() 58 | }) 59 | }) 60 | 61 | // 延时 2s,防止页面没有完整渲染,比如 canvas,如果没有足够的渲染时间会发现可能只渲染了部分 62 | await delay(2000) 63 | 64 | // 获取当前页面的 HTML 文档(纯静态的 HTML 字符串) 65 | const htmlStr = await page.evaluate(function () { 66 | /** 67 | * 获取当前页面的 HTML 文档,当然文档是经过特殊处理的 68 | * 1. 移除文档中的所有 JS 标签。因为这里希望拿到的 HTML 文档是纯静态的,当这段 HTML 被再次添加到 DOM 树中不希望 HTML 中的内容再次发生变化 69 | * 2. 将 canvas 绘制的内容转换为图片,然后通过 img 加载并替换当前 canvas 标签。因为 canvas 画布上的内容是通过 JS 绘制上去的,复制后的 HTML 文档中不包含 JS,会发现 canvas 画布是空白的 70 | * 3. 补全 HTML 文档中的 URL 地址,将所有的相对地址变成绝对地址 71 | * 72 | * 注意:这里不能应用常规的性能优化策略,比如将整个文档克隆一份,然后操作克隆出来的文档,这时候会发现 canvas 转成的图片没法正常渲染 73 | * 74 | * @returns 当前页面的 HTML 字符串,document.documentElement.innerHTML 75 | */ 76 | function getuCurrentPageHtml() { 77 | // 移除所有 JS,因为不希望这部分 HTML 添加到内容页的 DOM 树上后,数据再次发生变化 78 | const allScriptEl = document.querySelectorAll('script') 79 | const allLinkJS = document.querySelectorAll('link[as="script"]'); 80 | [...allScriptEl, ...allLinkJS].forEach(scriptEl => { 81 | scriptEl.parentNode?.removeChild(scriptEl) 82 | }) 83 | 84 | // 处理 canvas,canvas 直接复制只能复制一个空画布,需要将 canvas 转换成图片 85 | const allCanvasEl = document.querySelectorAll('canvas') 86 | allCanvasEl.forEach(canvasEl => { 87 | const image = new Image() 88 | // 图片的尺寸是 canvas 实际的物理像素 89 | image.width = canvasEl.offsetWidth 90 | image.height = canvasEl.offsetHeight 91 | image.src = canvasEl.toDataURL() 92 | canvasEl.parentNode?.appendChild(image) 93 | canvasEl.parentNode?.removeChild(canvasEl) 94 | }) 95 | 96 | // 补全 HTML 片段中的 URL 地址,将所有的相对地址变成绝对地址 97 | const hrefEls = document.querySelectorAll('[href]') 98 | hrefEls.forEach((el) => { 99 | // ,但在浏览器中通过 DOM 操作,获取到的 el.href 是绝对地址,用绝对地址覆盖现有的标签属性 100 | el.href = el.href 101 | }) 102 | const srcEls = document.querySelectorAll('[src]'); 103 | srcEls.forEach((el) => { 104 | // 不处理 Data URL 105 | if (!el.src.startsWith('data:')) { 106 | el.src = el.src 107 | } 108 | }) 109 | 110 | return document.documentElement.innerHTML 111 | } 112 | return getuCurrentPageHtml() 113 | }) 114 | 115 | pdfContentPages.push({ cssPrefix: `sandbox-${crypto.randomUUID()}`, content: htmlStr }) 116 | } 117 | 118 | // 打开 PDF 内容页的容器页面,页面会负责承载上一步获取到的所有 HTML 文档,然后将这个容器页面生成 PDF 119 | await page.goto('file:///Users/liyongning/studyspace/generate-pdf/fe/pdf-content.html', { waitUntil: ['load', 'networkidle0'] }) 120 | 121 | // 用上面拿到的 HTML 内容填充当前打开的容器页面 122 | await page.evaluate((pdfContentPagesStr) => { 123 | return new Promise(resolve => { 124 | /** 125 | * 生成 PDF 内容页 126 | * @param { Array<{ cssPrefix: string; content: string HTML 字符串; }> } pdfContentPages 127 | */ 128 | function generatePdfContent(pdfContentPages) { 129 | return new Promise(resolve => { 130 | const promiseArr = [] 131 | 132 | for (let i = 0, len = pdfContentPages.length; i < len; i++) { 133 | const { cssPrefix, content } = pdfContentPages[i] 134 | const wrapper = document.createElement('div') 135 | wrapper.setAttribute('id', cssPrefix) 136 | wrapper.setAttribute('css-prefix', cssPrefix) 137 | wrapper.innerHTML = content 138 | /** 139 | * 这里不能用 fragment 去尝试优化。如果用了 fragment 会导致样式沙箱出问题,因为未进入 DOM 树的 style 节点无法获取 styleEl.sheet 属性(值为 null) 140 | */ 141 | document.body.appendChild(wrapper) 142 | 143 | // 获取所有引入外部样式表的 link 标签 144 | const allLinkEl = Array.from(wrapper.querySelectorAll('link')).filter(linkEl => linkEl.getAttribute('rel') === 'stylesheet') 145 | 146 | const loadLinkPromise = [] 147 | 148 | // 将外部引入的样式表全部换成 style 标签 149 | const allLinkElLen = allLinkEl.length 150 | if (allLinkElLen > 0) { 151 | for (let j = 0; j < allLinkElLen; j++) { 152 | const linkEl = allLinkEl[j] 153 | const href = linkEl.getAttribute('href') 154 | const ret = fetch(href).then(res => res.text()).then(res => { 155 | const styleEl = document.createElement('style') 156 | styleEl.textContent = res 157 | wrapper.insertBefore(styleEl, linkEl) 158 | wrapper.removeChild(linkEl) 159 | }) 160 | loadLinkPromise.push(ret) 161 | } 162 | } 163 | 164 | // warpper 下的所有 link 标签替换为 style 标签之后,设置样式沙箱 165 | promiseArr.push(Promise.all(loadLinkPromise).then(() => editStyle(wrapper, cssPrefix))) 166 | } 167 | 168 | Promise.all(promiseArr).then(() => resolve()) 169 | }) 170 | 171 | /** 172 | * 处理指定节点下的所有 style 节点,为节点内的样式规则增加命名空间 173 | * @param { Element } rootNode 174 | */ 175 | function editStyle(rootNode, cssPrefix) { 176 | const allStyleEl = rootNode.querySelectorAll('style') 177 | allStyleEl.forEach(styleEl => { 178 | const rules = [...styleEl.sheet?.cssRules || []] 179 | const cssText = rewrite(rules, `#${cssPrefix}`) 180 | styleEl.textContent = cssText 181 | }) 182 | } 183 | 184 | function rewrite(rules, prefix) { 185 | let cssText = '' 186 | rules.forEach(rule => { 187 | switch (rule.type) { 188 | case 1: 189 | // style 190 | cssText += ruleStyle(rule, prefix) 191 | break; 192 | case 4: 193 | cssText += ruleMedia(rule, prefix) 194 | break; 195 | case 12: 196 | cssText += ruleSupport(rule, prefix) 197 | break; 198 | default: 199 | if (typeof rule.cssText === 'string') { 200 | cssText += `${rule.cssText}` 201 | } 202 | break; 203 | } 204 | }) 205 | return cssText 206 | } 207 | 208 | /** 209 | * 处理 CSSStyleRule 样式规则,为这些样式的选择器添加前缀(命名空间) 210 | * @param { CSSStyleRule } rule 就是一个 CSS 样式,比如 .content { xxx } 211 | * @param { string } prefix 前缀选择器 212 | * @returns cssText 213 | */ 214 | function ruleStyle(rule, prefix) { 215 | // 选择器 216 | const selector = rule.selectorText.trim(); 217 | 218 | // CSS 样式代码 219 | let cssText = ''; 220 | if (typeof rule.cssText === 'string') { 221 | cssText = rule.cssText; 222 | } 223 | 224 | /** 225 | * 匹配以 body、html 或 :root 打头的选择器 226 | * 这里用到了非捕获分组来剔除 xxbody、xxhtml、xx:root 的情况, 227 | * 比如 字母数字下划线body、-body、.body、#body 等情况,只匹配以 body、html、:root 这三个选择器开头的情况 228 | */ 229 | const rootSelectorRE = /((?:[^\w\-.#]|^)(body|html|:root))/gm; 230 | 231 | // 处理 html {}、body {}、:root {} 情况,将根选择器变成 .prefix {} 232 | if (selector === 'html' || selector === 'body' || selector === ':root') { 233 | return cssText.replace(rootSelectorRE, prefix); 234 | } 235 | 236 | /** 237 | * 利用 分组 来捕获 htmlxx,即以 html 打头的选择器,但 html 后面的字母、数字、下划线、{、[、] 等字符都不被捕获, 238 | * 所以基本上只匹配以 html 打头的选择器(包含组合选择器),比如 html、html 、html >、html + 等字符 239 | */ 240 | const rootCombinationRE = /(html[^\w{[]+)/gm; 241 | 242 | // 处理 html 打头的选择器 243 | if (rootCombinationRE.test(rule.selectorText)) { 244 | // 处理非 html + xx 或 html ~ xx 形式的组合选择器,但必须是 html 打头的,比如 html > .content,处理之后变成了 .content 245 | const siblingSelectorRE = /(html[^\w{]+)(\+|~)/gm; 246 | if (!siblingSelectorRE.test(rule.selectorText)) { 247 | cssText = cssText.replace(rootCombinationRE, ''); 248 | } 249 | } 250 | 251 | /** 252 | * 处理非 html 打头的选择器 253 | * 1. 匹配 “任意字符 {”,即:选择器 {,但这里的任意字符不包括 html 选择器,这种情况上面已经处理完了 254 | * 2. 将上一步的 “任意字符 {” 中的 “任意字符” 匹配出来,可能是 "selcotor" 或 ", selector",item 是选择器,p 和 s 分别是两个分组匹配出来的字符,所以 s 才是重点(选择器) 255 | * 3. 如果匹配到的选择器是以 body 或 :root 打头的,则将 前缀选择器 替换,否则直接在选择器前增加 前缀选择器 256 | */ 257 | cssText = cssText.replace(/^[\s\S]+{/, (selectors) => 258 | selectors.replace(/(^|,\n?)([^,]+)/g, (item, p, s) => { 259 | // 处理以 body 和 :root 打头的组合选择器,比如 body div {} 260 | if (rootSelectorRE.test(item)) { 261 | return item.replace(rootSelectorRE, (m) => { 262 | // 有效字符白名单,这些字符不会丢失 263 | const whitePrevChars = [',', '(']; 264 | 265 | // 如果前一个字符是逗号或左括号,则保留前一个字符 266 | if (m && whitePrevChars.includes(m[0])) { 267 | return `${m[0]}${prefix}`; 268 | } 269 | 270 | // 否则直接将 body 或 :root 替换为前缀选择器(命名空间) 271 | return prefix; 272 | }); 273 | } 274 | 275 | // 处理其他选择器,在选择器前添加前缀 276 | return `${p}${prefix} ${s.replace(/^ */, '')}`; 277 | }), 278 | ); 279 | 280 | return cssText; 281 | } 282 | 283 | // handle case: 284 | // @media screen and (max-width: 300px) {} 285 | function ruleMedia(rule, prefix) { 286 | const css = rewrite([...rule.cssRules], prefix); 287 | return `@media ${rule.conditionText || rule.media.mediaText} {${css}}`; 288 | } 289 | 290 | // handle case: 291 | // @supports (display: grid) {} 292 | function ruleSupport(rule, prefix) { 293 | const css = rewrite([...rule.cssRules], prefix); 294 | return `@supports ${rule.conditionText || rule.cssText.split('{')[0]} {${css}}`; 295 | } 296 | } 297 | 298 | // 生成内容页 299 | const pdfContentPromise = generatePdfContent(JSON.parse(pdfContentPagesStr)) 300 | 301 | /** 302 | * 这里加 5s 的延时,是因为重写 HTML 中可能有一些外部资源,比如 img 加载的图片,如果直接 resolve 的话,可能这些资源还未就绪(加载 和 完成渲染),所以延时。 303 | */ 304 | pdfContentPromise.then(() => { 305 | setTimeout(() => { 306 | resolve(true) 307 | }, 5000) 308 | }) 309 | }) 310 | }, JSON.stringify(pdfContentPages)) 311 | 312 | /** 313 | * 目录页 314 | * 这里为了展示核心逻辑,前端代码尽可能简洁,不影响主逻辑的理解 315 | */ 316 | // 目录配置,通过 page.evaluate 方法的第二个参数传递会回调函数 317 | const dirConfig = dir 318 | // 通过 DOM 操作为新闻页添加 目录 DOM 319 | await page.evaluate(function (dirConfig) { 320 | /** 321 | * 目录页样式 322 | */ 323 | const styleStr = ` 324 | .dirEl { 325 | break-after: page; 326 | } 327 | 328 | .pageTitleDiv { 329 | text-align: center; 330 | margin-bottom: 60px; 331 | } 332 | 333 | .dirItemWrapper { 334 | display: flex; 335 | justify-content: space-around; 336 | align-items: center; 337 | margin-bottom: 10px; 338 | } 339 | 340 | .dirItemWrapper__sepratorDiv { 341 | margin: 0 4px; 342 | border-bottom: 4px dotted #666; 343 | flex-grow: 1; 344 | } 345 | ` 346 | const styleEl = document.createElement('style') 347 | styleEl.appendChild(document.createTextNode(styleStr)) 348 | 349 | /** 350 | * 页面标题 —— 目录 351 | */ 352 | const pageTitleDiv = document.createElement('h1') 353 | pageTitleDiv.appendChild(document.createTextNode('目录')) 354 | pageTitleDiv.classList.add('pageTitleDiv') 355 | 356 | /** 357 | * 目录项 358 | */ 359 | const fragement = document.createDocumentFragment() 360 | // 累计补充高度。用来补充因为 page-break: page 或 page-break-before: always 样式而出现的空白区域 361 | let cumulativeCompensationHeight = 0 362 | 363 | for (let i = 0, len = dirConfig.length; i < len; i++) { 364 | const { title, id } = dirConfig[i] 365 | 366 | const dirItemWrapper = document.createElement('div') 367 | dirItemWrapper.classList.add('dirItemWrapper') 368 | // 带序号的标题 —— a 标签 369 | const titleA = document.createElement('a') 370 | titleA.appendChild(document.createTextNode(`${i + 1}、${title}`)) 371 | titleA.setAttribute('href', `#${id}`) 372 | // 标题 和 页码之间的分割符号 —— ......... 373 | const sepratorDiv = document.createElement('div') 374 | sepratorDiv.classList.add('dirItemWrapper__sepratorDiv') 375 | /** 376 | * 页码 377 | */ 378 | const pageNumSpan = document.createElement('span') 379 | // 获取当前锚点元素 380 | const anchorEl = document.querySelector(`#${id}`) 381 | // 得到锚点元素距离顶部的像素 382 | const { y } = anchorEl.getBoundingClientRect() 383 | /** 384 | * 假设 PDF 一页的像素高度是 1524px,从而计算出当前锚点在第几页 385 | * 为什么是 1524,而不是 1684 ? 386 | * 因为页面中的页眉、页脚是通过 puppeteer 直接生成的,没有通过前端开发,所以前端开发时,页面高度需要减去页眉、页脚的高度,即 1684 - 160 = 1524 387 | */ 388 | // 锚点当前在 PDF 文件中的高度 = 实际的高度 + 之前补充的高度 389 | const existHeight = y + cumulativeCompensationHeight 390 | // 计算当前锚点应该补充多少高度 391 | const currentElPatchHeight = existHeight % 1524 392 | // 当前元素之后的累积补充高度 393 | cumulativeCompensationHeight += currentElPatchHeight 394 | // (当前高度 + 补充高度) / 1524 来计算实际的页码 395 | const pageNum = Math.ceil((existHeight + currentElPatchHeight) / 1524) || 1 396 | // 加 1 是因为目录页占了一页,所以新闻页算是从第二页开始的 397 | pageNumSpan.appendChild(document.createTextNode(pageNum + 1)) 398 | 399 | // 将三个子元素添加到父元素内 400 | dirItemWrapper.appendChild(titleA) 401 | dirItemWrapper.appendChild(sepratorDiv) 402 | dirItemWrapper.appendChild(pageNumSpan) 403 | 404 | // 目录项添加到 fragment 片段中 405 | fragement.appendChild(dirItemWrapper) 406 | } 407 | 408 | // 汇总目录页的元素 409 | const dirEl = document.createElement('div') 410 | dirEl.classList.add('dirEl') 411 | dirEl.appendChild(styleEl) 412 | dirEl.appendChild(pageTitleDiv) 413 | dirEl.appendChild(fragement) 414 | 415 | // 将目录页 DOM 添加到新闻页 DOM 的最前面 416 | document.body.insertBefore(dirEl, document.body.firstChild) 417 | }, dirConfig) 418 | 419 | // 将当前页打印成 PDF 文件。不设置 path,文件将会保存在内存中 420 | const contentBuffer = await page.pdf({ 421 | // 以 A4 纸的尺寸来打印 PDF 422 | format: 'A4', 423 | scale, 424 | // 设置 PDF 文件的页边距,避免内容完全贴边 425 | margin: { 426 | top: 80 * scale, 427 | right: 80 * scale, 428 | bottom: 80 * scale, 429 | left: 80 * scale 430 | }, 431 | // 开启页眉、页脚 432 | displayHeaderFooter: true, 433 | // 通过 HTML 模版字符串自定义页眉、页脚 434 | headerTemplate: headerTemplate(), 435 | footerTemplate: footerTemplate(), 436 | // 打印的时候打印背景色 437 | printBackground: true, 438 | }) 439 | // 封面 440 | await page.goto(pageInfo.cover) 441 | const coverBuffer = await page.pdf({ 442 | format: 'A4', 443 | printBackground: true 444 | }) 445 | // 尾页 446 | await page.goto(pageInfo.lastPage) 447 | const lastPageBuffer = await page.pdf({ 448 | format: 'A4', 449 | printBackground: true 450 | }) 451 | // 合并三份 PDF 452 | const pdfBuffer = await mergePDF(coverBuffer, contentBuffer, lastPageBuffer) 453 | // 将合并后的终版 PDF 文件写盘 454 | writeFileSync('./final.pdf', pdfBuffer) 455 | // 关闭浏览器 456 | await browser.close() 457 | } 458 | 459 | // generatePDF() -------------------------------------------------------------------------------- /server/koa-server.mjs: -------------------------------------------------------------------------------- 1 | import Koa from 'koa' 2 | import KoaRouter from '@koa/router' 3 | import { generatePDF } from './index.mjs' 4 | import axios from 'axios' 5 | 6 | const app = new Koa() 7 | const router = new KoaRouter() 8 | 9 | // 当用户请求 http://localhost:3000 时,触发 generatePDF() 函数生成 PDF 文件 10 | router.get('/', async function (ctx) { 11 | const appId = ctx.query.appId 12 | const { data: configData } = await axios.get(`http://localhost:3000/get-pdf-config?appId=${appId}`) 13 | // 异常情况 14 | if (configData.errno) { 15 | ctx.body = configData 16 | return 17 | } 18 | 19 | const { data } = configData 20 | generatePDF(data) 21 | 22 | ctx.body = { 23 | errno: 0, 24 | data: [], 25 | msg: '正在生成 PDF 文件' 26 | } 27 | }) 28 | 29 | // 获取指定 appId 所对应的配置信息 30 | router.get('/get-pdf-config', function (ctx) { 31 | const pdfConfig = { 32 | // 为接入方分配唯一的 uuid 33 | '59edaf80-ca75-8699-7ca7-b8121d01d136': { 34 | name: 'PDF 生成服务测试', 35 | // 目录页配置 36 | dir: [ 37 | { title: '锚点 1', id: 'anchor1' }, 38 | { title: '锚点 2', id: 'anchor2' }, 39 | { title: '第二个内容页 —— 锚点 1', id: 'second-content-page-anchor1' }, 40 | { title: '第二个内容页 —— 锚点 2', id: 'second-content-page-anchor2' }, 41 | ], 42 | // 接入方的前端页面链接 43 | pageInfo: { 44 | // 封面 45 | "cover": "file:///Users/liyongning/studyspace/generate-pdf/fe/cover.html", 46 | // 内容页 47 | "content": [ 48 | "file:///Users/liyongning/studyspace/generate-pdf/fe/exact-page-num.html", 49 | "file:///Users/liyongning/studyspace/generate-pdf/fe/second-content-page.html" 50 | ], 51 | // 尾页 52 | "lastPage": "file:///Users/liyongning/studyspace/generate-pdf/fe/last-page.html" 53 | }, 54 | // ... 还可以增加其他配置 55 | } 56 | } 57 | 58 | const appId = ctx.query.appId || '' 59 | if (!pdfConfig[appId]) { 60 | ctx.body = { 61 | errno: 100, 62 | data: [], 63 | msg: '无效的 appId,请联系服务提供方申请接入' 64 | } 65 | return 66 | } 67 | 68 | ctx.body = { 69 | errno: 0, 70 | data: pdfConfig[appId], 71 | msg: 'success' 72 | } 73 | }) 74 | 75 | app.use(router.routes()) 76 | 77 | app.listen(3000, () => { 78 | console.log('koa-server start at 3000 port') 79 | }) -------------------------------------------------------------------------------- /server/logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/liyongning/generate-pdf/c3ed8e71b07f071b866b9c2c3f99510f633ac4d9/server/logo.png -------------------------------------------------------------------------------- /server/merge-pdf.mjs: -------------------------------------------------------------------------------- 1 | import { PDFDocument } from 'pdf-lib' 2 | 3 | /** 4 | * 将三份 PDF 文件合并为一份 5 | * 另外三个参数的类型都是 Buffer,是表示 PDF 文件加载到内存后二进制内容 6 | * @param { Buffer } coverBuffer 封面 PDF 7 | * @param { Buffer } contentBuffer 内容页 PDF 8 | * @param { Buffer } lastPageBuffer 尾页 PDF 9 | * @returns 合并后的 PDF 文件的二进制内容 10 | */ 11 | export default async function mergePDF(coverBuffer, contentBuffer, lastPageBuffer) { 12 | // 通过 pdf-lib 加载现有的 3份 PDF 文档 13 | const { load } = PDFDocument 14 | const [coverPdfDoc, contentPdfDoc, lastPagePdfDoc] = await Promise.all([load(coverBuffer), load(contentBuffer), load(lastPageBuffer)]) 15 | // 分别将封面文档和尾页文档的第一页拷贝到内容文档 16 | const [[coverPage], [lastPagePage]] = await Promise.all([contentPdfDoc.copyPages(coverPdfDoc, [0]), contentPdfDoc.copyPages(lastPagePdfDoc, [0])]) 17 | // 将封面页插入到 内容文档 的第 0 页,即最开始的位置 18 | contentPdfDoc.insertPage(0, coverPage) 19 | // 将尾页添加到 内容文档 的最后一页 20 | contentPdfDoc.addPage(lastPagePage) 21 | // 将合并后的 内容文档 序列化为字节数组(Uint8Array),并以二进制的格式返回 22 | return Buffer.from(await contentPdfDoc.save()) 23 | } --------------------------------------------------------------------------------