├── .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 |
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 | }
--------------------------------------------------------------------------------