├── 1.JPG
├── 2.JPG
├── Capture.JPG
├── LICENSE
├── README.md
├── app.js
├── package-lock.json
├── package.json
└── public
├── CSS
└── style.css
├── HTML
└── index.html
└── JS
├── AJAX.js
├── AJAX2.js
├── API.js
├── API2.js
├── connection.js
└── validate.js
/1.JPG:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AsadiAhmad/Simple-Signup-Nodejs/01b5d7efb490d36ad7b5d9e75bdb2f70d939507d/1.JPG
--------------------------------------------------------------------------------
/2.JPG:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AsadiAhmad/Simple-Signup-Nodejs/01b5d7efb490d36ad7b5d9e75bdb2f70d939507d/2.JPG
--------------------------------------------------------------------------------
/Capture.JPG:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/AsadiAhmad/Simple-Signup-Nodejs/01b5d7efb490d36ad7b5d9e75bdb2f70d939507d/Capture.JPG
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2024 Ahmad Asadi
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | ### Simple-Signup-Nodejs
2 |
3 | ## install xampp and run Apache and MySQL
4 |
5 |
6 |
7 | ## Create table in data base
8 |
9 | ```
10 | CREATE TABLE `user` (
11 | `id` int(11) NOT NULL,
12 | `username` varchar(255) DEFAULT NULL,
13 | `lastname` varchar(255) DEFAULT NULL,
14 | `gender` varchar(255) DEFAULT NULL
15 | ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
16 | ```
17 |
18 | ## run this command:
19 |
20 | 1. for npm libraries
21 | - ```npm install body-parser```
22 | - ```npm install express```
23 | - ```npm install mysql```
24 | - ```npm install path```
25 | 2. for running server
26 | - ```node app.js```
27 |
28 |
29 |
30 |
31 | ## Webpage
32 |
33 |
34 |
35 |
36 |
--------------------------------------------------------------------------------
/app.js:
--------------------------------------------------------------------------------
1 | const express = require('express');
2 | const bodyParser = require('body-parser');
3 | const path = require('path');
4 | const app = express();
5 |
6 | const getForm = require(path.join(__dirname, 'public','JS', 'API.js'));
7 | const getInfo2 = require(path.join(__dirname, 'public','JS', 'API2.js'));
8 |
9 | const hostname = '127.0.0.1';
10 | const port = 5050;
11 |
12 | app.use(bodyParser.urlencoded({ extended: false }));
13 | app.use(bodyParser.json());
14 | app.use(express.static(path.join(__dirname, 'public')));
15 |
16 | app.get('/', (req, res) => {
17 | res.sendFile(path.join(__dirname, 'public', 'HTML', 'index.html'));
18 | });
19 |
20 | app.use('/save', getForm);
21 | app.use('/getUserInfo', getInfo2);
22 |
23 |
24 | app.listen(port, hostname, () => {
25 | console.log(`Server running at http://${hostname}:${port}/`);
26 | });
27 |
--------------------------------------------------------------------------------
/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "example1",
3 | "lockfileVersion": 3,
4 | "requires": true,
5 | "packages": {
6 | "": {
7 | "dependencies": {
8 | "body-parser": "^1.20.2",
9 | "express": "^4.18.2",
10 | "mysql": "^2.18.1",
11 | "path": "^0.12.7"
12 | }
13 | },
14 | "node_modules/accepts": {
15 | "version": "1.3.8",
16 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz",
17 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==",
18 | "dependencies": {
19 | "mime-types": "~2.1.34",
20 | "negotiator": "0.6.3"
21 | },
22 | "engines": {
23 | "node": ">= 0.6"
24 | }
25 | },
26 | "node_modules/array-flatten": {
27 | "version": "1.1.1",
28 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
29 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg=="
30 | },
31 | "node_modules/bignumber.js": {
32 | "version": "9.0.0",
33 | "resolved": "https://registry.npmjs.org/bignumber.js/-/bignumber.js-9.0.0.tgz",
34 | "integrity": "sha512-t/OYhhJ2SD+YGBQcjY8GzzDHEk9f3nerxjtfa6tlMXfe7frs/WozhvCNoGvpM0P3bNf3Gq5ZRMlGr5f3r4/N8A==",
35 | "engines": {
36 | "node": "*"
37 | }
38 | },
39 | "node_modules/body-parser": {
40 | "version": "1.20.2",
41 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.2.tgz",
42 | "integrity": "sha512-ml9pReCu3M61kGlqoTm2umSXTlRTuGTx0bfYj+uIUKKYycG5NtSbeetV3faSU6R7ajOPw0g/J1PvK4qNy7s5bA==",
43 | "dependencies": {
44 | "bytes": "3.1.2",
45 | "content-type": "~1.0.5",
46 | "debug": "2.6.9",
47 | "depd": "2.0.0",
48 | "destroy": "1.2.0",
49 | "http-errors": "2.0.0",
50 | "iconv-lite": "0.4.24",
51 | "on-finished": "2.4.1",
52 | "qs": "6.11.0",
53 | "raw-body": "2.5.2",
54 | "type-is": "~1.6.18",
55 | "unpipe": "1.0.0"
56 | },
57 | "engines": {
58 | "node": ">= 0.8",
59 | "npm": "1.2.8000 || >= 1.4.16"
60 | }
61 | },
62 | "node_modules/bytes": {
63 | "version": "3.1.2",
64 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz",
65 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==",
66 | "engines": {
67 | "node": ">= 0.8"
68 | }
69 | },
70 | "node_modules/call-bind": {
71 | "version": "1.0.5",
72 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.5.tgz",
73 | "integrity": "sha512-C3nQxfFZxFRVoJoGKKI8y3MOEo129NQ+FgQ08iye+Mk4zNZZGdjfs06bVTr+DBSlA66Q2VEcMki/cUCP4SercQ==",
74 | "dependencies": {
75 | "function-bind": "^1.1.2",
76 | "get-intrinsic": "^1.2.1",
77 | "set-function-length": "^1.1.1"
78 | },
79 | "funding": {
80 | "url": "https://github.com/sponsors/ljharb"
81 | }
82 | },
83 | "node_modules/content-disposition": {
84 | "version": "0.5.4",
85 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz",
86 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==",
87 | "dependencies": {
88 | "safe-buffer": "5.2.1"
89 | },
90 | "engines": {
91 | "node": ">= 0.6"
92 | }
93 | },
94 | "node_modules/content-type": {
95 | "version": "1.0.5",
96 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz",
97 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==",
98 | "engines": {
99 | "node": ">= 0.6"
100 | }
101 | },
102 | "node_modules/cookie": {
103 | "version": "0.5.0",
104 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz",
105 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==",
106 | "engines": {
107 | "node": ">= 0.6"
108 | }
109 | },
110 | "node_modules/cookie-signature": {
111 | "version": "1.0.6",
112 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
113 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ=="
114 | },
115 | "node_modules/core-util-is": {
116 | "version": "1.0.3",
117 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz",
118 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ=="
119 | },
120 | "node_modules/debug": {
121 | "version": "2.6.9",
122 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
123 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
124 | "dependencies": {
125 | "ms": "2.0.0"
126 | }
127 | },
128 | "node_modules/define-data-property": {
129 | "version": "1.1.1",
130 | "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.1.tgz",
131 | "integrity": "sha512-E7uGkTzkk1d0ByLeSc6ZsFS79Axg+m1P/VsgYsxHgiuc3tFSj+MjMIwe90FC4lOAZzNBdY7kkO2P2wKdsQ1vgQ==",
132 | "dependencies": {
133 | "get-intrinsic": "^1.2.1",
134 | "gopd": "^1.0.1",
135 | "has-property-descriptors": "^1.0.0"
136 | },
137 | "engines": {
138 | "node": ">= 0.4"
139 | }
140 | },
141 | "node_modules/depd": {
142 | "version": "2.0.0",
143 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz",
144 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==",
145 | "engines": {
146 | "node": ">= 0.8"
147 | }
148 | },
149 | "node_modules/destroy": {
150 | "version": "1.2.0",
151 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz",
152 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==",
153 | "engines": {
154 | "node": ">= 0.8",
155 | "npm": "1.2.8000 || >= 1.4.16"
156 | }
157 | },
158 | "node_modules/ee-first": {
159 | "version": "1.1.1",
160 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
161 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow=="
162 | },
163 | "node_modules/encodeurl": {
164 | "version": "1.0.2",
165 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
166 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==",
167 | "engines": {
168 | "node": ">= 0.8"
169 | }
170 | },
171 | "node_modules/escape-html": {
172 | "version": "1.0.3",
173 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
174 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow=="
175 | },
176 | "node_modules/etag": {
177 | "version": "1.8.1",
178 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
179 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==",
180 | "engines": {
181 | "node": ">= 0.6"
182 | }
183 | },
184 | "node_modules/express": {
185 | "version": "4.18.2",
186 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz",
187 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==",
188 | "dependencies": {
189 | "accepts": "~1.3.8",
190 | "array-flatten": "1.1.1",
191 | "body-parser": "1.20.1",
192 | "content-disposition": "0.5.4",
193 | "content-type": "~1.0.4",
194 | "cookie": "0.5.0",
195 | "cookie-signature": "1.0.6",
196 | "debug": "2.6.9",
197 | "depd": "2.0.0",
198 | "encodeurl": "~1.0.2",
199 | "escape-html": "~1.0.3",
200 | "etag": "~1.8.1",
201 | "finalhandler": "1.2.0",
202 | "fresh": "0.5.2",
203 | "http-errors": "2.0.0",
204 | "merge-descriptors": "1.0.1",
205 | "methods": "~1.1.2",
206 | "on-finished": "2.4.1",
207 | "parseurl": "~1.3.3",
208 | "path-to-regexp": "0.1.7",
209 | "proxy-addr": "~2.0.7",
210 | "qs": "6.11.0",
211 | "range-parser": "~1.2.1",
212 | "safe-buffer": "5.2.1",
213 | "send": "0.18.0",
214 | "serve-static": "1.15.0",
215 | "setprototypeof": "1.2.0",
216 | "statuses": "2.0.1",
217 | "type-is": "~1.6.18",
218 | "utils-merge": "1.0.1",
219 | "vary": "~1.1.2"
220 | },
221 | "engines": {
222 | "node": ">= 0.10.0"
223 | }
224 | },
225 | "node_modules/express/node_modules/body-parser": {
226 | "version": "1.20.1",
227 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz",
228 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==",
229 | "dependencies": {
230 | "bytes": "3.1.2",
231 | "content-type": "~1.0.4",
232 | "debug": "2.6.9",
233 | "depd": "2.0.0",
234 | "destroy": "1.2.0",
235 | "http-errors": "2.0.0",
236 | "iconv-lite": "0.4.24",
237 | "on-finished": "2.4.1",
238 | "qs": "6.11.0",
239 | "raw-body": "2.5.1",
240 | "type-is": "~1.6.18",
241 | "unpipe": "1.0.0"
242 | },
243 | "engines": {
244 | "node": ">= 0.8",
245 | "npm": "1.2.8000 || >= 1.4.16"
246 | }
247 | },
248 | "node_modules/express/node_modules/raw-body": {
249 | "version": "2.5.1",
250 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz",
251 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==",
252 | "dependencies": {
253 | "bytes": "3.1.2",
254 | "http-errors": "2.0.0",
255 | "iconv-lite": "0.4.24",
256 | "unpipe": "1.0.0"
257 | },
258 | "engines": {
259 | "node": ">= 0.8"
260 | }
261 | },
262 | "node_modules/finalhandler": {
263 | "version": "1.2.0",
264 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz",
265 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==",
266 | "dependencies": {
267 | "debug": "2.6.9",
268 | "encodeurl": "~1.0.2",
269 | "escape-html": "~1.0.3",
270 | "on-finished": "2.4.1",
271 | "parseurl": "~1.3.3",
272 | "statuses": "2.0.1",
273 | "unpipe": "~1.0.0"
274 | },
275 | "engines": {
276 | "node": ">= 0.8"
277 | }
278 | },
279 | "node_modules/forwarded": {
280 | "version": "0.2.0",
281 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz",
282 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==",
283 | "engines": {
284 | "node": ">= 0.6"
285 | }
286 | },
287 | "node_modules/fresh": {
288 | "version": "0.5.2",
289 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
290 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==",
291 | "engines": {
292 | "node": ">= 0.6"
293 | }
294 | },
295 | "node_modules/function-bind": {
296 | "version": "1.1.2",
297 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz",
298 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==",
299 | "funding": {
300 | "url": "https://github.com/sponsors/ljharb"
301 | }
302 | },
303 | "node_modules/get-intrinsic": {
304 | "version": "1.2.2",
305 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.2.tgz",
306 | "integrity": "sha512-0gSo4ml/0j98Y3lngkFEot/zhiCeWsbYIlZ+uZOVgzLyLaUw7wxUL+nCTP0XJvJg1AXulJRI3UJi8GsbDuxdGA==",
307 | "dependencies": {
308 | "function-bind": "^1.1.2",
309 | "has-proto": "^1.0.1",
310 | "has-symbols": "^1.0.3",
311 | "hasown": "^2.0.0"
312 | },
313 | "funding": {
314 | "url": "https://github.com/sponsors/ljharb"
315 | }
316 | },
317 | "node_modules/gopd": {
318 | "version": "1.0.1",
319 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz",
320 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==",
321 | "dependencies": {
322 | "get-intrinsic": "^1.1.3"
323 | },
324 | "funding": {
325 | "url": "https://github.com/sponsors/ljharb"
326 | }
327 | },
328 | "node_modules/has-property-descriptors": {
329 | "version": "1.0.1",
330 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.1.tgz",
331 | "integrity": "sha512-VsX8eaIewvas0xnvinAe9bw4WfIeODpGYikiWYLH+dma0Jw6KHYqWiWfhQlgOVK8D6PvjubK5Uc4P0iIhIcNVg==",
332 | "dependencies": {
333 | "get-intrinsic": "^1.2.2"
334 | },
335 | "funding": {
336 | "url": "https://github.com/sponsors/ljharb"
337 | }
338 | },
339 | "node_modules/has-proto": {
340 | "version": "1.0.1",
341 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz",
342 | "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==",
343 | "engines": {
344 | "node": ">= 0.4"
345 | },
346 | "funding": {
347 | "url": "https://github.com/sponsors/ljharb"
348 | }
349 | },
350 | "node_modules/has-symbols": {
351 | "version": "1.0.3",
352 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz",
353 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==",
354 | "engines": {
355 | "node": ">= 0.4"
356 | },
357 | "funding": {
358 | "url": "https://github.com/sponsors/ljharb"
359 | }
360 | },
361 | "node_modules/hasown": {
362 | "version": "2.0.0",
363 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.0.tgz",
364 | "integrity": "sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA==",
365 | "dependencies": {
366 | "function-bind": "^1.1.2"
367 | },
368 | "engines": {
369 | "node": ">= 0.4"
370 | }
371 | },
372 | "node_modules/http-errors": {
373 | "version": "2.0.0",
374 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz",
375 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==",
376 | "dependencies": {
377 | "depd": "2.0.0",
378 | "inherits": "2.0.4",
379 | "setprototypeof": "1.2.0",
380 | "statuses": "2.0.1",
381 | "toidentifier": "1.0.1"
382 | },
383 | "engines": {
384 | "node": ">= 0.8"
385 | }
386 | },
387 | "node_modules/iconv-lite": {
388 | "version": "0.4.24",
389 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
390 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
391 | "dependencies": {
392 | "safer-buffer": ">= 2.1.2 < 3"
393 | },
394 | "engines": {
395 | "node": ">=0.10.0"
396 | }
397 | },
398 | "node_modules/inherits": {
399 | "version": "2.0.4",
400 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
401 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
402 | },
403 | "node_modules/ipaddr.js": {
404 | "version": "1.9.1",
405 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz",
406 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==",
407 | "engines": {
408 | "node": ">= 0.10"
409 | }
410 | },
411 | "node_modules/isarray": {
412 | "version": "1.0.0",
413 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
414 | "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ=="
415 | },
416 | "node_modules/media-typer": {
417 | "version": "0.3.0",
418 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
419 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==",
420 | "engines": {
421 | "node": ">= 0.6"
422 | }
423 | },
424 | "node_modules/merge-descriptors": {
425 | "version": "1.0.1",
426 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
427 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w=="
428 | },
429 | "node_modules/methods": {
430 | "version": "1.1.2",
431 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
432 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==",
433 | "engines": {
434 | "node": ">= 0.6"
435 | }
436 | },
437 | "node_modules/mime": {
438 | "version": "1.6.0",
439 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
440 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
441 | "bin": {
442 | "mime": "cli.js"
443 | },
444 | "engines": {
445 | "node": ">=4"
446 | }
447 | },
448 | "node_modules/mime-db": {
449 | "version": "1.52.0",
450 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
451 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
452 | "engines": {
453 | "node": ">= 0.6"
454 | }
455 | },
456 | "node_modules/mime-types": {
457 | "version": "2.1.35",
458 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
459 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
460 | "dependencies": {
461 | "mime-db": "1.52.0"
462 | },
463 | "engines": {
464 | "node": ">= 0.6"
465 | }
466 | },
467 | "node_modules/ms": {
468 | "version": "2.0.0",
469 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
470 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
471 | },
472 | "node_modules/mysql": {
473 | "version": "2.18.1",
474 | "resolved": "https://registry.npmjs.org/mysql/-/mysql-2.18.1.tgz",
475 | "integrity": "sha512-Bca+gk2YWmqp2Uf6k5NFEurwY/0td0cpebAucFpY/3jhrwrVGuxU2uQFCHjU19SJfje0yQvi+rVWdq78hR5lig==",
476 | "dependencies": {
477 | "bignumber.js": "9.0.0",
478 | "readable-stream": "2.3.7",
479 | "safe-buffer": "5.1.2",
480 | "sqlstring": "2.3.1"
481 | },
482 | "engines": {
483 | "node": ">= 0.6"
484 | }
485 | },
486 | "node_modules/mysql/node_modules/safe-buffer": {
487 | "version": "5.1.2",
488 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
489 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
490 | },
491 | "node_modules/negotiator": {
492 | "version": "0.6.3",
493 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz",
494 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==",
495 | "engines": {
496 | "node": ">= 0.6"
497 | }
498 | },
499 | "node_modules/object-inspect": {
500 | "version": "1.13.1",
501 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz",
502 | "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==",
503 | "funding": {
504 | "url": "https://github.com/sponsors/ljharb"
505 | }
506 | },
507 | "node_modules/on-finished": {
508 | "version": "2.4.1",
509 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz",
510 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==",
511 | "dependencies": {
512 | "ee-first": "1.1.1"
513 | },
514 | "engines": {
515 | "node": ">= 0.8"
516 | }
517 | },
518 | "node_modules/parseurl": {
519 | "version": "1.3.3",
520 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
521 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==",
522 | "engines": {
523 | "node": ">= 0.8"
524 | }
525 | },
526 | "node_modules/path": {
527 | "version": "0.12.7",
528 | "resolved": "https://registry.npmjs.org/path/-/path-0.12.7.tgz",
529 | "integrity": "sha512-aXXC6s+1w7otVF9UletFkFcDsJeO7lSZBPUQhtb5O0xJe8LtYhj/GxldoL09bBj9+ZmE2hNoHqQSFMN5fikh4Q==",
530 | "dependencies": {
531 | "process": "^0.11.1",
532 | "util": "^0.10.3"
533 | }
534 | },
535 | "node_modules/path-to-regexp": {
536 | "version": "0.1.7",
537 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
538 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ=="
539 | },
540 | "node_modules/process": {
541 | "version": "0.11.10",
542 | "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz",
543 | "integrity": "sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A==",
544 | "engines": {
545 | "node": ">= 0.6.0"
546 | }
547 | },
548 | "node_modules/process-nextick-args": {
549 | "version": "2.0.1",
550 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz",
551 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag=="
552 | },
553 | "node_modules/proxy-addr": {
554 | "version": "2.0.7",
555 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz",
556 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==",
557 | "dependencies": {
558 | "forwarded": "0.2.0",
559 | "ipaddr.js": "1.9.1"
560 | },
561 | "engines": {
562 | "node": ">= 0.10"
563 | }
564 | },
565 | "node_modules/qs": {
566 | "version": "6.11.0",
567 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz",
568 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==",
569 | "dependencies": {
570 | "side-channel": "^1.0.4"
571 | },
572 | "engines": {
573 | "node": ">=0.6"
574 | },
575 | "funding": {
576 | "url": "https://github.com/sponsors/ljharb"
577 | }
578 | },
579 | "node_modules/range-parser": {
580 | "version": "1.2.1",
581 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
582 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==",
583 | "engines": {
584 | "node": ">= 0.6"
585 | }
586 | },
587 | "node_modules/raw-body": {
588 | "version": "2.5.2",
589 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.2.tgz",
590 | "integrity": "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==",
591 | "dependencies": {
592 | "bytes": "3.1.2",
593 | "http-errors": "2.0.0",
594 | "iconv-lite": "0.4.24",
595 | "unpipe": "1.0.0"
596 | },
597 | "engines": {
598 | "node": ">= 0.8"
599 | }
600 | },
601 | "node_modules/readable-stream": {
602 | "version": "2.3.7",
603 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz",
604 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==",
605 | "dependencies": {
606 | "core-util-is": "~1.0.0",
607 | "inherits": "~2.0.3",
608 | "isarray": "~1.0.0",
609 | "process-nextick-args": "~2.0.0",
610 | "safe-buffer": "~5.1.1",
611 | "string_decoder": "~1.1.1",
612 | "util-deprecate": "~1.0.1"
613 | }
614 | },
615 | "node_modules/readable-stream/node_modules/safe-buffer": {
616 | "version": "5.1.2",
617 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
618 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
619 | },
620 | "node_modules/safe-buffer": {
621 | "version": "5.2.1",
622 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
623 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
624 | "funding": [
625 | {
626 | "type": "github",
627 | "url": "https://github.com/sponsors/feross"
628 | },
629 | {
630 | "type": "patreon",
631 | "url": "https://www.patreon.com/feross"
632 | },
633 | {
634 | "type": "consulting",
635 | "url": "https://feross.org/support"
636 | }
637 | ]
638 | },
639 | "node_modules/safer-buffer": {
640 | "version": "2.1.2",
641 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
642 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
643 | },
644 | "node_modules/send": {
645 | "version": "0.18.0",
646 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz",
647 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==",
648 | "dependencies": {
649 | "debug": "2.6.9",
650 | "depd": "2.0.0",
651 | "destroy": "1.2.0",
652 | "encodeurl": "~1.0.2",
653 | "escape-html": "~1.0.3",
654 | "etag": "~1.8.1",
655 | "fresh": "0.5.2",
656 | "http-errors": "2.0.0",
657 | "mime": "1.6.0",
658 | "ms": "2.1.3",
659 | "on-finished": "2.4.1",
660 | "range-parser": "~1.2.1",
661 | "statuses": "2.0.1"
662 | },
663 | "engines": {
664 | "node": ">= 0.8.0"
665 | }
666 | },
667 | "node_modules/send/node_modules/ms": {
668 | "version": "2.1.3",
669 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
670 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
671 | },
672 | "node_modules/serve-static": {
673 | "version": "1.15.0",
674 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz",
675 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==",
676 | "dependencies": {
677 | "encodeurl": "~1.0.2",
678 | "escape-html": "~1.0.3",
679 | "parseurl": "~1.3.3",
680 | "send": "0.18.0"
681 | },
682 | "engines": {
683 | "node": ">= 0.8.0"
684 | }
685 | },
686 | "node_modules/set-function-length": {
687 | "version": "1.2.0",
688 | "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.0.tgz",
689 | "integrity": "sha512-4DBHDoyHlM1IRPGYcoxexgh67y4ueR53FKV1yyxwFMY7aCqcN/38M1+SwZ/qJQ8iLv7+ck385ot4CcisOAPT9w==",
690 | "dependencies": {
691 | "define-data-property": "^1.1.1",
692 | "function-bind": "^1.1.2",
693 | "get-intrinsic": "^1.2.2",
694 | "gopd": "^1.0.1",
695 | "has-property-descriptors": "^1.0.1"
696 | },
697 | "engines": {
698 | "node": ">= 0.4"
699 | }
700 | },
701 | "node_modules/setprototypeof": {
702 | "version": "1.2.0",
703 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz",
704 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw=="
705 | },
706 | "node_modules/side-channel": {
707 | "version": "1.0.4",
708 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz",
709 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==",
710 | "dependencies": {
711 | "call-bind": "^1.0.0",
712 | "get-intrinsic": "^1.0.2",
713 | "object-inspect": "^1.9.0"
714 | },
715 | "funding": {
716 | "url": "https://github.com/sponsors/ljharb"
717 | }
718 | },
719 | "node_modules/sqlstring": {
720 | "version": "2.3.1",
721 | "resolved": "https://registry.npmjs.org/sqlstring/-/sqlstring-2.3.1.tgz",
722 | "integrity": "sha512-ooAzh/7dxIG5+uDik1z/Rd1vli0+38izZhGzSa34FwR7IbelPWCCKSNIl8jlL/F7ERvy8CB2jNeM1E9i9mXMAQ==",
723 | "engines": {
724 | "node": ">= 0.6"
725 | }
726 | },
727 | "node_modules/statuses": {
728 | "version": "2.0.1",
729 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
730 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==",
731 | "engines": {
732 | "node": ">= 0.8"
733 | }
734 | },
735 | "node_modules/string_decoder": {
736 | "version": "1.1.1",
737 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
738 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
739 | "dependencies": {
740 | "safe-buffer": "~5.1.0"
741 | }
742 | },
743 | "node_modules/string_decoder/node_modules/safe-buffer": {
744 | "version": "5.1.2",
745 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
746 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
747 | },
748 | "node_modules/toidentifier": {
749 | "version": "1.0.1",
750 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz",
751 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==",
752 | "engines": {
753 | "node": ">=0.6"
754 | }
755 | },
756 | "node_modules/type-is": {
757 | "version": "1.6.18",
758 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
759 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
760 | "dependencies": {
761 | "media-typer": "0.3.0",
762 | "mime-types": "~2.1.24"
763 | },
764 | "engines": {
765 | "node": ">= 0.6"
766 | }
767 | },
768 | "node_modules/unpipe": {
769 | "version": "1.0.0",
770 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
771 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==",
772 | "engines": {
773 | "node": ">= 0.8"
774 | }
775 | },
776 | "node_modules/util": {
777 | "version": "0.10.4",
778 | "resolved": "https://registry.npmjs.org/util/-/util-0.10.4.tgz",
779 | "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==",
780 | "dependencies": {
781 | "inherits": "2.0.3"
782 | }
783 | },
784 | "node_modules/util-deprecate": {
785 | "version": "1.0.2",
786 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
787 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw=="
788 | },
789 | "node_modules/util/node_modules/inherits": {
790 | "version": "2.0.3",
791 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
792 | "integrity": "sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw=="
793 | },
794 | "node_modules/utils-merge": {
795 | "version": "1.0.1",
796 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
797 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==",
798 | "engines": {
799 | "node": ">= 0.4.0"
800 | }
801 | },
802 | "node_modules/vary": {
803 | "version": "1.1.2",
804 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
805 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==",
806 | "engines": {
807 | "node": ">= 0.8"
808 | }
809 | }
810 | }
811 | }
812 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "dependencies": {
3 | "body-parser": "^1.20.2",
4 | "express": "^4.18.2",
5 | "mysql": "^2.18.1",
6 | "path": "^0.12.7"
7 | }
8 | }
9 |
--------------------------------------------------------------------------------
/public/CSS/style.css:
--------------------------------------------------------------------------------
1 | .container {
2 | max-width: 500px;
3 | margin: 0 auto;
4 | padding: 20px;
5 | }
6 |
7 | h2 {
8 | text-align: center;
9 | }
10 |
11 | .form-group {
12 | margin-bottom: 15px;
13 | display: flex;
14 | flex-direction: row;
15 | }
16 |
17 | label {
18 | display: block;
19 | margin-bottom: 5px;
20 | }
21 |
22 | input[type="text"],
23 | select {
24 | width: 100%;
25 | padding: 10px;
26 | border: 1px solid #ccc;
27 | border-radius: 4px;
28 | }
29 |
30 | input[type="submit"] {
31 | width: auto;
32 | padding: 10px 20px;
33 | background-color: #4CAF50;
34 | color: #fff;
35 | border: none;
36 | border-radius: 4px;
37 | cursor: pointer;
38 | }
39 |
40 | input[type="submit"]:hover {
41 | background-color: #45a049;
42 | }
43 |
44 | button{
45 | width: auto;
46 | padding: 10px 20px;
47 | background-color: rgb(230, 164, 42);
48 | color: #fff;
49 | border: none;
50 | border-radius: 4px;
51 | cursor: pointer;
52 | }
53 |
54 | button:hover{
55 | background-color: orange;
56 | }
57 |
58 | input[type="text"] {
59 | padding: 10px;
60 | border: 1px solid #ccc;
61 | border-radius: 4px;
62 | width: 200px;
63 | }
64 |
65 | p {
66 | margin-top: 20px;
67 | font-size: 14px;
68 | }
69 |
--------------------------------------------------------------------------------
/public/HTML/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
tag 9 | }, 10 | error: function(xhr, status, error) { 11 | console.log('Error:', error); 12 | } 13 | }); 14 | } -------------------------------------------------------------------------------- /public/JS/API.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const path = require('path'); 3 | const router = express.Router(); 4 | const connection = require(path.join(__dirname, 'connection.js')); 5 | 6 | // const getForm = (req, res) => { 7 | // const { username, lastname, gender } = req.body; // Assuming the form fields have the names "username" and "gender" 8 | 9 | // // Insert the form data into the database 10 | // const sql = 'INSERT INTO user (username, lastname, gender) VALUES (?, ?, ?)'; // Replace "your_table_name" with your actual table name 11 | // const values = [username, lastname ,gender]; 12 | 13 | // connection.query(sql, values, (error, result) => { 14 | // if (error) { 15 | // console.error('Error saving data:', error); 16 | // res.send('Error saving data'); 17 | // } else { 18 | // const insertedId = result.insertId; // Access the auto-incremented ID value 19 | // console.log('Data saved successfully. Inserted ID:', insertedId); 20 | // res.send('Data saved successfully. Inserted ID: ' + insertedId); 21 | // } 22 | // }); 23 | // }; 24 | 25 | // const getForm = (req, res) => { 26 | // const { username, lastname, gender } = req.body; // Assuming the form fields have the names "username", "lastname", and "gender" 27 | 28 | // // Check if the username already exists in the database 29 | // const checkUsernameSql = 'SELECT * FROM user WHERE username = ?'; 30 | // connection.query(checkUsernameSql, [username], (error, results) => { 31 | // if (error) { 32 | // console.error('Error checking username:', error); 33 | // res.send('Error checking username'); 34 | // } else { 35 | // if (results.length > 0) { 36 | // // Username already exists 37 | // console.log('Username already exists:', username); 38 | // res.send('Username already exists'); 39 | // } else { 40 | // // Insert the form data into the database 41 | // const insertSql = 'INSERT INTO user (username, lastname, gender) VALUES (?, ?, ?)'; 42 | // const values = [username, lastname ,gender]; 43 | 44 | // connection.query(insertSql, values, (error, result) => { 45 | // if (error) { 46 | // console.error('Error saving data:', error); 47 | // res.send('Error saving data'); 48 | // } else { 49 | // const insertedId = result.insertId; // Access the auto-incremented ID value 50 | // console.log('Data saved successfully. Inserted ID:', insertedId); 51 | // res.send('Data saved successfully. Inserted ID: ' + insertedId); 52 | // } 53 | // }); 54 | // } 55 | // } 56 | // }); 57 | // }; 58 | 59 | const getForm = (req, res) => { 60 | const { username, gender } = req.body; // Assuming the form fields have the names "username" and "gender" 61 | 62 | // Check if the username already exists in the database 63 | const checkUsernameSql = 'SELECT * FROM user WHERE username = ?'; 64 | connection.query(checkUsernameSql, [username], (error, results) => { 65 | if (error) { 66 | console.error('Error checking username:', error); 67 | res.send('Error checking username'); 68 | } else { 69 | if (results.length > 0) { 70 | // Username already exists 71 | console.log('Username already exists:', username); 72 | res.send('Username already exists'); 73 | } else { 74 | // Insert the form data into the database 75 | let insertSql; 76 | let values; 77 | 78 | if (req.body.lastname) { 79 | // If lastname is provided in the form data 80 | insertSql = 'INSERT INTO user (username, lastname, gender) VALUES (?, ?, ?)'; 81 | values = [username, req.body.lastname, gender]; 82 | } else { 83 | // If lastname is not provided in the form data 84 | insertSql = 'INSERT INTO user (username, gender) VALUES (?, ?)'; 85 | values = [username, gender]; 86 | } 87 | 88 | connection.query(insertSql, values, (error, result) => { 89 | if (error) { 90 | console.error('Error saving data:', error); 91 | res.send('Error saving data'); 92 | } else { 93 | const insertedId = result.insertId; // Access the auto-incremented ID value 94 | console.log('Data saved successfully. Inserted ID:', insertedId); 95 | res.send('Data saved successfully. Inserted ID: ' + insertedId); 96 | } 97 | }); 98 | } 99 | } 100 | }); 101 | }; 102 | 103 | 104 | router.post('/', getForm); 105 | 106 | module.exports = router; -------------------------------------------------------------------------------- /public/JS/API2.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const path = require('path'); 3 | const router = express.Router(); 4 | const connection = require(path.join(__dirname, 'connection.js')); 5 | const getInformation = (req, res) => { 6 | var userId = req.params.userId; 7 | var query = 'SELECT * FROM user WHERE id = ?'; 8 | console.log(userId) 9 | connection.query(query, [userId], function(err, results) { 10 | if (err) { 11 | console.error('Error querying MySQL database: ' + err.stack); 12 | return res.status(500).send('Error querying database'); 13 | } 14 | 15 | if (results.length === 0) { 16 | return res.status(404).send('User not found'); 17 | } 18 | 19 | var userInfo = 'ID: ' + results[0].id + ', Username: ' + results[0].username + 20 | ', Lastname: ' + results[0].lastname + ', Gender: ' + results[0].gender; 21 | 22 | res.send(userInfo); 23 | }); 24 | }; 25 | 26 | router.get('/:userId', getInformation); 27 | 28 | module.exports = router; 29 | -------------------------------------------------------------------------------- /public/JS/connection.js: -------------------------------------------------------------------------------- 1 | const mysql = require('mysql'); 2 | 3 | const connectionMySQL = mysql.createConnection({ 4 | host: 'localhost', 5 | user: 'root', 6 | password : '', 7 | database: 'links' 8 | }); 9 | 10 | connectionMySQL.connect((error) => { 11 | if (error) { 12 | console.error('Could not connect to database:', error); 13 | } else { 14 | console.log('Connected to the database'); 15 | } 16 | }); 17 | 18 | module.exports = connectionMySQL; 19 | -------------------------------------------------------------------------------- /public/JS/validate.js: -------------------------------------------------------------------------------- 1 | function validateForm(isAJAX) { 2 | var username = document.getElementById("username").value; 3 | var gender = document.getElementById("gender").value; 4 | var newsletter = document.getElementById("newsletter").checked; 5 | 6 | var regex = /^[a-zA-Z]+$/; // Regular expression to match only text 7 | 8 | if (!username.match(regex)) { 9 | if (!isAJAX) { 10 | alert("Please enter a valid username with no numbers."); 11 | } 12 | return false; 13 | } 14 | 15 | if (username === "" || gender === "" || !newsletter) { 16 | if (!isAJAX) { 17 | alert("Please fill in all the required fields and check the checkbox."); 18 | } 19 | return false; 20 | } 21 | 22 | return true; // Return true if the form is valid 23 | } 24 | --------------------------------------------------------------------------------