root commited on
Commit
675e98c
·
1 Parent(s): 54eefdf

update space

Browse files
.gitignore ADDED
@@ -0,0 +1,4 @@
 
 
 
 
 
1
+ node_modules/
2
+ uploads/
3
+ .env
4
+ .DS_Store
Dockerfile ADDED
@@ -0,0 +1,26 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ FROM node:18-alpine
2
+
3
+ WORKDIR /usr/src/app
4
+
5
+ COPY package.json package-lock.json ./
6
+
7
+ RUN npm ci --only=production
8
+
9
+ COPY . .
10
+
11
+ RUN mkdir -p uploads && chown -R node:node uploads
12
+
13
+ ENV PORT=7860
14
+ ENV NODE_ENV=production
15
+
16
+ # Use this for local development
17
+ # ENV DOMAIN=localhost
18
+
19
+ # Use this for production
20
+ ENV DOMAIN=fourstore-uploader.hf.space
21
+
22
+ USER node
23
+
24
+ EXPOSE 7860
25
+
26
+ CMD ["npm", "start"]
README.md CHANGED
@@ -3,9 +3,8 @@ title: Uploader
3
  emoji: 📈
4
  colorFrom: red
5
  colorTo: blue
6
- sdk: gradio
7
  sdk_version: 5.34.1
8
- app_file: app.py
9
  pinned: false
10
  license: apache-2.0
11
  short_description: Swagger
 
3
  emoji: 📈
4
  colorFrom: red
5
  colorTo: blue
6
+ sdk: docker
7
  sdk_version: 5.34.1
 
8
  pinned: false
9
  license: apache-2.0
10
  short_description: Swagger
