jbilcke-hf HF staff commited on
Commit
e4eeb10
0 Parent(s):

initial commit

Browse files
Files changed (11) hide show
  1. .dockerignore +6 -0
  2. .gitignore +9 -0
  3. .nvmrc +1 -0
  4. Dockerfile +35 -0
  5. LICENSE.txt +201 -0
  6. README.md +68 -0
  7. package-lock.json +937 -0
  8. package.json +21 -0
  9. public/index.html +24 -0
  10. src/index.mts +8 -0
  11. tsconfig.json +12 -0
.dockerignore ADDED
@@ -0,0 +1,6 @@
 
 
 
 
 
 
 
1
+ node_modules
2
+ npm-debug.log
3
+ models
4
+ sandbox
5
+ audio.pipe
6
+ video.pipe
.gitignore ADDED
@@ -0,0 +1,9 @@
 
 
 
 
 
 
 
 
 
 
1
+ node_modules
2
+ *.log
3
+ *.bin
4
+ .DS_Store
5
+ .venv
6
+ models/
7
+ sandbox/
8
+ audio.pipe
9
+ video.pipe
.nvmrc ADDED
@@ -0,0 +1 @@
 
 
1
+ v18.16.0
Dockerfile ADDED
@@ -0,0 +1,35 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ FROM node:18
2
+
3
+
4
+ ARG DEBIAN_FRONTEND=noninteractive
5
+
6
+ RUN apt update
7
+
8
+ RUN apt --yes install ffmpeg
9
+
10
+ # Set up a new user named "user" with user ID 1000
11
+ RUN useradd -o -u 1000 user
12
+
13
+ # Switch to the "user" user
14
+ USER user
15
+
16
+ # Set home to the user's home directory
17
+ ENV HOME=/home/user \
18
+ PATH=/home/user/.local/bin:$PATH
19
+
20
+ # Set the working directory to the user's home directory
21
+ WORKDIR $HOME/app
22
+
23
+ # Install app dependencies
24
+ # A wildcard is used to ensure both package.json AND package-lock.json are copied
25
+ # where available (npm@5+)
26
+ COPY --chown=user package*.json $HOME/app
27
+
28
+ RUN npm install
29
+
30
+ # Copy the current directory contents into the container at $HOME/app setting the owner to the user
31
+ COPY --chown=user . $HOME/app
32
+
33
+ EXPOSE 7860 1935 8000
34
+
35
+ CMD [ "bash", "start.sh" ]
LICENSE.txt ADDED
@@ -0,0 +1,201 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ Apache License
2
+ Version 2.0, January 2004
3
+ http://www.apache.org/licenses/
4
+
5
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
6
+
7
+ 1. Definitions.
8
+
9
+ "License" shall mean the terms and conditions for use, reproduction,
10
+ and distribution as defined by Sections 1 through 9 of this document.
11
+
12
+ "Licensor" shall mean the copyright owner or entity authorized by
13
+ the copyright owner that is granting the License.
14
+
15
+ "Legal Entity" shall mean the union of the acting entity and all
16
+ other entities that control, are controlled by, or are under common
17
+ control with that entity. For the purposes of this definition,
18
+ "control" means (i) the power, direct or indirect, to cause the
19
+ direction or management of such entity, whether by contract or
20
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
21
+ outstanding shares, or (iii) beneficial ownership of such entity.
22
+
23
+ "You" (or "Your") shall mean an individual or Legal Entity
24
+ exercising permissions granted by this License.
25
+
26
+ "Source" form shall mean the preferred form for making modifications,
27
+ including but not limited to software source code, documentation
28
+ source, and configuration files.
29
+
30
+ "Object" form shall mean any form resulting from mechanical
31
+ transformation or translation of a Source form, including but
32
+ not limited to compiled object code, generated documentation,
33
+ and conversions to other media types.
34
+
35
+ "Work" shall mean the work of authorship, whether in Source or
36
+ Object form, made available under the License, as indicated by a
37
+ copyright notice that is included in or attached to the work
38
+ (an example is provided in the Appendix below).
39
+
40
+ "Derivative Works" shall mean any work, whether in Source or Object
41
+ form, that is based on (or derived from) the Work and for which the
42
+ editorial revisions, annotations, elaborations, or other modifications
43
+ represent, as a whole, an original work of authorship. For the purposes
44
+ of this License, Derivative Works shall not include works that remain
45
+ separable from, or merely link (or bind by name) to the interfaces of,
46
+ the Work and Derivative Works thereof.
47
+
48
+ "Contribution" shall mean any work of authorship, including
49
+ the original version of the Work and any modifications or additions
50
+ to that Work or Derivative Works thereof, that is intentionally
51
+ submitted to Licensor for inclusion in the Work by the copyright owner
52
+ or by an individual or Legal Entity authorized to submit on behalf of
53
+ the copyright owner. For the purposes of this definition, "submitted"
54
+ means any form of electronic, verbal, or written communication sent
55
+ to the Licensor or its representatives, including but not limited to
56
+ communication on electronic mailing lists, source code control systems,
57
+ and issue tracking systems that are managed by, or on behalf of, the
58
+ Licensor for the purpose of discussing and improving the Work, but
59
+ excluding communication that is conspicuously marked or otherwise
60
+ designated in writing by the copyright owner as "Not a Contribution."
61
+
62
+ "Contributor" shall mean Licensor and any individual or Legal Entity
63
+ on behalf of whom a Contribution has been received by Licensor and
64
+ subsequently incorporated within the Work.
65
+
66
+ 2. Grant of Copyright License. Subject to the terms and conditions of
67
+ this License, each Contributor hereby grants to You a perpetual,
68
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
69
+ copyright license to reproduce, prepare Derivative Works of,
70
+ publicly display, publicly perform, sublicense, and distribute the
71
+ Work and such Derivative Works in Source or Object form.
72
+
73
+ 3. Grant of Patent License. Subject to the terms and conditions of
74
+ this License, each Contributor hereby grants to You a perpetual,
75
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
76
+ (except as stated in this section) patent license to make, have made,
77
+ use, offer to sell, sell, import, and otherwise transfer the Work,
78
+ where such license applies only to those patent claims licensable
79
+ by such Contributor that are necessarily infringed by their
80
+ Contribution(s) alone or by combination of their Contribution(s)
81
+ with the Work to which such Contribution(s) was submitted. If You
82
+ institute patent litigation against any entity (including a
83
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
84
+ or a Contribution incorporated within the Work constitutes direct
85
+ or contributory patent infringement, then any patent licenses
86
+ granted to You under this License for that Work shall terminate
87
+ as of the date such litigation is filed.
88
+
89
+ 4. Redistribution. You may reproduce and distribute copies of the
90
+ Work or Derivative Works thereof in any medium, with or without
91
+ modifications, and in Source or Object form, provided that You
92
+ meet the following conditions:
93
+
94
+ (a) You must give any other recipients of the Work or
95
+ Derivative Works a copy of this License; and
96
+
97
+ (b) You must cause any modified files to carry prominent notices
98
+ stating that You changed the files; and
99
+
100
+ (c) You must retain, in the Source form of any Derivative Works
101
+ that You distribute, all copyright, patent, trademark, and
102
+ attribution notices from the Source form of the Work,
103
+ excluding those notices that do not pertain to any part of
104
+ the Derivative Works; and
105
+
106
+ (d) If the Work includes a "NOTICE" text file as part of its
107
+ distribution, then any Derivative Works that You distribute must
108
+ include a readable copy of the attribution notices contained
109
+ within such NOTICE file, excluding those notices that do not
110
+ pertain to any part of the Derivative Works, in at least one
111
+ of the following places: within a NOTICE text file distributed
112
+ as part of the Derivative Works; within the Source form or
113
+ documentation, if provided along with the Derivative Works; or,
114
+ within a display generated by the Derivative Works, if and
115
+ wherever such third-party notices normally appear. The contents
116
+ of the NOTICE file are for informational purposes only and
117
+ do not modify the License. You may add Your own attribution
118
+ notices within Derivative Works that You distribute, alongside
119
+ or as an addendum to the NOTICE text from the Work, provided
120
+ that such additional attribution notices cannot be construed
121
+ as modifying the License.
122
+
123
+ You may add Your own copyright statement to Your modifications and
124
+ may provide additional or different license terms and conditions
125
+ for use, reproduction, or distribution of Your modifications, or
126
+ for any such Derivative Works as a whole, provided Your use,
127
+ reproduction, and distribution of the Work otherwise complies with
128
+ the conditions stated in this License.
129
+
130
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
131
+ any Contribution intentionally submitted for inclusion in the Work
132
+ by You to the Licensor shall be under the terms and conditions of
133
+ this License, without any additional terms or conditions.
134
+ Notwithstanding the above, nothing herein shall supersede or modify
135
+ the terms of any separate license agreement you may have executed
136
+ with Licensor regarding such Contributions.
137
+
138
+ 6. Trademarks. This License does not grant permission to use the trade
139
+ names, trademarks, service marks, or product names of the Licensor,
140
+ except as required for reasonable and customary use in describing the
141
+ origin of the Work and reproducing the content of the NOTICE file.
142
+
143
+ 7. Disclaimer of Warranty. Unless required by applicable law or
144
+ agreed to in writing, Licensor provides the Work (and each
145
+ Contributor provides its Contributions) on an "AS IS" BASIS,
146
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
147
+ implied, including, without limitation, any warranties or conditions
148
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
149
+ PARTICULAR PURPOSE. You are solely responsible for determining the
150
+ appropriateness of using or redistributing the Work and assume any
151
+ risks associated with Your exercise of permissions under this License.
152
+
153
+ 8. Limitation of Liability. In no event and under no legal theory,
154
+ whether in tort (including negligence), contract, or otherwise,
155
+ unless required by applicable law (such as deliberate and grossly
156
+ negligent acts) or agreed to in writing, shall any Contributor be
157
+ liable to You for damages, including any direct, indirect, special,
158
+ incidental, or consequential damages of any character arising as a
159
+ result of this License or out of the use or inability to use the
160
+ Work (including but not limited to damages for loss of goodwill,
161
+ work stoppage, computer failure or malfunction, or any and all
162
+ other commercial damages or losses), even if such Contributor
163
+ has been advised of the possibility of such damages.
164
+
165
+ 9. Accepting Warranty or Additional Liability. While redistributing
166
+ the Work or Derivative Works thereof, You may choose to offer,
167
+ and charge a fee for, acceptance of support, warranty, indemnity,
168
+ or other liability obligations and/or rights consistent with this
169
+ License. However, in accepting such obligations, You may act only
170
+ on Your own behalf and on Your sole responsibility, not on behalf
171
+ of any other Contributor, and only if You agree to indemnify,
172
+ defend, and hold each Contributor harmless for any liability
173
+ incurred by, or claims asserted against, such Contributor by reason
174
+ of your accepting any such warranty or additional liability.
175
+
176
+ END OF TERMS AND CONDITIONS
177
+
178
+ APPENDIX: How to apply the Apache License to your work.
179
+
180
+ To apply the Apache License to your work, attach the following
181
+ boilerplate notice, with the fields enclosed by brackets "[]"
182
+ replaced with your own identifying information. (Don't include
183
+ the brackets!) The text should be enclosed in the appropriate
184
+ comment syntax for the file format. We also recommend that a
185
+ file or class name and description of purpose be included on the
186
+ same "printed page" as the copyright notice for easier
187
+ identification within third-party archives.
188
+
189
+ Copyright [yyyy] [name of copyright owner]
190
+
191
+ Licensed under the Apache License, Version 2.0 (the "License");
192
+ you may not use this file except in compliance with the License.
193
+ You may obtain a copy of the License at
194
+
195
+ http://www.apache.org/licenses/LICENSE-2.0
196
+
197
+ Unless required by applicable law or agreed to in writing, software
198
+ distributed under the License is distributed on an "AS IS" BASIS,
199
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
200
+ See the License for the specific language governing permissions and
201
+ limitations under the License.
README.md ADDED
@@ -0,0 +1,68 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ title: AI WebTV
3
+ emoji: 🔮
4
+ colorFrom: purple
5
+ colorTo: white
6
+ sdk: docker
7
+ pinned: false
8
+ app_port: 7860
9
+ ---
10
+
11
+ A generative AI WebTV, powered by Zeroscope and Hugging Face.
12
+
13
+ # Installation
14
+ ## Building and run without Docker
15
+
16
+ ```bash
17
+ nvm use
18
+ npm i
19
+ ```
20
+
21
+ First setup some env vars:
22
+ WEBTV_VIDEOPATH="./sandbox/video"
23
+ WEBTV_AUDIOPATH="./sandbox/audio"
24
+ WEBTV_RTMP_URL="rtmp://localhost:1935/webtv"
25
+
26
+
27
+ In a terminal, run:
28
+
29
+ ```
30
+ ./scripts/init.sh
31
+ ```
32
+
33
+ Then run:
34
+
35
+ ```
36
+ ./scripts/audio.sh
37
+ ```
38
+
39
+ In another terminal, run:
40
+
41
+ ```
42
+ ./scripts/video.sh
43
+ ```
44
+
45
+ In another terminal, run:
46
+
47
+ ```
48
+ ./scripts/stream.sh
49
+ ```
50
+
51
+ In another terminal, run:
52
+
53
+ ```
54
+ npm run start
55
+ ```
56
+
57
+ ## Building and running with Docker
58
+
59
+ ```bash
60
+ npm run docker
61
+ ```
62
+
63
+ This script is a shortcut executing the following commands:
64
+
65
+ ```bash
66
+ docker build -t ai-webtv .
67
+ docker run -it -p 7860:7860 ai-webtv
68
+ ```
package-lock.json ADDED
@@ -0,0 +1,937 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "name": "ai-webtv",
3
+ "version": "1.0.0",
4
+ "lockfileVersion": 3,
5
+ "requires": true,
6
+ "packages": {
7
+ "": {
8
+ "name": "ai-webtv",
9
+ "version": "1.0.0",
10
+ "license": "Apache License",
11
+ "dependencies": {
12
+ "@types/express": "^4.17.17",
13
+ "express": "^4.18.2",
14
+ "node-fetch": "^3.3.1",
15
+ "ts-node": "^10.9.1"
16
+ }
17
+ },
18
+ "node_modules/@cspotcode/source-map-support": {
19
+ "version": "0.8.1",
20
+ "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz",
21
+ "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==",
22
+ "dependencies": {
23
+ "@jridgewell/trace-mapping": "0.3.9"
24
+ },
25
+ "engines": {
26
+ "node": ">=12"
27
+ }
28
+ },
29
+ "node_modules/@jridgewell/resolve-uri": {
30
+ "version": "3.1.1",
31
+ "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz",
32
+ "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==",
33
+ "engines": {
34
+ "node": ">=6.0.0"
35
+ }
36
+ },
37
+ "node_modules/@jridgewell/sourcemap-codec": {
38
+ "version": "1.4.15",
39
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz",
40
+ "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg=="
41
+ },
42
+ "node_modules/@jridgewell/trace-mapping": {
43
+ "version": "0.3.9",
44
+ "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz",
45
+ "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==",
46
+ "dependencies": {
47
+ "@jridgewell/resolve-uri": "^3.0.3",
48
+ "@jridgewell/sourcemap-codec": "^1.4.10"
49
+ }
50
+ },
51
+ "node_modules/@tsconfig/node10": {
52
+ "version": "1.0.9",
53
+ "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz",
54
+ "integrity": "sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA=="
55
+ },
56
+ "node_modules/@tsconfig/node12": {
57
+ "version": "1.0.11",
58
+ "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz",
59
+ "integrity": "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag=="
60
+ },
61
+ "node_modules/@tsconfig/node14": {
62
+ "version": "1.0.3",
63
+ "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz",
64
+ "integrity": "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow=="
65
+ },
66
+ "node_modules/@tsconfig/node16": {
67
+ "version": "1.0.4",
68
+ "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.4.tgz",
69
+ "integrity": "sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA=="
70
+ },
71
+ "node_modules/@types/body-parser": {
72
+ "version": "1.19.2",
73
+ "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz",
74
+ "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==",
75
+ "dependencies": {
76
+ "@types/connect": "*",
77
+ "@types/node": "*"
78
+ }
79
+ },
80
+ "node_modules/@types/connect": {
81
+ "version": "3.4.35",
82
+ "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz",
83
+ "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==",
84
+ "dependencies": {
85
+ "@types/node": "*"
86
+ }
87
+ },
88
+ "node_modules/@types/express": {
89
+ "version": "4.17.17",
90
+ "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.17.tgz",
91
+ "integrity": "sha512-Q4FmmuLGBG58btUnfS1c1r/NQdlp3DMfGDGig8WhfpA2YRUtEkxAjkZb0yvplJGYdF1fsQ81iMDcH24sSCNC/Q==",
92
+ "dependencies": {
93
+ "@types/body-parser": "*",
94
+ "@types/express-serve-static-core": "^4.17.33",
95
+ "@types/qs": "*",
96
+ "@types/serve-static": "*"
97
+ }
98
+ },
99
+ "node_modules/@types/express-serve-static-core": {
100
+ "version": "4.17.35",
101
+ "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.35.tgz",
102
+ "integrity": "sha512-wALWQwrgiB2AWTT91CB62b6Yt0sNHpznUXeZEcnPU3DRdlDIz74x8Qg1UUYKSVFi+va5vKOLYRBI1bRKiLLKIg==",
103
+ "dependencies": {
104
+ "@types/node": "*",
105
+ "@types/qs": "*",
106
+ "@types/range-parser": "*",
107
+ "@types/send": "*"
108
+ }
109
+ },
110
+ "node_modules/@types/http-errors": {
111
+ "version": "2.0.1",
112
+ "resolved": "https://registry.npmjs.org/@types/http-errors/-/http-errors-2.0.1.tgz",
113
+ "integrity": "sha512-/K3ds8TRAfBvi5vfjuz8y6+GiAYBZ0x4tXv1Av6CWBWn0IlADc+ZX9pMq7oU0fNQPnBwIZl3rmeLp6SBApbxSQ=="
114
+ },
115
+ "node_modules/@types/mime": {
116
+ "version": "1.3.2",
117
+ "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz",
118
+ "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw=="
119
+ },
120
+ "node_modules/@types/node": {
121
+ "version": "20.3.2",
122
+ "resolved": "https://registry.npmjs.org/@types/node/-/node-20.3.2.tgz",
123
+ "integrity": "sha512-vOBLVQeCQfIcF/2Y7eKFTqrMnizK5lRNQ7ykML/5RuwVXVWxYkgwS7xbt4B6fKCUPgbSL5FSsjHQpaGQP/dQmw=="
124
+ },
125
+ "node_modules/@types/qs": {
126
+ "version": "6.9.7",
127
+ "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz",
128
+ "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw=="
129
+ },
130
+ "node_modules/@types/range-parser": {
131
+ "version": "1.2.4",
132
+ "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz",
133
+ "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw=="
134
+ },
135
+ "node_modules/@types/send": {
136
+ "version": "0.17.1",
137
+ "resolved": "https://registry.npmjs.org/@types/send/-/send-0.17.1.tgz",
138
+ "integrity": "sha512-Cwo8LE/0rnvX7kIIa3QHCkcuF21c05Ayb0ZfxPiv0W8VRiZiNW/WuRupHKpqqGVGf7SUA44QSOUKaEd9lIrd/Q==",
139
+ "dependencies": {
140
+ "@types/mime": "^1",
141
+ "@types/node": "*"
142
+ }
143
+ },
144
+ "node_modules/@types/serve-static": {
145
+ "version": "1.15.2",
146
+ "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.15.2.tgz",
147
+ "integrity": "sha512-J2LqtvFYCzaj8pVYKw8klQXrLLk7TBZmQ4ShlcdkELFKGwGMfevMLneMMRkMgZxotOD9wg497LpC7O8PcvAmfw==",
148
+ "dependencies": {
149
+ "@types/http-errors": "*",
150
+ "@types/mime": "*",
151
+ "@types/node": "*"
152
+ }
153
+ },
154
+ "node_modules/accepts": {
155
+ "version": "1.3.8",
156
+ "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz",
157
+ "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==",
158
+ "dependencies": {
159
+ "mime-types": "~2.1.34",
160
+ "negotiator": "0.6.3"
161
+ },
162
+ "engines": {
163
+ "node": ">= 0.6"
164
+ }
165
+ },
166
+ "node_modules/acorn": {
167
+ "version": "8.9.0",
168
+ "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.9.0.tgz",
169
+ "integrity": "sha512-jaVNAFBHNLXspO543WnNNPZFRtavh3skAkITqD0/2aeMkKZTN+254PyhwxFYrk3vQ1xfY+2wbesJMs/JC8/PwQ==",
170
+ "bin": {
171
+ "acorn": "bin/acorn"
172
+ },
173
+ "engines": {
174
+ "node": ">=0.4.0"
175
+ }
176
+ },
177
+ "node_modules/acorn-walk": {
178
+ "version": "8.2.0",
179
+ "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz",
180
+ "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==",
181
+ "engines": {
182
+ "node": ">=0.4.0"
183
+ }
184
+ },
185
+ "node_modules/arg": {
186
+ "version": "4.1.3",
187
+ "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz",
188
+ "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA=="
189
+ },
190
+ "node_modules/array-flatten": {
191
+ "version": "1.1.1",
192
+ "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
193
+ "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg=="
194
+ },
195
+ "node_modules/body-parser": {
196
+ "version": "1.20.1",
197
+ "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz",
198
+ "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==",
199
+ "dependencies": {
200
+ "bytes": "3.1.2",
201
+ "content-type": "~1.0.4",
202
+ "debug": "2.6.9",
203
+ "depd": "2.0.0",
204
+ "destroy": "1.2.0",
205
+ "http-errors": "2.0.0",
206
+ "iconv-lite": "0.4.24",
207
+ "on-finished": "2.4.1",
208
+ "qs": "6.11.0",
209
+ "raw-body": "2.5.1",
210
+ "type-is": "~1.6.18",
211
+ "unpipe": "1.0.0"
212
+ },
213
+ "engines": {
214
+ "node": ">= 0.8",
215
+ "npm": "1.2.8000 || >= 1.4.16"
216
+ }
217
+ },
218
+ "node_modules/bytes": {
219
+ "version": "3.1.2",
220
+ "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz",
221
+ "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==",
222
+ "engines": {
223
+ "node": ">= 0.8"
224
+ }
225
+ },
226
+ "node_modules/call-bind": {
227
+ "version": "1.0.2",
228
+ "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz",
229
+ "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==",
230
+ "dependencies": {
231
+ "function-bind": "^1.1.1",
232
+ "get-intrinsic": "^1.0.2"
233
+ },
234
+ "funding": {
235
+ "url": "https://github.com/sponsors/ljharb"
236
+ }
237
+ },
238
+ "node_modules/content-disposition": {
239
+ "version": "0.5.4",
240
+ "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz",
241
+ "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==",
242
+ "dependencies": {
243
+ "safe-buffer": "5.2.1"
244
+ },
245
+ "engines": {
246
+ "node": ">= 0.6"
247
+ }
248
+ },
249
+ "node_modules/content-type": {
250
+ "version": "1.0.5",
251
+ "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz",
252
+ "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==",
253
+ "engines": {
254
+ "node": ">= 0.6"
255
+ }
256
+ },
257
+ "node_modules/cookie": {
258
+ "version": "0.5.0",
259
+ "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz",
260
+ "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==",
261
+ "engines": {
262
+ "node": ">= 0.6"
263
+ }
264
+ },
265
+ "node_modules/cookie-signature": {
266
+ "version": "1.0.6",
267
+ "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
268
+ "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ=="
269
+ },
270
+ "node_modules/create-require": {
271
+ "version": "1.1.1",
272
+ "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz",
273
+ "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ=="
274
+ },
275
+ "node_modules/data-uri-to-buffer": {
276
+ "version": "4.0.1",
277
+ "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-4.0.1.tgz",
278
+ "integrity": "sha512-0R9ikRb668HB7QDxT1vkpuUBtqc53YyAwMwGeUFKRojY/NWKvdZ+9UYtRfGmhqNbRkTSVpMbmyhXipFFv2cb/A==",
279
+ "engines": {
280
+ "node": ">= 12"
281
+ }
282
+ },
283
+ "node_modules/debug": {
284
+ "version": "2.6.9",
285
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
286
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
287
+ "dependencies": {
288
+ "ms": "2.0.0"
289
+ }
290
+ },
291
+ "node_modules/depd": {
292
+ "version": "2.0.0",
293
+ "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz",
294
+ "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==",
295
+ "engines": {
296
+ "node": ">= 0.8"
297
+ }
298
+ },
299
+ "node_modules/destroy": {
300
+ "version": "1.2.0",
301
+ "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz",
302
+ "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==",
303
+ "engines": {
304
+ "node": ">= 0.8",
305
+ "npm": "1.2.8000 || >= 1.4.16"
306
+ }
307
+ },
308
+ "node_modules/diff": {
309
+ "version": "4.0.2",
310
+ "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz",
311
+ "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==",
312
+ "engines": {
313
+ "node": ">=0.3.1"
314
+ }
315
+ },
316
+ "node_modules/ee-first": {
317
+ "version": "1.1.1",
318
+ "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
319
+ "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow=="
320
+ },
321
+ "node_modules/encodeurl": {
322
+ "version": "1.0.2",
323
+ "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
324
+ "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==",
325
+ "engines": {
326
+ "node": ">= 0.8"
327
+ }
328
+ },
329
+ "node_modules/escape-html": {
330
+ "version": "1.0.3",
331
+ "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
332
+ "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow=="
333
+ },
334
+ "node_modules/etag": {
335
+ "version": "1.8.1",
336
+ "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
337
+ "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==",
338
+ "engines": {
339
+ "node": ">= 0.6"
340
+ }
341
+ },
342
+ "node_modules/express": {
343
+ "version": "4.18.2",
344
+ "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz",
345
+ "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==",
346
+ "dependencies": {
347
+ "accepts": "~1.3.8",
348
+ "array-flatten": "1.1.1",
349
+ "body-parser": "1.20.1",
350
+ "content-disposition": "0.5.4",
351
+ "content-type": "~1.0.4",
352
+ "cookie": "0.5.0",
353
+ "cookie-signature": "1.0.6",
354
+ "debug": "2.6.9",
355
+ "depd": "2.0.0",
356
+ "encodeurl": "~1.0.2",
357
+ "escape-html": "~1.0.3",
358
+ "etag": "~1.8.1",
359
+ "finalhandler": "1.2.0",
360
+ "fresh": "0.5.2",
361
+ "http-errors": "2.0.0",
362
+ "merge-descriptors": "1.0.1",
363
+ "methods": "~1.1.2",
364
+ "on-finished": "2.4.1",
365
+ "parseurl": "~1.3.3",
366
+ "path-to-regexp": "0.1.7",
367
+ "proxy-addr": "~2.0.7",
368
+ "qs": "6.11.0",
369
+ "range-parser": "~1.2.1",
370
+ "safe-buffer": "5.2.1",
371
+ "send": "0.18.0",
372
+ "serve-static": "1.15.0",
373
+ "setprototypeof": "1.2.0",
374
+ "statuses": "2.0.1",
375
+ "type-is": "~1.6.18",
376
+ "utils-merge": "1.0.1",
377
+ "vary": "~1.1.2"
378
+ },
379
+ "engines": {
380
+ "node": ">= 0.10.0"
381
+ }
382
+ },
383
+ "node_modules/fetch-blob": {
384
+ "version": "3.2.0",
385
+ "resolved": "https://registry.npmjs.org/fetch-blob/-/fetch-blob-3.2.0.tgz",
386
+ "integrity": "sha512-7yAQpD2UMJzLi1Dqv7qFYnPbaPx7ZfFK6PiIxQ4PfkGPyNyl2Ugx+a/umUonmKqjhM4DnfbMvdX6otXq83soQQ==",
387
+ "funding": [
388
+ {
389
+ "type": "github",
390
+ "url": "https://github.com/sponsors/jimmywarting"
391
+ },
392
+ {
393
+ "type": "paypal",
394
+ "url": "https://paypal.me/jimmywarting"
395
+ }
396
+ ],
397
+ "dependencies": {
398
+ "node-domexception": "^1.0.0",
399
+ "web-streams-polyfill": "^3.0.3"
400
+ },
401
+ "engines": {
402
+ "node": "^12.20 || >= 14.13"
403
+ }
404
+ },
405
+ "node_modules/finalhandler": {
406
+ "version": "1.2.0",
407
+ "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz",
408
+ "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==",
409
+ "dependencies": {
410
+ "debug": "2.6.9",
411
+ "encodeurl": "~1.0.2",
412
+ "escape-html": "~1.0.3",
413
+ "on-finished": "2.4.1",
414
+ "parseurl": "~1.3.3",
415
+ "statuses": "2.0.1",
416
+ "unpipe": "~1.0.0"
417
+ },
418
+ "engines": {
419
+ "node": ">= 0.8"
420
+ }
421
+ },
422
+ "node_modules/formdata-polyfill": {
423
+ "version": "4.0.10",
424
+ "resolved": "https://registry.npmjs.org/formdata-polyfill/-/formdata-polyfill-4.0.10.tgz",
425
+ "integrity": "sha512-buewHzMvYL29jdeQTVILecSaZKnt/RJWjoZCF5OW60Z67/GmSLBkOFM7qh1PI3zFNtJbaZL5eQu1vLfazOwj4g==",
426
+ "dependencies": {
427
+ "fetch-blob": "^3.1.2"
428
+ },
429
+ "engines": {
430
+ "node": ">=12.20.0"
431
+ }
432
+ },
433
+ "node_modules/forwarded": {
434
+ "version": "0.2.0",
435
+ "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz",
436
+ "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==",
437
+ "engines": {
438
+ "node": ">= 0.6"
439
+ }
440
+ },
441
+ "node_modules/fresh": {
442
+ "version": "0.5.2",
443
+ "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
444
+ "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==",
445
+ "engines": {
446
+ "node": ">= 0.6"
447
+ }
448
+ },
449
+ "node_modules/function-bind": {
450
+ "version": "1.1.1",
451
+ "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
452
+ "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A=="
453
+ },
454
+ "node_modules/get-intrinsic": {
455
+ "version": "1.2.1",
456
+ "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz",
457
+ "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==",
458
+ "dependencies": {
459
+ "function-bind": "^1.1.1",
460
+ "has": "^1.0.3",
461
+ "has-proto": "^1.0.1",
462
+ "has-symbols": "^1.0.3"
463
+ },
464
+ "funding": {
465
+ "url": "https://github.com/sponsors/ljharb"
466
+ }
467
+ },
468
+ "node_modules/has": {
469
+ "version": "1.0.3",
470
+ "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
471
+ "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
472
+ "dependencies": {
473
+ "function-bind": "^1.1.1"
474
+ },
475
+ "engines": {
476
+ "node": ">= 0.4.0"
477
+ }
478
+ },
479
+ "node_modules/has-proto": {
480
+ "version": "1.0.1",
481
+ "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz",
482
+ "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==",
483
+ "engines": {
484
+ "node": ">= 0.4"
485
+ },
486
+ "funding": {
487
+ "url": "https://github.com/sponsors/ljharb"
488
+ }
489
+ },
490
+ "node_modules/has-symbols": {
491
+ "version": "1.0.3",
492
+ "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz",
493
+ "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==",
494
+ "engines": {
495
+ "node": ">= 0.4"
496
+ },
497
+ "funding": {
498
+ "url": "https://github.com/sponsors/ljharb"
499
+ }
500
+ },
501
+ "node_modules/http-errors": {
502
+ "version": "2.0.0",
503
+ "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz",
504
+ "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==",
505
+ "dependencies": {
506
+ "depd": "2.0.0",
507
+ "inherits": "2.0.4",
508
+ "setprototypeof": "1.2.0",
509
+ "statuses": "2.0.1",
510
+ "toidentifier": "1.0.1"
511
+ },
512
+ "engines": {
513
+ "node": ">= 0.8"
514
+ }
515
+ },
516
+ "node_modules/iconv-lite": {
517
+ "version": "0.4.24",
518
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
519
+ "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
520
+ "dependencies": {
521
+ "safer-buffer": ">= 2.1.2 < 3"
522
+ },
523
+ "engines": {
524
+ "node": ">=0.10.0"
525
+ }
526
+ },
527
+ "node_modules/inherits": {
528
+ "version": "2.0.4",
529
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
530
+ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
531
+ },
532
+ "node_modules/ipaddr.js": {
533
+ "version": "1.9.1",
534
+ "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz",
535
+ "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==",
536
+ "engines": {
537
+ "node": ">= 0.10"
538
+ }
539
+ },
540
+ "node_modules/make-error": {
541
+ "version": "1.3.6",
542
+ "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz",
543
+ "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw=="
544
+ },
545
+ "node_modules/media-typer": {
546
+ "version": "0.3.0",
547
+ "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
548
+ "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==",
549
+ "engines": {
550
+ "node": ">= 0.6"
551
+ }
552
+ },
553
+ "node_modules/merge-descriptors": {
554
+ "version": "1.0.1",
555
+ "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
556
+ "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w=="
557
+ },
558
+ "node_modules/methods": {
559
+ "version": "1.1.2",
560
+ "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
561
+ "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==",
562
+ "engines": {
563
+ "node": ">= 0.6"
564
+ }
565
+ },
566
+ "node_modules/mime": {
567
+ "version": "1.6.0",
568
+ "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
569
+ "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
570
+ "bin": {
571
+ "mime": "cli.js"
572
+ },
573
+ "engines": {
574
+ "node": ">=4"
575
+ }
576
+ },
577
+ "node_modules/mime-db": {
578
+ "version": "1.52.0",
579
+ "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
580
+ "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
581
+ "engines": {
582
+ "node": ">= 0.6"
583
+ }
584
+ },
585
+ "node_modules/mime-types": {
586
+ "version": "2.1.35",
587
+ "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
588
+ "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
589
+ "dependencies": {
590
+ "mime-db": "1.52.0"
591
+ },
592
+ "engines": {
593
+ "node": ">= 0.6"
594
+ }
595
+ },
596
+ "node_modules/ms": {
597
+ "version": "2.0.0",
598
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
599
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
600
+ },
601
+ "node_modules/negotiator": {
602
+ "version": "0.6.3",
603
+ "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz",
604
+ "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==",
605
+ "engines": {
606
+ "node": ">= 0.6"
607
+ }
608
+ },
609
+ "node_modules/node-domexception": {
610
+ "version": "1.0.0",
611
+ "resolved": "https://registry.npmjs.org/node-domexception/-/node-domexception-1.0.0.tgz",
612
+ "integrity": "sha512-/jKZoMpw0F8GRwl4/eLROPA3cfcXtLApP0QzLmUT/HuPCZWyB7IY9ZrMeKw2O/nFIqPQB3PVM9aYm0F312AXDQ==",
613
+ "funding": [
614
+ {
615
+ "type": "github",
616
+ "url": "https://github.com/sponsors/jimmywarting"
617
+ },
618
+ {
619
+ "type": "github",
620
+ "url": "https://paypal.me/jimmywarting"
621
+ }
622
+ ],
623
+ "engines": {
624
+ "node": ">=10.5.0"
625
+ }
626
+ },
627
+ "node_modules/node-fetch": {
628
+ "version": "3.3.1",
629
+ "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-3.3.1.tgz",
630
+ "integrity": "sha512-cRVc/kyto/7E5shrWca1Wsea4y6tL9iYJE5FBCius3JQfb/4P4I295PfhgbJQBLTx6lATE4z+wK0rPM4VS2uow==",
631
+ "dependencies": {
632
+ "data-uri-to-buffer": "^4.0.0",
633
+ "fetch-blob": "^3.1.4",
634
+ "formdata-polyfill": "^4.0.10"
635
+ },
636
+ "engines": {
637
+ "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
638
+ },
639
+ "funding": {
640
+ "type": "opencollective",
641
+ "url": "https://opencollective.com/node-fetch"
642
+ }
643
+ },
644
+ "node_modules/object-inspect": {
645
+ "version": "1.12.3",
646
+ "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz",
647
+ "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==",
648
+ "funding": {
649
+ "url": "https://github.com/sponsors/ljharb"
650
+ }
651
+ },
652
+ "node_modules/on-finished": {
653
+ "version": "2.4.1",
654
+ "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz",
655
+ "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==",
656
+ "dependencies": {
657
+ "ee-first": "1.1.1"
658
+ },
659
+ "engines": {
660
+ "node": ">= 0.8"
661
+ }
662
+ },
663
+ "node_modules/parseurl": {
664
+ "version": "1.3.3",
665
+ "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
666
+ "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==",
667
+ "engines": {
668
+ "node": ">= 0.8"
669
+ }
670
+ },
671
+ "node_modules/path-to-regexp": {
672
+ "version": "0.1.7",
673
+ "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
674
+ "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ=="
675
+ },
676
+ "node_modules/proxy-addr": {
677
+ "version": "2.0.7",
678
+ "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz",
679
+ "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==",
680
+ "dependencies": {
681
+ "forwarded": "0.2.0",
682
+ "ipaddr.js": "1.9.1"
683
+ },
684
+ "engines": {
685
+ "node": ">= 0.10"
686
+ }
687
+ },
688
+ "node_modules/qs": {
689
+ "version": "6.11.0",
690
+ "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz",
691
+ "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==",
692
+ "dependencies": {
693
+ "side-channel": "^1.0.4"
694
+ },
695
+ "engines": {
696
+ "node": ">=0.6"
697
+ },
698
+ "funding": {
699
+ "url": "https://github.com/sponsors/ljharb"
700
+ }
701
+ },
702
+ "node_modules/range-parser": {
703
+ "version": "1.2.1",
704
+ "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
705
+ "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==",
706
+ "engines": {
707
+ "node": ">= 0.6"
708
+ }
709
+ },
710
+ "node_modules/raw-body": {
711
+ "version": "2.5.1",
712
+ "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz",
713
+ "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==",
714
+ "dependencies": {
715
+ "bytes": "3.1.2",
716
+ "http-errors": "2.0.0",
717
+ "iconv-lite": "0.4.24",
718
+ "unpipe": "1.0.0"
719
+ },
720
+ "engines": {
721
+ "node": ">= 0.8"
722
+ }
723
+ },
724
+ "node_modules/safe-buffer": {
725
+ "version": "5.2.1",
726
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
727
+ "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
728
+ "funding": [
729
+ {
730
+ "type": "github",
731
+ "url": "https://github.com/sponsors/feross"
732
+ },
733
+ {
734
+ "type": "patreon",
735
+ "url": "https://www.patreon.com/feross"
736
+ },
737
+ {
738
+ "type": "consulting",
739
+ "url": "https://feross.org/support"
740
+ }
741
+ ]
742
+ },
743
+ "node_modules/safer-buffer": {
744
+ "version": "2.1.2",
745
+ "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
746
+ "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
747
+ },
748
+ "node_modules/send": {
749
+ "version": "0.18.0",
750
+ "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz",
751
+ "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==",
752
+ "dependencies": {
753
+ "debug": "2.6.9",
754
+ "depd": "2.0.0",
755
+ "destroy": "1.2.0",
756
+ "encodeurl": "~1.0.2",
757
+ "escape-html": "~1.0.3",
758
+ "etag": "~1.8.1",
759
+ "fresh": "0.5.2",
760
+ "http-errors": "2.0.0",
761
+ "mime": "1.6.0",
762
+ "ms": "2.1.3",
763
+ "on-finished": "2.4.1",
764
+ "range-parser": "~1.2.1",
765
+ "statuses": "2.0.1"
766
+ },
767
+ "engines": {
768
+ "node": ">= 0.8.0"
769
+ }
770
+ },
771
+ "node_modules/send/node_modules/ms": {
772
+ "version": "2.1.3",
773
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
774
+ "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
775
+ },
776
+ "node_modules/serve-static": {
777
+ "version": "1.15.0",
778
+ "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz",
779
+ "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==",
780
+ "dependencies": {
781
+ "encodeurl": "~1.0.2",
782
+ "escape-html": "~1.0.3",
783
+ "parseurl": "~1.3.3",
784
+ "send": "0.18.0"
785
+ },
786
+ "engines": {
787
+ "node": ">= 0.8.0"
788
+ }
789
+ },
790
+ "node_modules/setprototypeof": {
791
+ "version": "1.2.0",
792
+ "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz",
793
+ "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw=="
794
+ },
795
+ "node_modules/side-channel": {
796
+ "version": "1.0.4",
797
+ "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz",
798
+ "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==",
799
+ "dependencies": {
800
+ "call-bind": "^1.0.0",
801
+ "get-intrinsic": "^1.0.2",
802
+ "object-inspect": "^1.9.0"
803
+ },
804
+ "funding": {
805
+ "url": "https://github.com/sponsors/ljharb"
806
+ }
807
+ },
808
+ "node_modules/statuses": {
809
+ "version": "2.0.1",
810
+ "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
811
+ "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==",
812
+ "engines": {
813
+ "node": ">= 0.8"
814
+ }
815
+ },
816
+ "node_modules/toidentifier": {
817
+ "version": "1.0.1",
818
+ "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz",
819
+ "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==",
820
+ "engines": {
821
+ "node": ">=0.6"
822
+ }
823
+ },
824
+ "node_modules/ts-node": {
825
+ "version": "10.9.1",
826
+ "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.1.tgz",
827
+ "integrity": "sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw==",
828
+ "dependencies": {
829
+ "@cspotcode/source-map-support": "^0.8.0",
830
+ "@tsconfig/node10": "^1.0.7",
831
+ "@tsconfig/node12": "^1.0.7",
832
+ "@tsconfig/node14": "^1.0.0",
833
+ "@tsconfig/node16": "^1.0.2",
834
+ "acorn": "^8.4.1",
835
+ "acorn-walk": "^8.1.1",
836
+ "arg": "^4.1.0",
837
+ "create-require": "^1.1.0",
838
+ "diff": "^4.0.1",
839
+ "make-error": "^1.1.1",
840
+ "v8-compile-cache-lib": "^3.0.1",
841
+ "yn": "3.1.1"
842
+ },
843
+ "bin": {
844
+ "ts-node": "dist/bin.js",
845
+ "ts-node-cwd": "dist/bin-cwd.js",
846
+ "ts-node-esm": "dist/bin-esm.js",
847
+ "ts-node-script": "dist/bin-script.js",
848
+ "ts-node-transpile-only": "dist/bin-transpile.js",
849
+ "ts-script": "dist/bin-script-deprecated.js"
850
+ },
851
+ "peerDependencies": {
852
+ "@swc/core": ">=1.2.50",
853
+ "@swc/wasm": ">=1.2.50",
854
+ "@types/node": "*",
855
+ "typescript": ">=2.7"
856
+ },
857
+ "peerDependenciesMeta": {
858
+ "@swc/core": {
859
+ "optional": true
860
+ },
861
+ "@swc/wasm": {
862
+ "optional": true
863
+ }
864
+ }
865
+ },
866
+ "node_modules/type-is": {
867
+ "version": "1.6.18",
868
+ "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
869
+ "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
870
+ "dependencies": {
871
+ "media-typer": "0.3.0",
872
+ "mime-types": "~2.1.24"
873
+ },
874
+ "engines": {
875
+ "node": ">= 0.6"
876
+ }
877
+ },
878
+ "node_modules/typescript": {
879
+ "version": "5.1.6",
880
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.1.6.tgz",
881
+ "integrity": "sha512-zaWCozRZ6DLEWAWFrVDz1H6FVXzUSfTy5FUMWsQlU8Ym5JP9eO4xkTIROFCQvhQf61z6O/G6ugw3SgAnvvm+HA==",
882
+ "peer": true,
883
+ "bin": {
884
+ "tsc": "bin/tsc",
885
+ "tsserver": "bin/tsserver"
886
+ },
887
+ "engines": {
888
+ "node": ">=14.17"
889
+ }
890
+ },
891
+ "node_modules/unpipe": {
892
+ "version": "1.0.0",
893
+ "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
894
+ "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==",
895
+ "engines": {
896
+ "node": ">= 0.8"
897
+ }
898
+ },
899
+ "node_modules/utils-merge": {
900
+ "version": "1.0.1",
901
+ "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
902
+ "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==",
903
+ "engines": {
904
+ "node": ">= 0.4.0"
905
+ }
906
+ },
907
+ "node_modules/v8-compile-cache-lib": {
908
+ "version": "3.0.1",
909
+ "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz",
910
+ "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg=="
911
+ },
912
+ "node_modules/vary": {
913
+ "version": "1.1.2",
914
+ "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
915
+ "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==",
916
+ "engines": {
917
+ "node": ">= 0.8"
918
+ }
919
+ },
920
+ "node_modules/web-streams-polyfill": {
921
+ "version": "3.2.1",
922
+ "resolved": "https://registry.npmjs.org/web-streams-polyfill/-/web-streams-polyfill-3.2.1.tgz",
923
+ "integrity": "sha512-e0MO3wdXWKrLbL0DgGnUV7WHVuw9OUvL4hjgnPkIeEvESk74gAITi5G606JtZPp39cd8HA9VQzCIvA49LpPN5Q==",
924
+ "engines": {
925
+ "node": ">= 8"
926
+ }
927
+ },
928
+ "node_modules/yn": {
929
+ "version": "3.1.1",
930
+ "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz",
931
+ "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==",
932
+ "engines": {
933
+ "node": ">=6"
934
+ }
935
+ }
936
+ }
937
+ }
package.json ADDED
@@ -0,0 +1,21 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "name": "ai-webtv",
3
+ "version": "1.0.0",
4
+ "description": "A generative AI WebTV",
5
+ "main": "src/index.mts",
6
+ "scripts": {
7
+ "start": "node --loader ts-node/esm src/index.mts",
8
+ "test": "node --loader ts-node/esm src/test.mts",
9
+ "docker": "npm run docker:build && npm run docker:run",
10
+ "docker:build": "docker build -t ai-webtv .",
11
+ "docker:run": "docker run -it -p 7860:7860 ai-webtv"
12
+ },
13
+ "author": "Julian Bilcke <julian.bilcke@huggingface.co>",
14
+ "license": "Apache License",
15
+ "dependencies": {
16
+ "@types/express": "^4.17.17",
17
+ "express": "^4.18.2",
18
+ "node-fetch": "^3.3.1",
19
+ "ts-node": "^10.9.1"
20
+ }
21
+ }
public/index.html ADDED
@@ -0,0 +1,24 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <html>
2
+ <head>
3
+ <title>AI WebTV</title>
4
+ <link href="https://cdn.jsdelivr.net/npm/daisyui@3.1.6/dist/full.css" rel="stylesheet" type="text/css" />
5
+ <script defer src="https://cdn.jsdelivr.net/npm/alpinejs@3.x.x/dist/cdn.min.js"></script>
6
+ <script src="https://cdn.tailwindcss.com?plugins=forms,typography,aspect-ratio"></script>
7
+ <script src="https://cdnjs.cloudflare.com/ajax/libs/iframe-resizer/4.3.2/iframeResizer.contentWindow.min.js"></script>
8
+ <script src="https://cdn.dashjs.org/latest/dash.all.min.js"></script>
9
+ </head>
10
+ <body>
11
+ <div class="w-full h-48">
12
+ <iframe src="/stats" width="500" height="500"></iframe>
13
+ </div>
14
+ <div>
15
+ <video
16
+ data-dashjs-player
17
+ autoplay
18
+ src="https://jbilcke-hf-media-server.hf.space/live/webtv/index.mpd"
19
+ controls
20
+ class="w-full"
21
+ ></video>
22
+ </div>
23
+ </body>
24
+ </html>
src/index.mts ADDED
@@ -0,0 +1,8 @@
 
 
 
 
 
 
 
 
 
1
+ import express from 'express'
2
+
3
+ const app = express()
4
+ const port = 7860
5
+
6
+ app.use(express.static('public'))
7
+
8
+ app.listen(port, () => { console.log(`Open http://localhost:${port}`) })
tsconfig.json ADDED
@@ -0,0 +1,12 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "compilerOptions": {
3
+ "allowJs": true,
4
+ "esModuleInterop": true,
5
+ "allowSyntheticDefaultImports": true,
6
+ "module": "nodenext",
7
+ "noEmit": true,
8
+ "allowImportingTsExtensions": true,
9
+ "target": "es2017"
10
+ },
11
+ "include": ["**/*.ts", "**/*.mts"],
12
+ }