├── 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 | 4 | User Registration Form 5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 |

User Registration Form

13 |
14 |
15 | 16 | 17 |
18 |
19 | 20 | 21 |
22 |
23 | 24 | 30 |
31 |
32 | 33 | 34 |
35 |
36 | 37 |
38 |
39 |

User Info

40 | 41 | 42 |

43 |
44 | 45 | 46 | 47 | -------------------------------------------------------------------------------- /public/JS/AJAX.js: -------------------------------------------------------------------------------- 1 | // $(document).ready(function() { 2 | // $('#myForm').submit(function(e) { 3 | // e.preventDefault(); // Prevent default form submission 4 | // if (!validateForm(true)) { 5 | // return; // Stop execution if form validation fails 6 | // } 7 | // var formData = $(this).serialize(); // Serialize form data into a query string or JSON object 8 | 9 | // // Send an Ajax POST request to the server-side script 10 | // $.ajax({ 11 | // url: '/save', // Replace with your server-side endpoint 12 | // type: 'POST', 13 | // data: formData, 14 | // success: function(response) { 15 | // // Handle the success response 16 | // console.log(response); 17 | // }, 18 | // error: function(error) { 19 | // // Handle the error response 20 | // console.log(error); 21 | // } 22 | // }); 23 | // }); 24 | // }); 25 | 26 | $(document).ready(function() { 27 | $('#myForm').submit(function(e) { 28 | e.preventDefault(); // Prevent default form submission 29 | if (!validateForm(true)) { 30 | return; // Stop execution if form validation fails 31 | } 32 | var formData = $(this).serialize(); // Serialize form data into a query string or JSON object 33 | 34 | // Send an Ajax POST request to the server-side script 35 | $.ajax({ 36 | url: '/save', // Replace with your server-side endpoint 37 | type: 'POST', 38 | data: formData, 39 | success: function(response) { 40 | // Handle the success response 41 | console.log(response); 42 | if (response === 'Username already exists') { 43 | // Display an alert if the username already exists 44 | alert('Username already exists. Please choose a different username.'); 45 | } else { 46 | // Display a success message if the data was saved successfully 47 | alert('Data saved successfully. Inserted ID: ' + response); 48 | } 49 | }, 50 | error: function(error) { 51 | // Handle the error response 52 | console.log(error); 53 | alert('Error saving data. Please try again later.'); 54 | } 55 | }); 56 | }); 57 | }); 58 | -------------------------------------------------------------------------------- /public/JS/AJAX2.js: -------------------------------------------------------------------------------- 1 | function getUserInfo() { 2 | var userId = $('#userIdInput').val(); 3 | 4 | $.ajax({ 5 | url: '/getUserInfo/' + userId, 6 | type: 'GET', 7 | success: function(response) { 8 | $('#userInfo').text(response); // Update the content of the

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 | --------------------------------------------------------------------------------