package-lock.json ADDED
@@ -0,0 +1,1448 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "name": "whatsapp-uploader",
3
+ "version": "1.0.0",
4
+ "lockfileVersion": 3,
5
+ "requires": true,
6
+ "packages": {
7
+ "": {
8
+ "name": "whatsapp-uploader",
9
+ "version": "1.0.0",
10
+ "dependencies": {
11
+ "cors": "^2.8.5",
12
+ "dotenv": "^16.5.0",
13
+ "express": "^4.18.2",
14
+ "helmet": "^8.1.0",
15
+ "multer": "^1.4.5-lts.1",
16
+ "swagger-ui-express": "^5.0.0"
17
+ },
18
+ "devDependencies": {
19
+ "nodemon": "^3.0.2"
20
+ }
21
+ },
22
+ "node_modules/@scarf/scarf": {
23
+ "version": "1.4.0",
24
+ "resolved": "https://registry.npmjs.org/@scarf/scarf/-/scarf-1.4.0.tgz",
25
+ "integrity": "sha512-xxeapPiUXdZAE3che6f3xogoJPeZgig6omHEy1rIY5WVsB3H2BHNnZH+gHG6x91SCWyQCzWGsuL2Hh3ClO5/qQ==",
26
+ "hasInstallScript": true,
27
+ "license": "Apache-2.0"
28
+ },
29
+ "node_modules/accepts": {
30
+ "version": "1.3.8",
31
+ "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz",
32
+ "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==",
33
+ "license": "MIT",
34
+ "dependencies": {
35
+ "mime-types": "~2.1.34",
36
+ "negotiator": "0.6.3"
37
+ },
38
+ "engines": {
39
+ "node": ">= 0.6"
40
+ }
41
+ },
42
+ "node_modules/anymatch": {
43
+ "version": "3.1.3",
44
+ "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz",
45
+ "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==",
46
+ "dev": true,
47
+ "license": "ISC",
48
+ "dependencies": {
49
+ "normalize-path": "^3.0.0",
50
+ "picomatch": "^2.0.4"
51
+ },
52
+ "engines": {
53
+ "node": ">= 8"
54
+ }
55
+ },
56
+ "node_modules/append-field": {
57
+ "version": "1.0.0",
58
+ "resolved": "https://registry.npmjs.org/append-field/-/append-field-1.0.0.tgz",
59
+ "integrity": "sha512-klpgFSWLW1ZEs8svjfb7g4qWY0YS5imI82dTg+QahUvJ8YqAY0P10Uk8tTyh9ZGuYEZEMaeJYCF5BFuX552hsw==",
60
+ "license": "MIT"
61
+ },
62
+ "node_modules/array-flatten": {
63
+ "version": "1.1.1",
64
+ "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
65
+ "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==",
66
+ "license": "MIT"
67
+ },
68
+ "node_modules/balanced-match": {
69
+ "version": "1.0.2",
70
+ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
71
+ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
72
+ "dev": true,
73
+ "license": "MIT"
74
+ },
75
+ "node_modules/binary-extensions": {
76
+ "version": "2.3.0",
77
+ "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz",
78
+ "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==",
79
+ "dev": true,
80
+ "license": "MIT",
81
+ "engines": {
82
+ "node": ">=8"
83
+ },
84
+ "funding": {
85
+ "url": "https://github.com/sponsors/sindresorhus"
86
+ }
87
+ },
88
+ "node_modules/body-parser": {
89
+ "version": "1.20.3",
90
+ "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.3.tgz",
91
+ "integrity": "sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g==",
92
+ "license": "MIT",
93
+ "dependencies": {
94
+ "bytes": "3.1.2",
95
+ "content-type": "~1.0.5",
96
+ "debug": "2.6.9",
97
+ "depd": "2.0.0",
98
+ "destroy": "1.2.0",
99
+ "http-errors": "2.0.0",
100
+ "iconv-lite": "0.4.24",
101
+ "on-finished": "2.4.1",
102
+ "qs": "6.13.0",
103
+ "raw-body": "2.5.2",
104
+ "type-is": "~1.6.18",
105
+ "unpipe": "1.0.0"
106
+ },
107
+ "engines": {
108
+ "node": ">= 0.8",
109
+ "npm": "1.2.8000 || >= 1.4.16"
110
+ }
111
+ },
112
+ "node_modules/brace-expansion": {
113
+ "version": "1.1.12",
114
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.12.tgz",
115
+ "integrity": "sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg==",
116
+ "dev": true,
117
+ "license": "MIT",
118
+ "dependencies": {
119
+ "balanced-match": "^1.0.0",
120
+ "concat-map": "0.0.1"
121
+ }
122
+ },
123
+ "node_modules/braces": {
124
+ "version": "3.0.3",
125
+ "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz",
126
+ "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==",
127
+ "dev": true,
128
+ "license": "MIT",
129
+ "dependencies": {
130
+ "fill-range": "^7.1.1"
131
+ },
132
+ "engines": {
133
+ "node": ">=8"
134
+ }
135
+ },
136
+ "node_modules/buffer-from": {
137
+ "version": "1.1.2",
138
+ "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz",
139
+ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==",
140
+ "license": "MIT"
141
+ },
142
+ "node_modules/busboy": {
143
+ "version": "1.6.0",
144
+ "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz",
145
+ "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==",
146
+ "dependencies": {
147
+ "streamsearch": "^1.1.0"
148
+ },
149
+ "engines": {
150
+ "node": ">=10.16.0"
151
+ }
152
+ },
153
+ "node_modules/bytes": {
154
+ "version": "3.1.2",
155
+ "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz",
156
+ "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==",
157
+ "license": "MIT",
158
+ "engines": {
159
+ "node": ">= 0.8"
160
+ }
161
+ },
162
+ "node_modules/call-bind-apply-helpers": {
163
+ "version": "1.0.2",
164
+ "resolved": "https://registry.npmjs.org/call-bind-apply-helpers/-/call-bind-apply-helpers-1.0.2.tgz",
165
+ "integrity": "sha512-Sp1ablJ0ivDkSzjcaJdxEunN5/XvksFJ2sMBFfq6x0ryhQV/2b/KwFe21cMpmHtPOSij8K99/wSfoEuTObmuMQ==",
166
+ "license": "MIT",
167
+ "dependencies": {
168
+ "es-errors": "^1.3.0",
169
+ "function-bind": "^1.1.2"
170
+ },
171
+ "engines": {
172
+ "node": ">= 0.4"
173
+ }
174
+ },
175
+ "node_modules/call-bound": {
176
+ "version": "1.0.4",
177
+ "resolved": "https://registry.npmjs.org/call-bound/-/call-bound-1.0.4.tgz",
178
+ "integrity": "sha512-+ys997U96po4Kx/ABpBCqhA9EuxJaQWDQg7295H4hBphv3IZg0boBKuwYpt4YXp6MZ5AmZQnU/tyMTlRpaSejg==",
179
+ "license": "MIT",
180
+ "dependencies": {
181
+ "call-bind-apply-helpers": "^1.0.2",
182
+ "get-intrinsic": "^1.3.0"
183
+ },
184
+ "engines": {
185
+ "node": ">= 0.4"
186
+ },
187
+ "funding": {
188
+ "url": "https://github.com/sponsors/ljharb"
189
+ }
190
+ },
191
+ "node_modules/chokidar": {
192
+ "version": "3.6.0",
193
+ "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz",
194
+ "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==",
195
+ "dev": true,
196
+ "license": "MIT",
197
+ "dependencies": {
198
+ "anymatch": "~3.1.2",
199
+ "braces": "~3.0.2",
200
+ "glob-parent": "~5.1.2",
201
+ "is-binary-path": "~2.1.0",
202
+ "is-glob": "~4.0.1",
203
+ "normalize-path": "~3.0.0",
204
+ "readdirp": "~3.6.0"
205
+ },
206
+ "engines": {
207
+ "node": ">= 8.10.0"
208
+ },
209
+ "funding": {
210
+ "url": "https://paulmillr.com/funding/"
211
+ },
212
+ "optionalDependencies": {
213
+ "fsevents": "~2.3.2"
214
+ }
215
+ },
216
+ "node_modules/concat-map": {
217
+ "version": "0.0.1",
218
+ "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
219
+ "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==",
220
+ "dev": true,
221
+ "license": "MIT"
222
+ },
223
+ "node_modules/concat-stream": {
224
+ "version": "1.6.2",
225
+ "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz",
226
+ "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==",
227
+ "engines": [
228
+ "node >= 0.8"
229
+ ],
230
+ "license": "MIT",
231
+ "dependencies": {
232
+ "buffer-from": "^1.0.0",
233
+ "inherits": "^2.0.3",
234
+ "readable-stream": "^2.2.2",
235
+ "typedarray": "^0.0.6"
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
+ "license": "MIT",
243
+ "dependencies": {
244
+ "safe-buffer": "5.2.1"
245
+ },
246
+ "engines": {
247
+ "node": ">= 0.6"
248
+ }
249
+ },
250
+ "node_modules/content-type": {
251
+ "version": "1.0.5",
252
+ "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz",
253
+ "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==",
254
+ "license": "MIT",
255
+ "engines": {
256
+ "node": ">= 0.6"
257
+ }
258
+ },
259
+ "node_modules/cookie": {
260
+ "version": "0.7.1",
261
+ "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.7.1.tgz",
262
+ "integrity": "sha512-6DnInpx7SJ2AK3+CTUE/ZM0vWTUboZCegxhC2xiIydHR9jNuTAASBrfEpHhiGOZw/nX51bHt6YQl8jsGo4y/0w==",
263
+ "license": "MIT",
264
+ "engines": {
265
+ "node": ">= 0.6"
266
+ }
267
+ },
268
+ "node_modules/cookie-signature": {
269
+ "version": "1.0.6",
270
+ "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
271
+ "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==",
272
+ "license": "MIT"
273
+ },
274
+ "node_modules/core-util-is": {
275
+ "version": "1.0.3",
276
+ "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz",
277
+ "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==",
278
+ "license": "MIT"
279
+ },
280
+ "node_modules/cors": {
281
+ "version": "2.8.5",
282
+ "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz",
283
+ "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==",
284
+ "license": "MIT",
285
+ "dependencies": {
286
+ "object-assign": "^4",
287
+ "vary": "^1"
288
+ },
289
+ "engines": {
290
+ "node": ">= 0.10"
291
+ }
292
+ },
293
+ "node_modules/debug": {
294
+ "version": "2.6.9",
295
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
296
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
297
+ "license": "MIT",
298
+ "dependencies": {
299
+ "ms": "2.0.0"
300
+ }
301
+ },
302
+ "node_modules/depd": {
303
+ "version": "2.0.0",
304
+ "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz",
305
+ "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==",
306
+ "license": "MIT",
307
+ "engines": {
308
+ "node": ">= 0.8"
309
+ }
310
+ },
311
+ "node_modules/destroy": {
312
+ "version": "1.2.0",
313
+ "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz",
314
+ "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==",
315
+ "license": "MIT",
316
+ "engines": {
317
+ "node": ">= 0.8",
318
+ "npm": "1.2.8000 || >= 1.4.16"
319
+ }
320
+ },
321
+ "node_modules/dotenv": {
322
+ "version": "16.5.0",
323
+ "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.5.0.tgz",
324
+ "integrity": "sha512-m/C+AwOAr9/W1UOIZUo232ejMNnJAJtYQjUbHoNTBNTJSvqzzDh7vnrei3o3r3m9blf6ZoDkvcw0VmozNRFJxg==",
325
+ "license": "BSD-2-Clause",
326
+ "engines": {
327
+ "node": ">=12"
328
+ },
329
+ "funding": {
330
+ "url": "https://dotenvx.com"
331
+ }
332
+ },
333
+ "node_modules/dunder-proto": {
334
+ "version": "1.0.1",
335
+ "resolved": "https://registry.npmjs.org/dunder-proto/-/dunder-proto-1.0.1.tgz",
336
+ "integrity": "sha512-KIN/nDJBQRcXw0MLVhZE9iQHmG68qAVIBg9CqmUYjmQIhgij9U5MFvrqkUL5FbtyyzZuOeOt0zdeRe4UY7ct+A==",
337
+ "license": "MIT",
338
+ "dependencies": {
339
+ "call-bind-apply-helpers": "^1.0.1",
340
+ "es-errors": "^1.3.0",
341
+ "gopd": "^1.2.0"
342
+ },
343
+ "engines": {
344
+ "node": ">= 0.4"
345
+ }
346
+ },
347
+ "node_modules/ee-first": {
348
+ "version": "1.1.1",
349
+ "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
350
+ "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==",
351
+ "license": "MIT"
352
+ },
353
+ "node_modules/encodeurl": {
354
+ "version": "2.0.0",
355
+ "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-2.0.0.tgz",
356
+ "integrity": "sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg==",
357
+ "license": "MIT",
358
+ "engines": {
359
+ "node": ">= 0.8"
360
+ }
361
+ },
362
+ "node_modules/es-define-property": {
363
+ "version": "1.0.1",
364
+ "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.1.tgz",
365
+ "integrity": "sha512-e3nRfgfUZ4rNGL232gUgX06QNyyez04KdjFrF+LTRoOXmrOgFKDg4BCdsjW8EnT69eqdYGmRpJwiPVYNrCaW3g==",
366
+ "license": "MIT",
367
+ "engines": {
368
+ "node": ">= 0.4"
369
+ }
370
+ },
371
+ "node_modules/es-errors": {
372
+ "version": "1.3.0",
373
+ "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz",
374
+ "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==",
375
+ "license": "MIT",
376
+ "engines": {
377
+ "node": ">= 0.4"
378
+ }
379
+ },
380
+ "node_modules/es-object-atoms": {
381
+ "version": "1.1.1",
382
+ "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.1.1.tgz",
383
+ "integrity": "sha512-FGgH2h8zKNim9ljj7dankFPcICIK9Cp5bm+c2gQSYePhpaG5+esrLODihIorn+Pe6FGJzWhXQotPv73jTaldXA==",
384
+ "license": "MIT",
385
+ "dependencies": {
386
+ "es-errors": "^1.3.0"
387
+ },
388
+ "engines": {
389
+ "node": ">= 0.4"
390
+ }
391
+ },
392
+ "node_modules/escape-html": {
393
+ "version": "1.0.3",
394
+ "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
395
+ "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==",
396
+ "license": "MIT"
397
+ },
398
+ "node_modules/etag": {
399
+ "version": "1.8.1",
400
+ "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
401
+ "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==",
402
+ "license": "MIT",
403
+ "engines": {
404
+ "node": ">= 0.6"
405
+ }
406
+ },
407
+ "node_modules/express": {
408
+ "version": "4.21.2",
409
+ "resolved": "https://registry.npmjs.org/express/-/express-4.21.2.tgz",
410
+ "integrity": "sha512-28HqgMZAmih1Czt9ny7qr6ek2qddF4FclbMzwhCREB6OFfH+rXAnuNCwo1/wFvrtbgsQDb4kSbX9de9lFbrXnA==",
411
+ "license": "MIT",
412
+ "dependencies": {
413
+ "accepts": "~1.3.8",
414
+ "array-flatten": "1.1.1",
415
+ "body-parser": "1.20.3",
416
+ "content-disposition": "0.5.4",
417
+ "content-type": "~1.0.4",
418
+ "cookie": "0.7.1",
419
+ "cookie-signature": "1.0.6",
420
+ "debug": "2.6.9",
421
+ "depd": "2.0.0",
422
+ "encodeurl": "~2.0.0",
423
+ "escape-html": "~1.0.3",
424
+ "etag": "~1.8.1",
425
+ "finalhandler": "1.3.1",
426
+ "fresh": "0.5.2",
427
+ "http-errors": "2.0.0",
428
+ "merge-descriptors": "1.0.3",
429
+ "methods": "~1.1.2",
430
+ "on-finished": "2.4.1",
431
+ "parseurl": "~1.3.3",
432
+ "path-to-regexp": "0.1.12",
433
+ "proxy-addr": "~2.0.7",
434
+ "qs": "6.13.0",
435
+ "range-parser": "~1.2.1",
436
+ "safe-buffer": "5.2.1",
437
+ "send": "0.19.0",
438
+ "serve-static": "1.16.2",
439
+ "setprototypeof": "1.2.0",
440
+ "statuses": "2.0.1",
441
+ "type-is": "~1.6.18",
442
+ "utils-merge": "1.0.1",
443
+ "vary": "~1.1.2"
444
+ },
445
+ "engines": {
446
+ "node": ">= 0.10.0"
447
+ },
448
+ "funding": {
449
+ "type": "opencollective",
450
+ "url": "https://opencollective.com/express"
451
+ }
452
+ },
453
+ "node_modules/fill-range": {
454
+ "version": "7.1.1",
455
+ "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz",
456
+ "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==",
457
+ "dev": true,
458
+ "license": "MIT",
459
+ "dependencies": {
460
+ "to-regex-range": "^5.0.1"
461
+ },
462
+ "engines": {
463
+ "node": ">=8"
464
+ }
465
+ },
466
+ "node_modules/finalhandler": {
467
+ "version": "1.3.1",
468
+ "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.3.1.tgz",
469
+ "integrity": "sha512-6BN9trH7bp3qvnrRyzsBz+g3lZxTNZTbVO2EV1CS0WIcDbawYVdYvGflME/9QP0h0pYlCDBCTjYa9nZzMDpyxQ==",
470
+ "license": "MIT",
471
+ "dependencies": {
472
+ "debug": "2.6.9",
473
+ "encodeurl": "~2.0.0",
474
+ "escape-html": "~1.0.3",
475
+ "on-finished": "2.4.1",
476
+ "parseurl": "~1.3.3",
477
+ "statuses": "2.0.1",
478
+ "unpipe": "~1.0.0"
479
+ },
480
+ "engines": {
481
+ "node": ">= 0.8"
482
+ }
483
+ },
484
+ "node_modules/forwarded": {
485
+ "version": "0.2.0",
486
+ "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz",
487
+ "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==",
488
+ "license": "MIT",
489
+ "engines": {
490
+ "node": ">= 0.6"
491
+ }
492
+ },
493
+ "node_modules/fresh": {
494
+ "version": "0.5.2",
495
+ "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
496
+ "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==",
497
+ "license": "MIT",
498
+ "engines": {
499
+ "node": ">= 0.6"
500
+ }
501
+ },
502
+ "node_modules/fsevents": {
503
+ "version": "2.3.3",
504
+ "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz",
505
+ "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==",
506
+ "dev": true,
507
+ "hasInstallScript": true,
508
+ "license": "MIT",
509
+ "optional": true,
510
+ "os": [
511
+ "darwin"
512
+ ],
513
+ "engines": {
514
+ "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
515
+ }
516
+ },
517
+ "node_modules/function-bind": {
518
+ "version": "1.1.2",
519
+ "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz",
520
+ "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==",
521
+ "license": "MIT",
522
+ "funding": {
523
+ "url": "https://github.com/sponsors/ljharb"
524
+ }
525
+ },
526
+ "node_modules/get-intrinsic": {
527
+ "version": "1.3.0",
528
+ "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.3.0.tgz",
529
+ "integrity": "sha512-9fSjSaos/fRIVIp+xSJlE6lfwhES7LNtKaCBIamHsjr2na1BiABJPo0mOjjz8GJDURarmCPGqaiVg5mfjb98CQ==",
530
+ "license": "MIT",
531
+ "dependencies": {
532
+ "call-bind-apply-helpers": "^1.0.2",
533
+ "es-define-property": "^1.0.1",
534
+ "es-errors": "^1.3.0",
535
+ "es-object-atoms": "^1.1.1",
536
+ "function-bind": "^1.1.2",
537
+ "get-proto": "^1.0.1",
538
+ "gopd": "^1.2.0",
539
+ "has-symbols": "^1.1.0",
540
+ "hasown": "^2.0.2",
541
+ "math-intrinsics": "^1.1.0"
542
+ },
543
+ "engines": {
544
+ "node": ">= 0.4"
545
+ },
546
+ "funding": {
547
+ "url": "https://github.com/sponsors/ljharb"
548
+ }
549
+ },
550
+ "node_modules/get-proto": {
551
+ "version": "1.0.1",
552
+ "resolved": "https://registry.npmjs.org/get-proto/-/get-proto-1.0.1.tgz",
553
+ "integrity": "sha512-sTSfBjoXBp89JvIKIefqw7U2CCebsc74kiY6awiGogKtoSGbgjYE/G/+l9sF3MWFPNc9IcoOC4ODfKHfxFmp0g==",
554
+ "license": "MIT",
555
+ "dependencies": {
556
+ "dunder-proto": "^1.0.1",
557
+ "es-object-atoms": "^1.0.0"
558
+ },
559
+ "engines": {
560
+ "node": ">= 0.4"
561
+ }
562
+ },
563
+ "node_modules/glob-parent": {
564
+ "version": "5.1.2",
565
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
566
+ "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
567
+ "dev": true,
568
+ "license": "ISC",
569
+ "dependencies": {
570
+ "is-glob": "^4.0.1"
571
+ },
572
+ "engines": {
573
+ "node": ">= 6"
574
+ }
575
+ },
576
+ "node_modules/gopd": {
577
+ "version": "1.2.0",
578
+ "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.2.0.tgz",
579
+ "integrity": "sha512-ZUKRh6/kUFoAiTAtTYPZJ3hw9wNxx+BIBOijnlG9PnrJsCcSjs1wyyD6vJpaYtgnzDrKYRSqf3OO6Rfa93xsRg==",
580
+ "license": "MIT",
581
+ "engines": {
582
+ "node": ">= 0.4"
583
+ },
584
+ "funding": {
585
+ "url": "https://github.com/sponsors/ljharb"
586
+ }
587
+ },
588
+ "node_modules/has-flag": {
589
+ "version": "3.0.0",
590
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
591
+ "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==",
592
+ "dev": true,
593
+ "license": "MIT",
594
+ "engines": {
595
+ "node": ">=4"
596
+ }
597
+ },
598
+ "node_modules/has-symbols": {
599
+ "version": "1.1.0",
600
+ "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.1.0.tgz",
601
+ "integrity": "sha512-1cDNdwJ2Jaohmb3sg4OmKaMBwuC48sYni5HUw2DvsC8LjGTLK9h+eb1X6RyuOHe4hT0ULCW68iomhjUoKUqlPQ==",
602
+ "license": "MIT",
603
+ "engines": {
604
+ "node": ">= 0.4"
605
+ },
606
+ "funding": {
607
+ "url": "https://github.com/sponsors/ljharb"
608
+ }
609
+ },
610
+ "node_modules/hasown": {
611
+ "version": "2.0.2",
612
+ "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz",
613
+ "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==",
614
+ "license": "MIT",
615
+ "dependencies": {
616
+ "function-bind": "^1.1.2"
617
+ },
618
+ "engines": {
619
+ "node": ">= 0.4"
620
+ }
621
+ },
622
+ "node_modules/helmet": {
623
+ "version": "8.1.0",
624
+ "resolved": "https://registry.npmjs.org/helmet/-/helmet-8.1.0.tgz",
625
+ "integrity": "sha512-jOiHyAZsmnr8LqoPGmCjYAaiuWwjAPLgY8ZX2XrmHawt99/u1y6RgrZMTeoPfpUbV96HOalYgz1qzkRbw54Pmg==",
626
+ "license": "MIT",
627
+ "engines": {
628
+ "node": ">=18.0.0"
629
+ }
630
+ },
631
+ "node_modules/http-errors": {
632
+ "version": "2.0.0",
633
+ "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz",
634
+ "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==",
635
+ "license": "MIT",
636
+ "dependencies": {
637
+ "depd": "2.0.0",
638
+ "inherits": "2.0.4",
639
+ "setprototypeof": "1.2.0",
640
+ "statuses": "2.0.1",
641
+ "toidentifier": "1.0.1"
642
+ },
643
+ "engines": {
644
+ "node": ">= 0.8"
645
+ }
646
+ },
647
+ "node_modules/iconv-lite": {
648
+ "version": "0.4.24",
649
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
650
+ "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
651
+ "license": "MIT",
652
+ "dependencies": {
653
+ "safer-buffer": ">= 2.1.2 < 3"
654
+ },
655
+ "engines": {
656
+ "node": ">=0.10.0"
657
+ }
658
+ },
659
+ "node_modules/ignore-by-default": {
660
+ "version": "1.0.1",
661
+ "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz",
662
+ "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==",
663
+ "dev": true,
664
+ "license": "ISC"
665
+ },
666
+ "node_modules/inherits": {
667
+ "version": "2.0.4",
668
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
669
+ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==",
670
+ "license": "ISC"
671
+ },
672
+ "node_modules/ipaddr.js": {
673
+ "version": "1.9.1",
674
+ "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz",
675
+ "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==",
676
+ "license": "MIT",
677
+ "engines": {
678
+ "node": ">= 0.10"
679
+ }
680
+ },
681
+ "node_modules/is-binary-path": {
682
+ "version": "2.1.0",
683
+ "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
684
+ "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
685
+ "dev": true,
686
+ "license": "MIT",
687
+ "dependencies": {
688
+ "binary-extensions": "^2.0.0"
689
+ },
690
+ "engines": {
691
+ "node": ">=8"
692
+ }
693
+ },
694
+ "node_modules/is-extglob": {
695
+ "version": "2.1.1",
696
+ "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
697
+ "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
698
+ "dev": true,
699
+ "license": "MIT",
700
+ "engines": {
701
+ "node": ">=0.10.0"
702
+ }
703
+ },
704
+ "node_modules/is-glob": {
705
+ "version": "4.0.3",
706
+ "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
707
+ "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
708
+ "dev": true,
709
+ "license": "MIT",
710
+ "dependencies": {
711
+ "is-extglob": "^2.1.1"
712
+ },
713
+ "engines": {
714
+ "node": ">=0.10.0"
715
+ }
716
+ },
717
+ "node_modules/is-number": {
718
+ "version": "7.0.0",
719
+ "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
720
+ "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
721
+ "dev": true,
722
+ "license": "MIT",
723
+ "engines": {
724
+ "node": ">=0.12.0"
725
+ }
726
+ },
727
+ "node_modules/isarray": {
728
+ "version": "1.0.0",
729
+ "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
730
+ "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==",
731
+ "license": "MIT"
732
+ },
733
+ "node_modules/math-intrinsics": {
734
+ "version": "1.1.0",
735
+ "resolved": "https://registry.npmjs.org/math-intrinsics/-/math-intrinsics-1.1.0.tgz",
736
+ "integrity": "sha512-/IXtbwEk5HTPyEwyKX6hGkYXxM9nbj64B+ilVJnC/R6B0pH5G4V3b0pVbL7DBj4tkhBAppbQUlf6F6Xl9LHu1g==",
737
+ "license": "MIT",
738
+ "engines": {
739
+ "node": ">= 0.4"
740
+ }
741
+ },
742
+ "node_modules/media-typer": {
743
+ "version": "0.3.0",
744
+ "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
745
+ "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==",
746
+ "license": "MIT",
747
+ "engines": {
748
+ "node": ">= 0.6"
749
+ }
750
+ },
751
+ "node_modules/merge-descriptors": {
752
+ "version": "1.0.3",
753
+ "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.3.tgz",
754
+ "integrity": "sha512-gaNvAS7TZ897/rVaZ0nMtAyxNyi/pdbjbAwUpFQpN70GqnVfOiXpeUUMKRBmzXaSQ8DdTX4/0ms62r2K+hE6mQ==",
755
+ "license": "MIT",
756
+ "funding": {
757
+ "url": "https://github.com/sponsors/sindresorhus"
758
+ }
759
+ },
760
+ "node_modules/methods": {
761
+ "version": "1.1.2",
762
+ "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
763
+ "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==",
764
+ "license": "MIT",
765
+ "engines": {
766
+ "node": ">= 0.6"
767
+ }
768
+ },
769
+ "node_modules/mime": {
770
+ "version": "1.6.0",
771
+ "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
772
+ "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
773
+ "license": "MIT",
774
+ "bin": {
775
+ "mime": "cli.js"
776
+ },
777
+ "engines": {
778
+ "node": ">=4"
779
+ }
780
+ },
781
+ "node_modules/mime-db": {
782
+ "version": "1.52.0",
783
+ "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
784
+ "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
785
+ "license": "MIT",
786
+ "engines": {
787
+ "node": ">= 0.6"
788
+ }
789
+ },
790
+ "node_modules/mime-types": {
791
+ "version": "2.1.35",
792
+ "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
793
+ "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
794
+ "license": "MIT",
795
+ "dependencies": {
796
+ "mime-db": "1.52.0"
797
+ },
798
+ "engines": {
799
+ "node": ">= 0.6"
800
+ }
801
+ },
802
+ "node_modules/minimatch": {
803
+ "version": "3.1.2",
804
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
805
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
806
+ "dev": true,
807
+ "license": "ISC",
808
+ "dependencies": {
809
+ "brace-expansion": "^1.1.7"
810
+ },
811
+ "engines": {
812
+ "node": "*"
813
+ }
814
+ },
815
+ "node_modules/minimist": {
816
+ "version": "1.2.8",
817
+ "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz",
818
+ "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==",
819
+ "license": "MIT",
820
+ "funding": {
821
+ "url": "https://github.com/sponsors/ljharb"
822
+ }
823
+ },
824
+ "node_modules/mkdirp": {
825
+ "version": "0.5.6",
826
+ "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz",
827
+ "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==",
828
+ "license": "MIT",
829
+ "dependencies": {
830
+ "minimist": "^1.2.6"
831
+ },
832
+ "bin": {
833
+ "mkdirp": "bin/cmd.js"
834
+ }
835
+ },
836
+ "node_modules/ms": {
837
+ "version": "2.0.0",
838
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
839
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
840
+ "license": "MIT"
841
+ },
842
+ "node_modules/multer": {
843
+ "version": "1.4.5-lts.2",
844
+ "resolved": "https://registry.npmjs.org/multer/-/multer-1.4.5-lts.2.tgz",
845
+ "integrity": "sha512-VzGiVigcG9zUAoCNU+xShztrlr1auZOlurXynNvO9GiWD1/mTBbUljOKY+qMeazBqXgRnjzeEgJI/wyjJUHg9A==",
846
+ "deprecated": "Multer 1.x is impacted by a number of vulnerabilities, which have been patched in 2.x. You should upgrade to the latest 2.x version.",
847
+ "license": "MIT",
848
+ "dependencies": {
849
+ "append-field": "^1.0.0",
850
+ "busboy": "^1.0.0",
851
+ "concat-stream": "^1.5.2",
852
+ "mkdirp": "^0.5.4",
853
+ "object-assign": "^4.1.1",
854
+ "type-is": "^1.6.4",
855
+ "xtend": "^4.0.0"
856
+ },
857
+ "engines": {
858
+ "node": ">= 6.0.0"
859
+ }
860
+ },
861
+ "node_modules/negotiator": {
862
+ "version": "0.6.3",
863
+ "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz",
864
+ "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==",
865
+ "license": "MIT",
866
+ "engines": {
867
+ "node": ">= 0.6"
868
+ }
869
+ },
870
+ "node_modules/nodemon": {
871
+ "version": "3.1.10",
872
+ "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-3.1.10.tgz",
873
+ "integrity": "sha512-WDjw3pJ0/0jMFmyNDp3gvY2YizjLmmOUQo6DEBY+JgdvW/yQ9mEeSw6H5ythl5Ny2ytb7f9C2nIbjSxMNzbJXw==",
874
+ "dev": true,
875
+ "license": "MIT",
876
+ "dependencies": {
877
+ "chokidar": "^3.5.2",
878
+ "debug": "^4",
879
+ "ignore-by-default": "^1.0.1",
880
+ "minimatch": "^3.1.2",
881
+ "pstree.remy": "^1.1.8",
882
+ "semver": "^7.5.3",
883
+ "simple-update-notifier": "^2.0.0",
884
+ "supports-color": "^5.5.0",
885
+ "touch": "^3.1.0",
886
+ "undefsafe": "^2.0.5"
887
+ },
888
+ "bin": {
889
+ "nodemon": "bin/nodemon.js"
890
+ },
891
+ "engines": {
892
+ "node": ">=10"
893
+ },
894
+ "funding": {
895
+ "type": "opencollective",
896
+ "url": "https://opencollective.com/nodemon"
897
+ }
898
+ },
899
+ "node_modules/nodemon/node_modules/debug": {
900
+ "version": "4.4.1",
901
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.1.tgz",
902
+ "integrity": "sha512-KcKCqiftBJcZr++7ykoDIEwSa3XWowTfNPo92BYxjXiyYEVrUQh2aLyhxBCwww+heortUFxEJYcRzosstTEBYQ==",
903
+ "dev": true,
904
+ "license": "MIT",
905
+ "dependencies": {
906
+ "ms": "^2.1.3"
907
+ },
908
+ "engines": {
909
+ "node": ">=6.0"
910
+ },
911
+ "peerDependenciesMeta": {
912
+ "supports-color": {
913
+ "optional": true
914
+ }
915
+ }
916
+ },
917
+ "node_modules/nodemon/node_modules/ms": {
918
+ "version": "2.1.3",
919
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
920
+ "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
921
+ "dev": true,
922
+ "license": "MIT"
923
+ },
924
+ "node_modules/normalize-path": {
925
+ "version": "3.0.0",
926
+ "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
927
+ "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
928
+ "dev": true,
929
+ "license": "MIT",
930
+ "engines": {
931
+ "node": ">=0.10.0"
932
+ }
933
+ },
934
+ "node_modules/object-assign": {
935
+ "version": "4.1.1",
936
+ "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
937
+ "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==",
938
+ "license": "MIT",
939
+ "engines": {
940
+ "node": ">=0.10.0"
941
+ }
942
+ },
943
+ "node_modules/object-inspect": {
944
+ "version": "1.13.4",
945
+ "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.4.tgz",
946
+ "integrity": "sha512-W67iLl4J2EXEGTbfeHCffrjDfitvLANg0UlX3wFUUSTx92KXRFegMHUVgSqE+wvhAbi4WqjGg9czysTV2Epbew==",
947
+ "license": "MIT",
948
+ "engines": {
949
+ "node": ">= 0.4"
950
+ },
951
+ "funding": {
952
+ "url": "https://github.com/sponsors/ljharb"
953
+ }
954
+ },
955
+ "node_modules/on-finished": {
956
+ "version": "2.4.1",
957
+ "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz",
958
+ "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==",
959
+ "license": "MIT",
960
+ "dependencies": {
961
+ "ee-first": "1.1.1"
962
+ },
963
+ "engines": {
964
+ "node": ">= 0.8"
965
+ }
966
+ },
967
+ "node_modules/parseurl": {
968
+ "version": "1.3.3",
969
+ "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
970
+ "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==",
971
+ "license": "MIT",
972
+ "engines": {
973
+ "node": ">= 0.8"
974
+ }
975
+ },
976
+ "node_modules/path-to-regexp": {
977
+ "version": "0.1.12",
978
+ "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.12.tgz",
979
+ "integrity": "sha512-RA1GjUVMnvYFxuqovrEqZoxxW5NUZqbwKtYz/Tt7nXerk0LbLblQmrsgdeOxV5SFHf0UDggjS/bSeOZwt1pmEQ==",
980
+ "license": "MIT"
981
+ },
982
+ "node_modules/picomatch": {
983
+ "version": "2.3.1",
984
+ "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
985
+ "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
986
+ "dev": true,
987
+ "license": "MIT",
988
+ "engines": {
989
+ "node": ">=8.6"
990
+ },
991
+ "funding": {
992
+ "url": "https://github.com/sponsors/jonschlinkert"
993
+ }
994
+ },
995
+ "node_modules/process-nextick-args": {
996
+ "version": "2.0.1",
997
+ "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz",
998
+ "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==",
999
+ "license": "MIT"
1000
+ },
1001
+ "node_modules/proxy-addr": {
1002
+ "version": "2.0.7",
1003
+ "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz",
1004
+ "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==",
1005
+ "license": "MIT",
1006
+ "dependencies": {
1007
+ "forwarded": "0.2.0",
1008
+ "ipaddr.js": "1.9.1"
1009
+ },
1010
+ "engines": {
1011
+ "node": ">= 0.10"
1012
+ }
1013
+ },
1014
+ "node_modules/pstree.remy": {
1015
+ "version": "1.1.8",
1016
+ "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz",
1017
+ "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==",
1018
+ "dev": true,
1019
+ "license": "MIT"
1020
+ },
1021
+ "node_modules/qs": {
1022
+ "version": "6.13.0",
1023
+ "resolved": "https://registry.npmjs.org/qs/-/qs-6.13.0.tgz",
1024
+ "integrity": "sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg==",
1025
+ "license": "BSD-3-Clause",
1026
+ "dependencies": {
1027
+ "side-channel": "^1.0.6"
1028
+ },
1029
+ "engines": {
1030
+ "node": ">=0.6"
1031
+ },
1032
+ "funding": {
1033
+ "url": "https://github.com/sponsors/ljharb"
1034
+ }
1035
+ },
1036
+ "node_modules/range-parser": {
1037
+ "version": "1.2.1",
1038
+ "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
1039
+ "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==",
1040
+ "license": "MIT",
1041
+ "engines": {
1042
+ "node": ">= 0.6"
1043
+ }
1044
+ },
1045
+ "node_modules/raw-body": {
1046
+ "version": "2.5.2",
1047
+ "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.2.tgz",
1048
+ "integrity": "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==",
1049
+ "license": "MIT",
1050
+ "dependencies": {
1051
+ "bytes": "3.1.2",
1052
+ "http-errors": "2.0.0",
1053
+ "iconv-lite": "0.4.24",
1054
+ "unpipe": "1.0.0"
1055
+ },
1056
+ "engines": {
1057
+ "node": ">= 0.8"
1058
+ }
1059
+ },
1060
+ "node_modules/readable-stream": {
1061
+ "version": "2.3.8",
1062
+ "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz",
1063
+ "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==",
1064
+ "license": "MIT",
1065
+ "dependencies": {
1066
+ "core-util-is": "~1.0.0",
1067
+ "inherits": "~2.0.3",
1068
+ "isarray": "~1.0.0",
1069
+ "process-nextick-args": "~2.0.0",
1070
+ "safe-buffer": "~5.1.1",
1071
+ "string_decoder": "~1.1.1",
1072
+ "util-deprecate": "~1.0.1"
1073
+ }
1074
+ },
1075
+ "node_modules/readable-stream/node_modules/safe-buffer": {
1076
+ "version": "5.1.2",
1077
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
1078
+ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==",
1079
+ "license": "MIT"
1080
+ },
1081
+ "node_modules/readdirp": {
1082
+ "version": "3.6.0",
1083
+ "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
1084
+ "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
1085
+ "dev": true,
1086
+ "license": "MIT",
1087
+ "dependencies": {
1088
+ "picomatch": "^2.2.1"
1089
+ },
1090
+ "engines": {
1091
+ "node": ">=8.10.0"
1092
+ }
1093
+ },
1094
+ "node_modules/safe-buffer": {
1095
+ "version": "5.2.1",
1096
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
1097
+ "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
1098
+ "funding": [
1099
+ {
1100
+ "type": "github",
1101
+ "url": "https://github.com/sponsors/feross"
1102
+ },
1103
+ {
1104
+ "type": "patreon",
1105
+ "url": "https://www.patreon.com/feross"
1106
+ },
1107
+ {
1108
+ "type": "consulting",
1109
+ "url": "https://feross.org/support"
1110
+ }
1111
+ ],
1112
+ "license": "MIT"
1113
+ },
1114
+ "node_modules/safer-buffer": {
1115
+ "version": "2.1.2",
1116
+ "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
1117
+ "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==",
1118
+ "license": "MIT"
1119
+ },
1120
+ "node_modules/semver": {
1121
+ "version": "7.7.2",
1122
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz",
1123
+ "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==",
1124
+ "dev": true,
1125
+ "license": "ISC",
1126
+ "bin": {
1127
+ "semver": "bin/semver.js"
1128
+ },
1129
+ "engines": {
1130
+ "node": ">=10"
1131
+ }
1132
+ },
1133
+ "node_modules/send": {
1134
+ "version": "0.19.0",
1135
+ "resolved": "https://registry.npmjs.org/send/-/send-0.19.0.tgz",
1136
+ "integrity": "sha512-dW41u5VfLXu8SJh5bwRmyYUbAoSB3c9uQh6L8h/KtsFREPWpbX1lrljJo186Jc4nmci/sGUZ9a0a0J2zgfq2hw==",
1137
+ "license": "MIT",
1138
+ "dependencies": {
1139
+ "debug": "2.6.9",
1140
+ "depd": "2.0.0",
1141
+ "destroy": "1.2.0",
1142
+ "encodeurl": "~1.0.2",
1143
+ "escape-html": "~1.0.3",
1144
+ "etag": "~1.8.1",
1145
+ "fresh": "0.5.2",
1146
+ "http-errors": "2.0.0",
1147
+ "mime": "1.6.0",
1148
+ "ms": "2.1.3",
1149
+ "on-finished": "2.4.1",
1150
+ "range-parser": "~1.2.1",
1151
+ "statuses": "2.0.1"
1152
+ },
1153
+ "engines": {
1154
+ "node": ">= 0.8.0"
1155
+ }
1156
+ },
1157
+ "node_modules/send/node_modules/encodeurl": {
1158
+ "version": "1.0.2",
1159
+ "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
1160
+ "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==",
1161
+ "license": "MIT",
1162
+ "engines": {
1163
+ "node": ">= 0.8"
1164
+ }
1165
+ },
1166
+ "node_modules/send/node_modules/ms": {
1167
+ "version": "2.1.3",
1168
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
1169
+ "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
1170
+ "license": "MIT"
1171
+ },
1172
+ "node_modules/serve-static": {
1173
+ "version": "1.16.2",
1174
+ "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.16.2.tgz",
1175
+ "integrity": "sha512-VqpjJZKadQB/PEbEwvFdO43Ax5dFBZ2UECszz8bQ7pi7wt//PWe1P6MN7eCnjsatYtBT6EuiClbjSWP2WrIoTw==",
1176
+ "license": "MIT",
1177
+ "dependencies": {
1178
+ "encodeurl": "~2.0.0",
1179
+ "escape-html": "~1.0.3",
1180
+ "parseurl": "~1.3.3",
1181
+ "send": "0.19.0"
1182
+ },
1183
+ "engines": {
1184
+ "node": ">= 0.8.0"
1185
+ }
1186
+ },
1187
+ "node_modules/setprototypeof": {
1188
+ "version": "1.2.0",
1189
+ "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz",
1190
+ "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==",
1191
+ "license": "ISC"
1192
+ },
1193
+ "node_modules/side-channel": {
1194
+ "version": "1.1.0",
1195
+ "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.1.0.tgz",
1196
+ "integrity": "sha512-ZX99e6tRweoUXqR+VBrslhda51Nh5MTQwou5tnUDgbtyM0dBgmhEDtWGP/xbKn6hqfPRHujUNwz5fy/wbbhnpw==",
1197
+ "license": "MIT",
1198
+ "dependencies": {
1199
+ "es-errors": "^1.3.0",
1200
+ "object-inspect": "^1.13.3",
1201
+ "side-channel-list": "^1.0.0",
1202
+ "side-channel-map": "^1.0.1",
1203
+ "side-channel-weakmap": "^1.0.2"
1204
+ },
1205
+ "engines": {
1206
+ "node": ">= 0.4"
1207
+ },
1208
+ "funding": {
1209
+ "url": "https://github.com/sponsors/ljharb"
1210
+ }
1211
+ },
1212
+ "node_modules/side-channel-list": {
1213
+ "version": "1.0.0",
1214
+ "resolved": "https://registry.npmjs.org/side-channel-list/-/side-channel-list-1.0.0.tgz",
1215
+ "integrity": "sha512-FCLHtRD/gnpCiCHEiJLOwdmFP+wzCmDEkc9y7NsYxeF4u7Btsn1ZuwgwJGxImImHicJArLP4R0yX4c2KCrMrTA==",
1216
+ "license": "MIT",
1217
+ "dependencies": {
1218
+ "es-errors": "^1.3.0",
1219
+ "object-inspect": "^1.13.3"
1220
+ },
1221
+ "engines": {
1222
+ "node": ">= 0.4"
1223
+ },
1224
+ "funding": {
1225
+ "url": "https://github.com/sponsors/ljharb"
1226
+ }
1227
+ },
1228
+ "node_modules/side-channel-map": {
1229
+ "version": "1.0.1",
1230
+ "resolved": "https://registry.npmjs.org/side-channel-map/-/side-channel-map-1.0.1.tgz",
1231
+ "integrity": "sha512-VCjCNfgMsby3tTdo02nbjtM/ewra6jPHmpThenkTYh8pG9ucZ/1P8So4u4FGBek/BjpOVsDCMoLA/iuBKIFXRA==",
1232
+ "license": "MIT",
1233
+ "dependencies": {
1234
+ "call-bound": "^1.0.2",
1235
+ "es-errors": "^1.3.0",
1236
+ "get-intrinsic": "^1.2.5",
1237
+ "object-inspect": "^1.13.3"
1238
+ },
1239
+ "engines": {
1240
+ "node": ">= 0.4"
1241
+ },
1242
+ "funding": {
1243
+ "url": "https://github.com/sponsors/ljharb"
1244
+ }
1245
+ },
1246
+ "node_modules/side-channel-weakmap": {
1247
+ "version": "1.0.2",
1248
+ "resolved": "https://registry.npmjs.org/side-channel-weakmap/-/side-channel-weakmap-1.0.2.tgz",
1249
+ "integrity": "sha512-WPS/HvHQTYnHisLo9McqBHOJk2FkHO/tlpvldyrnem4aeQp4hai3gythswg6p01oSoTl58rcpiFAjF2br2Ak2A==",
1250
+ "license": "MIT",
1251
+ "dependencies": {
1252
+ "call-bound": "^1.0.2",
1253
+ "es-errors": "^1.3.0",
1254
+ "get-intrinsic": "^1.2.5",
1255
+ "object-inspect": "^1.13.3",
1256
+ "side-channel-map": "^1.0.1"
1257
+ },
1258
+ "engines": {
1259
+ "node": ">= 0.4"
1260
+ },
1261
+ "funding": {
1262
+ "url": "https://github.com/sponsors/ljharb"
1263
+ }
1264
+ },
1265
+ "node_modules/simple-update-notifier": {
1266
+ "version": "2.0.0",
1267
+ "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-2.0.0.tgz",
1268
+ "integrity": "sha512-a2B9Y0KlNXl9u/vsW6sTIu9vGEpfKu2wRV6l1H3XEas/0gUIzGzBoP/IouTcUQbm9JWZLH3COxyn03TYlFax6w==",
1269
+ "dev": true,
1270
+ "license": "MIT",
1271
+ "dependencies": {
1272
+ "semver": "^7.5.3"
1273
+ },
1274
+ "engines": {
1275
+ "node": ">=10"
1276
+ }
1277
+ },
1278
+ "node_modules/statuses": {
1279
+ "version": "2.0.1",
1280
+ "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
1281
+ "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==",
1282
+ "license": "MIT",
1283
+ "engines": {
1284
+ "node": ">= 0.8"
1285
+ }
1286
+ },
1287
+ "node_modules/streamsearch": {
1288
+ "version": "1.1.0",
1289
+ "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz",
1290
+ "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==",
1291
+ "engines": {
1292
+ "node": ">=10.0.0"
1293
+ }
1294
+ },
1295
+ "node_modules/string_decoder": {
1296
+ "version": "1.1.1",
1297
+ "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
1298
+ "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
1299
+ "license": "MIT",
1300
+ "dependencies": {
1301
+ "safe-buffer": "~5.1.0"
1302
+ }
1303
+ },
1304
+ "node_modules/string_decoder/node_modules/safe-buffer": {
1305
+ "version": "5.1.2",
1306
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
1307
+ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==",
1308
+ "license": "MIT"
1309
+ },
1310
+ "node_modules/supports-color": {
1311
+ "version": "5.5.0",
1312
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
1313
+ "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
1314
+ "dev": true,
1315
+ "license": "MIT",
1316
+ "dependencies": {
1317
+ "has-flag": "^3.0.0"
1318
+ },
1319
+ "engines": {
1320
+ "node": ">=4"
1321
+ }
1322
+ },
1323
+ "node_modules/swagger-ui-dist": {
1324
+ "version": "5.25.2",
1325
+ "resolved": "https://registry.npmjs.org/swagger-ui-dist/-/swagger-ui-dist-5.25.2.tgz",
1326
+ "integrity": "sha512-V4JyoygUe5nCbn7bAD0fVKSC0yNcL3ROIQtGC7M0NATKuyosCSmMU6T0yDZIIuGpSxjsjZh/D2Ejb8lnF2jjxw==",
1327
+ "license": "Apache-2.0",
1328
+ "dependencies": {
1329
+ "@scarf/scarf": "=1.4.0"
1330
+ }
1331
+ },
1332
+ "node_modules/swagger-ui-express": {
1333
+ "version": "5.0.1",
1334
+ "resolved": "https://registry.npmjs.org/swagger-ui-express/-/swagger-ui-express-5.0.1.tgz",
1335
+ "integrity": "sha512-SrNU3RiBGTLLmFU8GIJdOdanJTl4TOmT27tt3bWWHppqYmAZ6IDuEuBvMU6nZq0zLEe6b/1rACXCgLZqO6ZfrA==",
1336
+ "license": "MIT",
1337
+ "dependencies": {
1338
+ "swagger-ui-dist": ">=5.0.0"
1339
+ },
1340
+ "engines": {
1341
+ "node": ">= v0.10.32"
1342
+ },
1343
+ "peerDependencies": {
1344
+ "express": ">=4.0.0 || >=5.0.0-beta"
1345
+ }
1346
+ },
1347
+ "node_modules/to-regex-range": {
1348
+ "version": "5.0.1",
1349
+ "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
1350
+ "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
1351
+ "dev": true,
1352
+ "license": "MIT",
1353
+ "dependencies": {
1354
+ "is-number": "^7.0.0"
1355
+ },
1356
+ "engines": {
1357
+ "node": ">=8.0"
1358
+ }
1359
+ },
1360
+ "node_modules/toidentifier": {
1361
+ "version": "1.0.1",
1362
+ "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz",
1363
+ "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==",
1364
+ "license": "MIT",
1365
+ "engines": {
1366
+ "node": ">=0.6"
1367
+ }
1368
+ },
1369
+ "node_modules/touch": {
1370
+ "version": "3.1.1",
1371
+ "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.1.tgz",
1372
+ "integrity": "sha512-r0eojU4bI8MnHr8c5bNo7lJDdI2qXlWWJk6a9EAFG7vbhTjElYhBVS3/miuE0uOuoLdb8Mc/rVfsmm6eo5o9GA==",
1373
+ "dev": true,
1374
+ "license": "ISC",
1375
+ "bin": {
1376
+ "nodetouch": "bin/nodetouch.js"
1377
+ }
1378
+ },
1379
+ "node_modules/type-is": {
1380
+ "version": "1.6.18",
1381
+ "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
1382
+ "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
1383
+ "license": "MIT",
1384
+ "dependencies": {
1385
+ "media-typer": "0.3.0",
1386
+ "mime-types": "~2.1.24"
1387
+ },
1388
+ "engines": {
1389
+ "node": ">= 0.6"
1390
+ }
1391
+ },
1392
+ "node_modules/typedarray": {
1393
+ "version": "0.0.6",
1394
+ "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz",
1395
+ "integrity": "sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA==",
1396
+ "license": "MIT"
1397
+ },
1398
+ "node_modules/undefsafe": {
1399
+ "version": "2.0.5",
1400
+ "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz",
1401
+ "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==",
1402
+ "dev": true,
1403
+ "license": "MIT"
1404
+ },
1405
+ "node_modules/unpipe": {
1406
+ "version": "1.0.0",
1407
+ "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
1408
+ "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==",
1409
+ "license": "MIT",
1410
+ "engines": {
1411
+ "node": ">= 0.8"
1412
+ }
1413
+ },
1414
+ "node_modules/util-deprecate": {
1415
+ "version": "1.0.2",
1416
+ "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
1417
+ "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==",
1418
+ "license": "MIT"
1419
+ },
1420
+ "node_modules/utils-merge": {
1421
+ "version": "1.0.1",
1422
+ "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
1423
+ "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==",
1424
+ "license": "MIT",
1425
+ "engines": {
1426
+ "node": ">= 0.4.0"
1427
+ }
1428
+ },
1429
+ "node_modules/vary": {
1430
+ "version": "1.1.2",
1431
+ "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
1432
+ "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==",
1433
+ "license": "MIT",
1434
+ "engines": {
1435
+ "node": ">= 0.8"
1436
+ }
1437
+ },
1438
+ "node_modules/xtend": {
1439
+ "version": "4.0.2",
1440
+ "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz",
1441
+ "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==",
1442
+ "license": "MIT",
1443
+ "engines": {
1444
+ "node": ">=0.4"
1445
+ }
1446
+ }
1447
+ }
1448
+ }
package.json ADDED
@@ -0,0 +1,21 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "name": "whatsapp-uploader",
3
+ "version": "1.0.0",
4
+ "description": "WhatsApp Bot File Uploader with Docker",
5
+ "main": "src/app.js",
6
+ "scripts": {
7
+ "start": "node src/app.js",
8
+ "dev": "nodemon src/app.js"
9
+ },
10
+ "dependencies": {
11
+ "cors": "^2.8.5",
12
+ "dotenv": "^16.5.0",
13
+ "express": "^4.18.2",
14
+ "helmet": "^8.1.0",
15
+ "multer": "^1.4.5-lts.1",
16
+ "swagger-ui-express": "^5.0.0"
17
+ },
18
+ "devDependencies": {
19
+ "nodemon": "^3.0.2"
20
+ }
21
+ }
src/app.js ADDED
@@ -0,0 +1,71 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ require('dotenv').config();
2
+ const express = require('express');
3
+ const cors = require('cors');
4
+ const helmet = require('helmet');
5
+ const path = require('path');
6
+ const mime = require('mime-types');
7
+ const apiRouter = require('./routes/api');
8
+ const uiRouter = require('./routes/ui');
9
+ const swaggerUi = require('swagger-ui-express');
10
+ const swaggerDocument = require('./swagger/swagger.json');
11
+
12
+ const app = express();
13
+ const PORT = process.env.PORT || 7860;
14
+ const DOMAIN = process.env.DOMAIN || 'localhost';
15
+
16
+ // Security middleware
17
+ app.use(helmet());
18
+ app.disable('x-powered-by');
19
+
20
+ // CORS configuration
21
+ const corsOptions = {
22
+ origin: [
23
+ `http://${DOMAIN}`,
24
+ `https://${DOMAIN}`,
25
+ `http://${DOMAIN}:${PORT}`,
26
+ `https://${DOMAIN}:${PORT}`,
27
+ 'http://localhost:7860',
28
+ 'http://127.0.0.1:7860'
29
+ ],
30
+ methods: ['GET', 'POST', 'OPTIONS'],
31
+ allowedHeaders: ['Content-Type', 'Authorization'],
32
+ optionsSuccessStatus: 200
33
+ };
34
+ app.use(cors(corsOptions));
35
+
36
+ // Other middleware
37
+ app.use(express.json());
38
+ app.use(express.urlencoded({ extended: true }));
39
+ app.use(express.static(path.join(__dirname, '../public')));
40
+
41
+ // File serving
42
+ app.use('/api/files', express.static(path.join(__dirname, '../uploads'), {
43
+ setHeaders: (res, filePath) => {
44
+ const contentType = mime.lookup(filePath) || 'application/octet-stream';
45
+ res.setHeader('Content-Type', contentType);
46
+ }
47
+ }));
48
+
49
+ // Routes
50
+ app.use('/api', apiRouter);
51
+ app.use('/', uiRouter);
52
+ app.use('/api-docs', swaggerUi.serve, swaggerUi.setup(swaggerDocument));
53
+
54
+ // Error handling middleware
55
+ app.use((err, req, res, next) => {
56
+ console.error(err.stack);
57
+ res.status(500).json({ error: 'Internal Server Error' });
58
+ });
59
+
60
+ // Start server
61
+ app.listen(PORT, () => {
62
+ if (DOMAIN === 'localhost') {
63
+ console.log(`Server running on http://localhost:${PORT}`);
64
+ console.log(`API Docs: http://localhost:${PORT}/api-docs`);
65
+ console.log(`Upload UI: http://localhost:${PORT}/upload`);
66
+ } else {
67
+ console.log(`Server running on https://${DOMAIN}`);
68
+ console.log(`API Docs: https://${DOMAIN}/api-docs`);
69
+ console.log(`Upload UI: https://${DOMAIN}/upload`);
70
+ }
71
+ });
src/routes/api.js ADDED
@@ -0,0 +1,92 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ const express = require('express');
2
+ const multer = require('multer');
3
+ const path = require('path');
4
+ const fs = require('fs');
5
+ const mime = require('mime-types');
6
+ const router = express.Router();
7
+
8
+ const uploadDir = path.join(__dirname, '../../uploads');
9
+ if (!fs.existsSync(uploadDir)) {
10
+ fs.mkdirSync(uploadDir, { recursive: true });
11
+ }
12
+
13
+ const supportedExtensions = [
14
+ '.jpg', '.jpeg', '.png', '.gif', '.webp',
15
+ '.mp4', '.mov', '.avi', '.mkv', '.webm',
16
+ '.mp3', '.wav', '.ogg', '.m4a'
17
+ ];
18
+
19
+ const storage = multer.diskStorage({
20
+ destination: (req, file, cb) => {
21
+ cb(null, uploadDir);
22
+ },
23
+ filename: (req, file, cb) => {
24
+ const ext = path.extname(file.originalname).toLowerCase();
25
+ const uniqueSuffix = Date.now() + '-' + Math.round(Math.random() * 1E9);
26
+ cb(null, 'file-' + uniqueSuffix + ext);
27
+ }
28
+ });
29
+
30
+ const fileFilter = (req, file, cb) => {
31
+ const ext = path.extname(file.originalname).toLowerCase();
32
+ if (supportedExtensions.includes(ext)) {
33
+ cb(null, true);
34
+ } else {
35
+ cb(new Error(`Unsupported file type: ${ext}`), false);
36
+ }
37
+ };
38
+
39
+ const upload = multer({
40
+ storage: storage,
41
+ fileFilter: fileFilter,
42
+ limits: {
43
+ fileSize: 100 * 1024 * 1024 // 100MB
44
+ }
45
+ });
46
+
47
+ router.post('/upload', upload.single('file'), (req, res) => {
48
+ if (!req.file) {
49
+ return res.status(400).json({ error: 'No file uploaded or invalid file type' });
50
+ }
51
+
52
+ const fileType = mime.lookup(req.file.originalname) || 'application/octet-stream';
53
+ const fileCategory = getFileCategory(fileType);
54
+ const protocol = req.secure || req.headers['x-forwarded-proto'] === 'https' ? 'https' : 'http';
55
+ const host = req.headers.host || `${DOMAIN}:${PORT}`;
56
+
57
+ res.json({
58
+ message: 'File uploaded successfully',
59
+ file: {
60
+ originalName: req.file.originalname,
61
+ fileName: req.file.filename,
62
+ size: req.file.size,
63
+ type: fileType,
64
+ category: fileCategory,
65
+ url: `${protocol}://${host}/api/files/${req.file.filename}`
66
+ }
67
+ });
68
+ });
69
+
70
+ router.get('/files/:filename', (req, res) => {
71
+ const filePath = path.join(uploadDir, req.params.filename);
72
+
73
+ if (!fs.existsSync(filePath)) {
74
+ return res.status(404).json({
75
+ error: 'File not found',
76
+ message: `The requested file does not exist on the server`
77
+ });
78
+ }
79
+
80
+ const contentType = mime.lookup(filePath) || 'application/octet-stream';
81
+ res.setHeader('Content-Type', contentType);
82
+ res.sendFile(filePath);
83
+ });
84
+
85
+ function getFileCategory(mimeType) {
86
+ if (mimeType.startsWith('image/')) return 'image';
87
+ if (mimeType.startsWith('video/')) return 'video';
88
+ if (mimeType.startsWith('audio/')) return 'audio';
89
+ return 'other';
90
+ }
91
+
92
+ module.exports = router;
src/routes/ui.js ADDED
@@ -0,0 +1,14 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ const express = require('express');
2
+ const path = require('path');
3
+ const router = express.Router();
4
+
5
+ // Serve HTML UI
6
+ router.get('/', (req, res) => {
7
+ res.sendFile(path.join(__dirname, '../views/index.html'));
8
+ });
9
+
10
+ router.get('/upload', (req, res) => {
11
+ res.sendFile(path.join(__dirname, '../views/upload.html'));
12
+ });
13
+
14
+ module.exports = router;
src/swagger/swagger.json ADDED
@@ -0,0 +1,115 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "openapi": "3.0.0",
3
+ "info": {
4
+ "title": "WhatsApp Bot Uploader API",
5
+ "description": "API for uploading files to be used with WhatsApp Bot",
6
+ "version": "1.0.0"
7
+ },
8
+ "servers": [
9
+ {
10
+ "url": "http://localhost:7860",
11
+ "description": "Local development server"
12
+ },
13
+ {
14
+ "url": "https://your-huggingface-space.herokuapp.com",
15
+ "description": "Production server"
16
+ }
17
+ ],
18
+ "paths": {
19
+ "/api/upload": {
20
+ "post": {
21
+ "summary": "Upload a file",
22
+ "description": "Upload a file that can be accessed by the WhatsApp bot",
23
+ "requestBody": {
24
+ "content": {
25
+ "multipart/form-data": {
26
+ "schema": {
27
+ "type": "object",
28
+ "properties": {
29
+ "file": {
30
+ "type": "string",
31
+ "format": "binary"
32
+ }
33
+ }
34
+ }
35
+ }
36
+ },
37
+ "required": true
38
+ },
39
+ "responses": {
40
+ "200": {
41
+ "description": "File uploaded successfully",
42
+ "content": {
43
+ "application/json": {
44
+ "schema": {
45
+ "type": "object",
46
+ "properties": {
47
+ "message": {
48
+ "type": "string"
49
+ },
50
+ "file": {
51
+ "type": "object",
52
+ "properties": {
53
+ "originalName": {
54
+ "type": "string"
55
+ },
56
+ "fileName": {
57
+ "type": "string"
58
+ },
59
+ "size": {
60
+ "type": "number"
61
+ },
62
+ "url": {
63
+ "type": "string"
64
+ }
65
+ }
66
+ }
67
+ }
68
+ }
69
+ }
70
+ }
71
+ },
72
+ "400": {
73
+ "description": "No file was uploaded"
74
+ },
75
+ "500": {
76
+ "description": "Internal server error"
77
+ }
78
+ }
79
+ }
80
+ },
81
+ "/api/files/{filename}": {
82
+ "get": {
83
+ "summary": "Get a file",
84
+ "description": "Retrieve an uploaded file by its filename",
85
+ "parameters": [
86
+ {
87
+ "name": "filename",
88
+ "in": "path",
89
+ "description": "Name of the file to retrieve",
90
+ "required": true,
91
+ "schema": {
92
+ "type": "string"
93
+ }
94
+ }
95
+ ],
96
+ "responses": {
97
+ "200": {
98
+ "description": "File content",
99
+ "content": {
100
+ "application/octet-stream": {
101
+ "schema": {
102
+ "type": "string",
103
+ "format": "binary"
104
+ }
105
+ }
106
+ }
107
+ },
108
+ "404": {
109
+ "description": "File not found"
110
+ }
111
+ }
112
+ }
113
+ }
114
+ }
115
+ }
src/views/index.html ADDED
@@ -0,0 +1,59 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8">
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
6
+ <title>WhatsApp Bot Uploader</title>
7
+ <style>
8
+ body {
9
+ font-family: Arial, sans-serif;
10
+ max-width: 800px;
11
+ margin: 0 auto;
12
+ padding: 20px;
13
+ background-color: #f5f5f5;
14
+ }
15
+ .container {
16
+ background-color: white;
17
+ padding: 30px;
18
+ border-radius: 8px;
19
+ box-shadow: 0 2px 10px rgba(0,0,0,0.1);
20
+ }
21
+ h1 {
22
+ color: #25D366;
23
+ text-align: center;
24
+ }
25
+ .btn {
26
+ display: inline-block;
27
+ padding: 10px 20px;
28
+ background-color: #25D366;
29
+ color: white;
30
+ text-decoration: none;
31
+ border-radius: 4px;
32
+ margin: 10px 0;
33
+ }
34
+ .btn:hover {
35
+ background-color: #128C7E;
36
+ }
37
+ .links {
38
+ margin-top: 30px;
39
+ }
40
+ </style>
41
+ </head>
42
+ <body>
43
+ <div class="container">
44
+ <h1>WhatsApp Bot File Uploader</h1>
45
+ <p>Welcome to the WhatsApp Bot file upload service. You can upload files that will be accessible to your WhatsApp bot.</p>
46
+
47
+ <a href="/upload" class="btn">Upload File</a>
48
+ <a href="/api-docs" class="btn">API Documentation</a>
49
+
50
+ <div class="links">
51
+ <h3>Useful Links:</h3>
52
+ <ul>
53
+ <li><a href="/api-docs">API Documentation (Swagger UI)</a></li>
54
+ <li><a href="/upload">File Upload Form</a></li>
55
+ </ul>
56
+ </div>
57
+ </div>
58
+ </body>
59
+ </html>
src/views/upload.html ADDED
@@ -0,0 +1,130 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8">
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
6
+ <title>Upload File</title>
7
+ <style>
8
+ body {
9
+ font-family: Arial, sans-serif;
10
+ max-width: 600px;
11
+ margin: 0 auto;
12
+ padding: 20px;
13
+ background-color: #f5f5f5;
14
+ }
15
+ .container {
16
+ background-color: white;
17
+ padding: 30px;
18
+ border-radius: 8px;
19
+ box-shadow: 0 2px 10px rgba(0,0,0,0.1);
20
+ }
21
+ h1 {
22
+ color: #25D366;
23
+ text-align: center;
24
+ }
25
+ .form-group {
26
+ margin-bottom: 20px;
27
+ }
28
+ label {
29
+ display: block;
30
+ margin-bottom: 5px;
31
+ font-weight: bold;
32
+ }
33
+ input[type="file"] {
34
+ width: 100%;
35
+ padding: 10px;
36
+ border: 1px solid #ddd;
37
+ border-radius: 4px;
38
+ }
39
+ button {
40
+ background-color: #25D366;
41
+ color: white;
42
+ border: none;
43
+ padding: 10px 20px;
44
+ border-radius: 4px;
45
+ cursor: pointer;
46
+ }
47
+ button:hover {
48
+ background-color: #128C7E;
49
+ }
50
+ #result {
51
+ margin-top: 20px;
52
+ padding: 10px;
53
+ border-radius: 4px;
54
+ }
55
+ .success {
56
+ background-color: #d4edda;
57
+ color: #155724;
58
+ }
59
+ .error {
60
+ background-color: #f8d7da;
61
+ color: #721c24;
62
+ }
63
+ .back-link {
64
+ display: block;
65
+ margin-top: 20px;
66
+ text-align: center;
67
+ }
68
+ </style>
69
+ </head>
70
+ <body>
71
+ <div class="container">
72
+ <h1>Upload File for WhatsApp Bot</h1>
73
+
74
+ <form id="uploadForm">
75
+ <div class="form-group">
76
+ <label for="file">Select file to upload:</label>
77
+ <input type="file" id="file" name="file" required>
78
+ </div>
79
+ <button type="submit">Upload</button>
80
+ </form>
81
+
82
+ <div id="result"></div>
83
+
84
+ <a href="/" class="back-link">← Back to Home</a>
85
+ </div>
86
+
87
+ <script>
88
+ document.getElementById('uploadForm').addEventListener('submit', async (e) => {
89
+ e.preventDefault();
90
+
91
+ const fileInput = document.getElementById('file');
92
+ const resultDiv = document.getElementById('result');
93
+
94
+ if (fileInput.files.length === 0) {
95
+ resultDiv.className = 'error';
96
+ resultDiv.textContent = 'Please select a file to upload';
97
+ return;
98
+ }
99
+
100
+ const formData = new FormData();
101
+ formData.append('file', fileInput.files[0]);
102
+
103
+ try {
104
+ const response = await fetch('/api/upload', {
105
+ method: 'POST',
106
+ body: formData
107
+ });
108
+
109
+ const data = await response.json();
110
+
111
+ if (response.ok) {
112
+ resultDiv.className = 'success';
113
+ resultDiv.innerHTML = `
114
+ <p>File uploaded successfully!</p>
115
+ <p><strong>Original Name:</strong> ${data.file.originalName}</p>
116
+ <p><strong>File Name:</strong> ${data.file.fileName}</p>
117
+ <p><strong>Size:</strong> ${(data.file.size / 1024).toFixed(2)} KB</p>
118
+ <p><strong>URL:</strong> <a href="${data.file.url}" target="_blank">${data.file.url}</a></p>
119
+ `;
120
+ } else {
121
+ throw new Error(data.error || 'Failed to upload file');
122
+ }
123
+ } catch (error) {
124
+ resultDiv.className = 'error';
125
+ resultDiv.textContent = `Error: ${error.message}`;
126
+ }
127
+ });
128
+ </script>
129
+ </body>
130
+ </html>