├── .dockerignore ├── .env_example ├── .gitignore ├── Dockerfile ├── LICENSE ├── README.md ├── package-lock.json ├── package.json ├── src ├── controllers │ ├── crypto.controller.ts │ └── keygen.controller.ts ├── index.ts ├── routes │ └── api.routes.ts ├── server.ts └── services │ ├── crypto.service.ts │ ├── hepler.service.ts │ └── keygen.service.ts ├── test ├── routes │ └── api-routes.spec.ts ├── server.spec.ts └── services │ ├── crypto-service.spec.ts │ ├── helper-service.spec.ts │ └── keygen-service.spec.ts └── tsconfig.json /.dockerignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | README.md -------------------------------------------------------------------------------- /.env_example: -------------------------------------------------------------------------------- 1 | SECRET_KEY=CreateReliableKeyUsingRandomGenerator 2 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | dist 3 | /public 4 | .env -------------------------------------------------------------------------------- /Dockerfile: -------------------------------------------------------------------------------- 1 | FROM node:18-alpine 2 | 3 | WORKDIR /app 4 | COPY package*.json ./ 5 | 6 | RUN npm install 7 | 8 | COPY . . 9 | RUN npm run build 10 | ENV PORT 5000 11 | ENV SECRET_KEY = CreateReliableKeyUsingRandomGenerator 12 | EXPOSE ${PORT} 13 | 14 | CMD ["npm", "start"] 15 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2021 cheatsnake 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 | # :key: Classify 2 | 3 | ![GitHub repo size](https://img.shields.io/github/repo-size/cheatsnake/classify?color=blue) 4 | ![GitHub](https://img.shields.io/github/license/cheatsnake/classify?color=%235DAF83) 5 | [![contributions welcome](https://img.shields.io/badge/contributions-welcome-brightgreen.svg?style=flat)](https://github.com/cheatsnake/classify/issues) 6 | 7 |

Telegram bot now available

8 | 9 |

10 | 11 | Classify is open source project for enrypting text messages. Encryption is based on a simple and clear "One-time pad" method. The essence of this method is to apply the "exclusive OR" operation for each ASCII code of the message symbol in binary form and the corresponding ASCII code of the secret key. 12 | 13 | ## :eyeglasses: API overview 14 | 15 | Classify API provides unlimited access to encoding and decoding text messages using a given key. You can freely use the endpoints of this API to create your own apps. 16 | 17 | ## :lock: Encrypting data 18 | 19 | This endpoint accepts text message data and a secret key as input. At the output, the user receives a JSON object with an encoded message. 20 | 21 | ```rs 22 | POST /api/encrypt 23 | ``` 24 | 25 | ```json 26 | { 27 | "data": "Your message", 28 | "key": "Your key" 29 | } 30 | ``` 31 | 32 | ## :unlock: Decrypting data 33 | 34 | This endpoint accepts an encrypted text message and a secret key as input. At the output, the user receives a JSON object with a decrypted message. 35 | 36 | ```rs 37 | POST /api/decrypt 38 | ``` 39 | 40 | ```json 41 | { 42 | "data": "Encrypted message", 43 | "key": "Secret key" 44 | } 45 | ``` 46 | 47 | ## :key: Keygen 48 | 49 | The reliability of the encrypted message depends on the specified key. Ideally, the key should be randomly generated and have a message length. To do this, you can use our built-in key generator. 50 | 51 | ```rs 52 | GET /api/keygen 53 | ``` 54 | 55 | Key length parameter: 56 | 57 | ```sh 58 | ?length=32 59 | ``` 60 | 61 | Presence of symbols (1 - true, 0 - false): 62 | 63 | ```sh 64 | ?symbols=1 65 | ``` 66 | 67 | ## :dart: Examples 68 | 69 | JavaScript: 70 | 71 | ```js 72 | const encryptData = async () => { 73 | try { 74 | const url = 'http://localhost:5000/api/encrypt'; 75 | const jsonData = JSON.stringify({ 76 | data: "Hello world!", key: "secret" 77 | }); 78 | let response = await fetch(url, { 79 | method: 'POST', 80 | headers: { 81 | 'Content-Type': 'application/json;charset=utf-8' 82 | }, 83 | body: jsonData 84 | }); 85 | const result = await response.json(); 86 | console.log(result); 87 | } catch (error) { 88 | console.error(error); 89 | } 90 | } 91 | ``` 92 | 93 | ## :zap: Launch local server 94 | 95 | 1. Install packages 96 | 97 | ```sh 98 | npm install 99 | ``` 100 | 101 | 2. Create `.env` file with secret key 102 | 103 | ```sh 104 | SECRET_KEY=CreateReliableKeyUsingRandomGenerator 105 | ``` 106 | 107 | > :warning: :warning: :warning: Classify uses double encryption. This means that after encrypting the message with your key, the received encrypted message is encrypted again with the key that is defined in the .env file. Therefore, each created copy of the application will have its own built-in key, and will not support decryption of encrypted messages from another copies of application. 108 | 109 | 3. Runs the server with Nodemon for development 110 | 111 | ```sh 112 | npm run dev 113 | ``` 114 | 115 | > The page will reload if you make edits.\ 116 | > You will also see any lint errors in the console.\ 117 | > Open [http://localhost:5000](http://localhost:5000) to view it in the browser. 118 | 119 | 4. Launch tests 120 | 121 | ```sh 122 | npm run test 123 | ``` 124 | 125 | 5. Create a production build 126 | 127 | ```sh 128 | npm run build 129 | ``` 130 | 131 | 6. Runs the server of production build 132 | 133 | ```sh 134 | npm start 135 | ``` 136 | 137 | > Open [http://localhost:5000](http://localhost:5000) to view it in the browser. 138 | 139 | ## :whale: Docker startup 140 | 141 | 1. Change `ENV SECRET_KEY` in Dockerfile. 142 | 143 | 2. Build docker image from Dockerfile: 144 | 145 | ``` 146 | docker build . -t classify 147 | ``` 148 | 149 | 3. Create docker container from new image: 150 | 151 | ``` 152 | docker run -p 5000:5000 -d --name classify-server classify 153 | ``` 154 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "app", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@cspotcode/source-map-consumer": { 8 | "version": "0.8.0", 9 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-consumer/-/source-map-consumer-0.8.0.tgz", 10 | "integrity": "sha512-41qniHzTU8yAGbCp04ohlmSrZf8bkf/iJsl3V0dRGsQN/5GFfx+LbCSsCpp2gqrqjTVg/K6O8ycoV35JIwAzAg==", 11 | "dev": true 12 | }, 13 | "@cspotcode/source-map-support": { 14 | "version": "0.7.0", 15 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.7.0.tgz", 16 | "integrity": "sha512-X4xqRHqN8ACt2aHVe51OxeA2HjbcL4MqFqXkrmQszJ1NOUuUu5u6Vqx/0lZSVNku7velL5FC/s5uEAj1lsBMhA==", 17 | "dev": true, 18 | "requires": { 19 | "@cspotcode/source-map-consumer": "0.8.0" 20 | } 21 | }, 22 | "@sindresorhus/is": { 23 | "version": "0.14.0", 24 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz", 25 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==", 26 | "dev": true 27 | }, 28 | "@szmarczak/http-timer": { 29 | "version": "1.1.2", 30 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz", 31 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==", 32 | "dev": true, 33 | "requires": { 34 | "defer-to-connect": "^1.0.1" 35 | } 36 | }, 37 | "@tsconfig/node10": { 38 | "version": "1.0.8", 39 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.8.tgz", 40 | "integrity": "sha512-6XFfSQmMgq0CFLY1MslA/CPUfhIL919M1rMsa5lP2P097N2Wd1sSX0tx1u4olM16fLNhtHZpRhedZJphNJqmZg==", 41 | "dev": true 42 | }, 43 | "@tsconfig/node12": { 44 | "version": "1.0.9", 45 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.9.tgz", 46 | "integrity": "sha512-/yBMcem+fbvhSREH+s14YJi18sp7J9jpuhYByADT2rypfajMZZN4WQ6zBGgBKp53NKmqI36wFYDb3yaMPurITw==", 47 | "dev": true 48 | }, 49 | "@tsconfig/node14": { 50 | "version": "1.0.1", 51 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.1.tgz", 52 | "integrity": "sha512-509r2+yARFfHHE7T6Puu2jjkoycftovhXRqW328PDXTVGKihlb1P8Z9mMZH04ebyajfRY7dedfGynlrFHJUQCg==", 53 | "dev": true 54 | }, 55 | "@tsconfig/node16": { 56 | "version": "1.0.2", 57 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.2.tgz", 58 | "integrity": "sha512-eZxlbI8GZscaGS7kkc/trHTT5xgrjH3/1n2JDwusC9iahPKWMRvRjJSAN5mCXviuTGQ/lHnhvv8Q1YTpnfz9gA==", 59 | "dev": true 60 | }, 61 | "@types/body-parser": { 62 | "version": "1.19.2", 63 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz", 64 | "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==", 65 | "dev": true, 66 | "requires": { 67 | "@types/connect": "*", 68 | "@types/node": "*" 69 | } 70 | }, 71 | "@types/chai": { 72 | "version": "4.2.22", 73 | "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.2.22.tgz", 74 | "integrity": "sha512-tFfcE+DSTzWAgifkjik9AySNqIyNoYwmR+uecPwwD/XRNfvOjmC/FjCxpiUGDkDVDphPfCUecSQVFw+lN3M3kQ==", 75 | "dev": true 76 | }, 77 | "@types/connect": { 78 | "version": "3.4.35", 79 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", 80 | "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", 81 | "dev": true, 82 | "requires": { 83 | "@types/node": "*" 84 | } 85 | }, 86 | "@types/cookiejar": { 87 | "version": "2.1.2", 88 | "resolved": "https://registry.npmjs.org/@types/cookiejar/-/cookiejar-2.1.2.tgz", 89 | "integrity": "sha512-t73xJJrvdTjXrn4jLS9VSGRbz0nUY3cl2DMGDU48lKl+HR9dbbjW2A9r3g40VA++mQpy6uuHg33gy7du2BKpog==", 90 | "dev": true 91 | }, 92 | "@types/cors": { 93 | "version": "2.8.12", 94 | "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.12.tgz", 95 | "integrity": "sha512-vt+kDhq/M2ayberEtJcIN/hxXy1Pk+59g2FV/ZQceeaTyCtCucjL2Q7FXlFjtWn4n15KCr1NE2lNNFhp0lEThw==", 96 | "dev": true 97 | }, 98 | "@types/express": { 99 | "version": "4.17.13", 100 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz", 101 | "integrity": "sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA==", 102 | "dev": true, 103 | "requires": { 104 | "@types/body-parser": "*", 105 | "@types/express-serve-static-core": "^4.17.18", 106 | "@types/qs": "*", 107 | "@types/serve-static": "*" 108 | } 109 | }, 110 | "@types/express-serve-static-core": { 111 | "version": "4.17.25", 112 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.25.tgz", 113 | "integrity": "sha512-OUJIVfRMFijZukGGwTpKNFprqCCXk5WjNGvUgB/CxxBR40QWSjsNK86+yvGKlCOGc7sbwfHLaXhkG+NsytwBaQ==", 114 | "dev": true, 115 | "requires": { 116 | "@types/node": "*", 117 | "@types/qs": "*", 118 | "@types/range-parser": "*" 119 | } 120 | }, 121 | "@types/json5": { 122 | "version": "0.0.29", 123 | "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", 124 | "integrity": "sha1-7ihweulOEdK4J7y+UnC86n8+ce4=", 125 | "dev": true 126 | }, 127 | "@types/mime": { 128 | "version": "1.3.2", 129 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", 130 | "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==", 131 | "dev": true 132 | }, 133 | "@types/mocha": { 134 | "version": "9.0.0", 135 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-9.0.0.tgz", 136 | "integrity": "sha512-scN0hAWyLVAvLR9AyW7HoFF5sJZglyBsbPuHO4fv7JRvfmPBMfp1ozWqOf/e4wwPNxezBZXRfWzMb6iFLgEVRA==", 137 | "dev": true 138 | }, 139 | "@types/node": { 140 | "version": "16.11.9", 141 | "resolved": "https://registry.npmjs.org/@types/node/-/node-16.11.9.tgz", 142 | "integrity": "sha512-MKmdASMf3LtPzwLyRrFjtFFZ48cMf8jmX5VRYrDQiJa8Ybu5VAmkqBWqKU8fdCwD8ysw4mQ9nrEHvzg6gunR7A==", 143 | "dev": true 144 | }, 145 | "@types/qs": { 146 | "version": "6.9.7", 147 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 148 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==", 149 | "dev": true 150 | }, 151 | "@types/range-parser": { 152 | "version": "1.2.4", 153 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", 154 | "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==", 155 | "dev": true 156 | }, 157 | "@types/serve-static": { 158 | "version": "1.13.10", 159 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz", 160 | "integrity": "sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ==", 161 | "dev": true, 162 | "requires": { 163 | "@types/mime": "^1", 164 | "@types/node": "*" 165 | } 166 | }, 167 | "@types/superagent": { 168 | "version": "4.1.13", 169 | "resolved": "https://registry.npmjs.org/@types/superagent/-/superagent-4.1.13.tgz", 170 | "integrity": "sha512-YIGelp3ZyMiH0/A09PMAORO0EBGlF5xIKfDpK74wdYvWUs2o96b5CItJcWPdH409b7SAXIIG6p8NdU/4U2Maww==", 171 | "dev": true, 172 | "requires": { 173 | "@types/cookiejar": "*", 174 | "@types/node": "*" 175 | } 176 | }, 177 | "@types/supertest": { 178 | "version": "2.0.11", 179 | "resolved": "https://registry.npmjs.org/@types/supertest/-/supertest-2.0.11.tgz", 180 | "integrity": "sha512-uci4Esokrw9qGb9bvhhSVEjd6rkny/dk5PK/Qz4yxKiyppEI+dOPlNrZBahE3i+PoKFYyDxChVXZ/ysS/nrm1Q==", 181 | "dev": true, 182 | "requires": { 183 | "@types/superagent": "*" 184 | } 185 | }, 186 | "@ungap/promise-all-settled": { 187 | "version": "1.1.2", 188 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 189 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 190 | "dev": true 191 | }, 192 | "abbrev": { 193 | "version": "1.1.1", 194 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 195 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 196 | "dev": true 197 | }, 198 | "accepts": { 199 | "version": "1.3.7", 200 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 201 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 202 | "requires": { 203 | "mime-types": "~2.1.24", 204 | "negotiator": "0.6.2" 205 | } 206 | }, 207 | "acorn": { 208 | "version": "8.6.0", 209 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.6.0.tgz", 210 | "integrity": "sha512-U1riIR+lBSNi3IbxtaHOIKdH8sLFv3NYfNv8sg7ZsNhcfl4HF2++BfqqrNAxoCLQW1iiylOj76ecnaUxz+z9yw==", 211 | "dev": true 212 | }, 213 | "acorn-walk": { 214 | "version": "8.2.0", 215 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 216 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 217 | "dev": true 218 | }, 219 | "ansi-align": { 220 | "version": "3.0.1", 221 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.1.tgz", 222 | "integrity": "sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w==", 223 | "dev": true, 224 | "requires": { 225 | "string-width": "^4.1.0" 226 | } 227 | }, 228 | "ansi-colors": { 229 | "version": "4.1.1", 230 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 231 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 232 | "dev": true 233 | }, 234 | "ansi-regex": { 235 | "version": "5.0.1", 236 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 237 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 238 | "dev": true 239 | }, 240 | "ansi-styles": { 241 | "version": "4.3.0", 242 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 243 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 244 | "dev": true, 245 | "requires": { 246 | "color-convert": "^2.0.1" 247 | } 248 | }, 249 | "anymatch": { 250 | "version": "3.1.2", 251 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 252 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 253 | "dev": true, 254 | "requires": { 255 | "normalize-path": "^3.0.0", 256 | "picomatch": "^2.0.4" 257 | } 258 | }, 259 | "arg": { 260 | "version": "4.1.3", 261 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 262 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 263 | "dev": true 264 | }, 265 | "argparse": { 266 | "version": "2.0.1", 267 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 268 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 269 | "dev": true 270 | }, 271 | "array-flatten": { 272 | "version": "1.1.1", 273 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 274 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 275 | }, 276 | "assertion-error": { 277 | "version": "1.1.0", 278 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 279 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 280 | "dev": true 281 | }, 282 | "asynckit": { 283 | "version": "0.4.0", 284 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 285 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 286 | "dev": true 287 | }, 288 | "balanced-match": { 289 | "version": "1.0.2", 290 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 291 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 292 | "dev": true 293 | }, 294 | "binary-extensions": { 295 | "version": "2.2.0", 296 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 297 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 298 | "dev": true 299 | }, 300 | "body-parser": { 301 | "version": "1.19.0", 302 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 303 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 304 | "requires": { 305 | "bytes": "3.1.0", 306 | "content-type": "~1.0.4", 307 | "debug": "2.6.9", 308 | "depd": "~1.1.2", 309 | "http-errors": "1.7.2", 310 | "iconv-lite": "0.4.24", 311 | "on-finished": "~2.3.0", 312 | "qs": "6.7.0", 313 | "raw-body": "2.4.0", 314 | "type-is": "~1.6.17" 315 | } 316 | }, 317 | "boxen": { 318 | "version": "5.1.2", 319 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-5.1.2.tgz", 320 | "integrity": "sha512-9gYgQKXx+1nP8mP7CzFyaUARhg7D3n1dF/FnErWmu9l6JvGpNUN278h0aSb+QjoiKSWG+iZ3uHrcqk0qrY9RQQ==", 321 | "dev": true, 322 | "requires": { 323 | "ansi-align": "^3.0.0", 324 | "camelcase": "^6.2.0", 325 | "chalk": "^4.1.0", 326 | "cli-boxes": "^2.2.1", 327 | "string-width": "^4.2.2", 328 | "type-fest": "^0.20.2", 329 | "widest-line": "^3.1.0", 330 | "wrap-ansi": "^7.0.0" 331 | } 332 | }, 333 | "brace-expansion": { 334 | "version": "1.1.11", 335 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 336 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 337 | "dev": true, 338 | "requires": { 339 | "balanced-match": "^1.0.0", 340 | "concat-map": "0.0.1" 341 | } 342 | }, 343 | "braces": { 344 | "version": "3.0.2", 345 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 346 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 347 | "dev": true, 348 | "requires": { 349 | "fill-range": "^7.0.1" 350 | } 351 | }, 352 | "browser-stdout": { 353 | "version": "1.3.1", 354 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 355 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 356 | "dev": true 357 | }, 358 | "bytes": { 359 | "version": "3.1.0", 360 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 361 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 362 | }, 363 | "cacheable-request": { 364 | "version": "6.1.0", 365 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz", 366 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==", 367 | "dev": true, 368 | "requires": { 369 | "clone-response": "^1.0.2", 370 | "get-stream": "^5.1.0", 371 | "http-cache-semantics": "^4.0.0", 372 | "keyv": "^3.0.0", 373 | "lowercase-keys": "^2.0.0", 374 | "normalize-url": "^4.1.0", 375 | "responselike": "^1.0.2" 376 | }, 377 | "dependencies": { 378 | "get-stream": { 379 | "version": "5.2.0", 380 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", 381 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", 382 | "dev": true, 383 | "requires": { 384 | "pump": "^3.0.0" 385 | } 386 | }, 387 | "lowercase-keys": { 388 | "version": "2.0.0", 389 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", 390 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==", 391 | "dev": true 392 | } 393 | } 394 | }, 395 | "call-bind": { 396 | "version": "1.0.2", 397 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 398 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 399 | "dev": true, 400 | "requires": { 401 | "function-bind": "^1.1.1", 402 | "get-intrinsic": "^1.0.2" 403 | } 404 | }, 405 | "camelcase": { 406 | "version": "6.2.1", 407 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.1.tgz", 408 | "integrity": "sha512-tVI4q5jjFV5CavAU8DXfza/TJcZutVKo/5Foskmsqcm0MsL91moHvwiGNnqaa2o6PF/7yT5ikDRcVcl8Rj6LCA==", 409 | "dev": true 410 | }, 411 | "chai": { 412 | "version": "4.3.4", 413 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.4.tgz", 414 | "integrity": "sha512-yS5H68VYOCtN1cjfwumDSuzn/9c+yza4f3reKXlE5rUg7SFcCEy90gJvydNgOYtblyf4Zi6jIWRnXOgErta0KA==", 415 | "dev": true, 416 | "requires": { 417 | "assertion-error": "^1.1.0", 418 | "check-error": "^1.0.2", 419 | "deep-eql": "^3.0.1", 420 | "get-func-name": "^2.0.0", 421 | "pathval": "^1.1.1", 422 | "type-detect": "^4.0.5" 423 | } 424 | }, 425 | "chalk": { 426 | "version": "4.1.2", 427 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 428 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 429 | "dev": true, 430 | "requires": { 431 | "ansi-styles": "^4.1.0", 432 | "supports-color": "^7.1.0" 433 | }, 434 | "dependencies": { 435 | "supports-color": { 436 | "version": "7.2.0", 437 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 438 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 439 | "dev": true, 440 | "requires": { 441 | "has-flag": "^4.0.0" 442 | } 443 | } 444 | } 445 | }, 446 | "check-error": { 447 | "version": "1.0.2", 448 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 449 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 450 | "dev": true 451 | }, 452 | "chokidar": { 453 | "version": "3.5.2", 454 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 455 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 456 | "dev": true, 457 | "requires": { 458 | "anymatch": "~3.1.2", 459 | "braces": "~3.0.2", 460 | "fsevents": "~2.3.2", 461 | "glob-parent": "~5.1.2", 462 | "is-binary-path": "~2.1.0", 463 | "is-glob": "~4.0.1", 464 | "normalize-path": "~3.0.0", 465 | "readdirp": "~3.6.0" 466 | } 467 | }, 468 | "ci-info": { 469 | "version": "2.0.0", 470 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 471 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", 472 | "dev": true 473 | }, 474 | "cli-boxes": { 475 | "version": "2.2.1", 476 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz", 477 | "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==", 478 | "dev": true 479 | }, 480 | "cliui": { 481 | "version": "7.0.4", 482 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 483 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 484 | "dev": true, 485 | "requires": { 486 | "string-width": "^4.2.0", 487 | "strip-ansi": "^6.0.0", 488 | "wrap-ansi": "^7.0.0" 489 | } 490 | }, 491 | "clone-response": { 492 | "version": "1.0.2", 493 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz", 494 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=", 495 | "dev": true, 496 | "requires": { 497 | "mimic-response": "^1.0.0" 498 | } 499 | }, 500 | "color-convert": { 501 | "version": "2.0.1", 502 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 503 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 504 | "dev": true, 505 | "requires": { 506 | "color-name": "~1.1.4" 507 | } 508 | }, 509 | "color-name": { 510 | "version": "1.1.4", 511 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 512 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 513 | "dev": true 514 | }, 515 | "combined-stream": { 516 | "version": "1.0.8", 517 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 518 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 519 | "dev": true, 520 | "requires": { 521 | "delayed-stream": "~1.0.0" 522 | } 523 | }, 524 | "component-emitter": { 525 | "version": "1.3.0", 526 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", 527 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==", 528 | "dev": true 529 | }, 530 | "concat-map": { 531 | "version": "0.0.1", 532 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 533 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 534 | "dev": true 535 | }, 536 | "configstore": { 537 | "version": "5.0.1", 538 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz", 539 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==", 540 | "dev": true, 541 | "requires": { 542 | "dot-prop": "^5.2.0", 543 | "graceful-fs": "^4.1.2", 544 | "make-dir": "^3.0.0", 545 | "unique-string": "^2.0.0", 546 | "write-file-atomic": "^3.0.0", 547 | "xdg-basedir": "^4.0.0" 548 | } 549 | }, 550 | "content-disposition": { 551 | "version": "0.5.3", 552 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 553 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 554 | "requires": { 555 | "safe-buffer": "5.1.2" 556 | } 557 | }, 558 | "content-type": { 559 | "version": "1.0.4", 560 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 561 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 562 | }, 563 | "cookie": { 564 | "version": "0.4.0", 565 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 566 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 567 | }, 568 | "cookie-signature": { 569 | "version": "1.0.6", 570 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 571 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 572 | }, 573 | "cookiejar": { 574 | "version": "2.1.3", 575 | "resolved": "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.3.tgz", 576 | "integrity": "sha512-JxbCBUdrfr6AQjOXrxoTvAMJO4HBTUIlBzslcJPAz+/KT8yk53fXun51u+RenNYvad/+Vc2DIz5o9UxlCDymFQ==", 577 | "dev": true 578 | }, 579 | "cors": { 580 | "version": "2.8.5", 581 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 582 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 583 | "requires": { 584 | "object-assign": "^4", 585 | "vary": "^1" 586 | } 587 | }, 588 | "create-require": { 589 | "version": "1.1.1", 590 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 591 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 592 | "dev": true 593 | }, 594 | "crypto-random-string": { 595 | "version": "2.0.0", 596 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", 597 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==", 598 | "dev": true 599 | }, 600 | "debug": { 601 | "version": "2.6.9", 602 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 603 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 604 | "requires": { 605 | "ms": "2.0.0" 606 | } 607 | }, 608 | "decamelize": { 609 | "version": "4.0.0", 610 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 611 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 612 | "dev": true 613 | }, 614 | "decompress-response": { 615 | "version": "3.3.0", 616 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz", 617 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=", 618 | "dev": true, 619 | "requires": { 620 | "mimic-response": "^1.0.0" 621 | } 622 | }, 623 | "deep-eql": { 624 | "version": "3.0.1", 625 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 626 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 627 | "dev": true, 628 | "requires": { 629 | "type-detect": "^4.0.0" 630 | } 631 | }, 632 | "deep-extend": { 633 | "version": "0.6.0", 634 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 635 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 636 | "dev": true 637 | }, 638 | "defer-to-connect": { 639 | "version": "1.1.3", 640 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz", 641 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==", 642 | "dev": true 643 | }, 644 | "delayed-stream": { 645 | "version": "1.0.0", 646 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 647 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 648 | "dev": true 649 | }, 650 | "depd": { 651 | "version": "1.1.2", 652 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 653 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 654 | }, 655 | "destroy": { 656 | "version": "1.0.4", 657 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 658 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 659 | }, 660 | "diff": { 661 | "version": "5.0.0", 662 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 663 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 664 | "dev": true 665 | }, 666 | "dot-prop": { 667 | "version": "5.3.0", 668 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz", 669 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==", 670 | "dev": true, 671 | "requires": { 672 | "is-obj": "^2.0.0" 673 | } 674 | }, 675 | "dotenv": { 676 | "version": "10.0.0", 677 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-10.0.0.tgz", 678 | "integrity": "sha512-rlBi9d8jpv9Sf1klPjNfFAuWDjKLwTIJJ/VxtoTwIR6hnZxcEOQCZg2oIL3MWBYw5GpUDKOEnND7LXTbIpQ03Q==" 679 | }, 680 | "duplexer3": { 681 | "version": "0.1.4", 682 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 683 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=", 684 | "dev": true 685 | }, 686 | "ee-first": { 687 | "version": "1.1.1", 688 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 689 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 690 | }, 691 | "emoji-regex": { 692 | "version": "8.0.0", 693 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 694 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 695 | "dev": true 696 | }, 697 | "encodeurl": { 698 | "version": "1.0.2", 699 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 700 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 701 | }, 702 | "end-of-stream": { 703 | "version": "1.4.4", 704 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 705 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 706 | "dev": true, 707 | "requires": { 708 | "once": "^1.4.0" 709 | } 710 | }, 711 | "escalade": { 712 | "version": "3.1.1", 713 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 714 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 715 | "dev": true 716 | }, 717 | "escape-goat": { 718 | "version": "2.1.1", 719 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz", 720 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==", 721 | "dev": true 722 | }, 723 | "escape-html": { 724 | "version": "1.0.3", 725 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 726 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 727 | }, 728 | "escape-string-regexp": { 729 | "version": "4.0.0", 730 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 731 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 732 | "dev": true 733 | }, 734 | "etag": { 735 | "version": "1.8.1", 736 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 737 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 738 | }, 739 | "express": { 740 | "version": "4.17.1", 741 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 742 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 743 | "requires": { 744 | "accepts": "~1.3.7", 745 | "array-flatten": "1.1.1", 746 | "body-parser": "1.19.0", 747 | "content-disposition": "0.5.3", 748 | "content-type": "~1.0.4", 749 | "cookie": "0.4.0", 750 | "cookie-signature": "1.0.6", 751 | "debug": "2.6.9", 752 | "depd": "~1.1.2", 753 | "encodeurl": "~1.0.2", 754 | "escape-html": "~1.0.3", 755 | "etag": "~1.8.1", 756 | "finalhandler": "~1.1.2", 757 | "fresh": "0.5.2", 758 | "merge-descriptors": "1.0.1", 759 | "methods": "~1.1.2", 760 | "on-finished": "~2.3.0", 761 | "parseurl": "~1.3.3", 762 | "path-to-regexp": "0.1.7", 763 | "proxy-addr": "~2.0.5", 764 | "qs": "6.7.0", 765 | "range-parser": "~1.2.1", 766 | "safe-buffer": "5.1.2", 767 | "send": "0.17.1", 768 | "serve-static": "1.14.1", 769 | "setprototypeof": "1.1.1", 770 | "statuses": "~1.5.0", 771 | "type-is": "~1.6.18", 772 | "utils-merge": "1.0.1", 773 | "vary": "~1.1.2" 774 | } 775 | }, 776 | "fast-safe-stringify": { 777 | "version": "2.1.1", 778 | "resolved": "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.1.1.tgz", 779 | "integrity": "sha512-W+KJc2dmILlPplD/H4K9l9LcAHAfPtP6BY84uVLXQ6Evcz9Lcg33Y2z1IVblT6xdY54PXYVHEv+0Wpq8Io6zkA==", 780 | "dev": true 781 | }, 782 | "fill-range": { 783 | "version": "7.0.1", 784 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 785 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 786 | "dev": true, 787 | "requires": { 788 | "to-regex-range": "^5.0.1" 789 | } 790 | }, 791 | "finalhandler": { 792 | "version": "1.1.2", 793 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 794 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 795 | "requires": { 796 | "debug": "2.6.9", 797 | "encodeurl": "~1.0.2", 798 | "escape-html": "~1.0.3", 799 | "on-finished": "~2.3.0", 800 | "parseurl": "~1.3.3", 801 | "statuses": "~1.5.0", 802 | "unpipe": "~1.0.0" 803 | } 804 | }, 805 | "find-up": { 806 | "version": "5.0.0", 807 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 808 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 809 | "dev": true, 810 | "requires": { 811 | "locate-path": "^6.0.0", 812 | "path-exists": "^4.0.0" 813 | } 814 | }, 815 | "flat": { 816 | "version": "5.0.2", 817 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 818 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 819 | "dev": true 820 | }, 821 | "form-data": { 822 | "version": "3.0.1", 823 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", 824 | "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", 825 | "dev": true, 826 | "requires": { 827 | "asynckit": "^0.4.0", 828 | "combined-stream": "^1.0.8", 829 | "mime-types": "^2.1.12" 830 | } 831 | }, 832 | "formidable": { 833 | "version": "1.2.6", 834 | "resolved": "https://registry.npmjs.org/formidable/-/formidable-1.2.6.tgz", 835 | "integrity": "sha512-KcpbcpuLNOwrEjnbpMC0gS+X8ciDoZE1kkqzat4a8vrprf+s9pKNQ/QIwWfbfs4ltgmFl3MD177SNTkve3BwGQ==", 836 | "dev": true 837 | }, 838 | "forwarded": { 839 | "version": "0.2.0", 840 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 841 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 842 | }, 843 | "fresh": { 844 | "version": "0.5.2", 845 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 846 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 847 | }, 848 | "fs.realpath": { 849 | "version": "1.0.0", 850 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 851 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 852 | "dev": true 853 | }, 854 | "fsevents": { 855 | "version": "2.3.2", 856 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 857 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 858 | "dev": true, 859 | "optional": true 860 | }, 861 | "function-bind": { 862 | "version": "1.1.1", 863 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 864 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 865 | "dev": true 866 | }, 867 | "get-caller-file": { 868 | "version": "2.0.5", 869 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 870 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 871 | "dev": true 872 | }, 873 | "get-func-name": { 874 | "version": "2.0.0", 875 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 876 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 877 | "dev": true 878 | }, 879 | "get-intrinsic": { 880 | "version": "1.1.1", 881 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 882 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 883 | "dev": true, 884 | "requires": { 885 | "function-bind": "^1.1.1", 886 | "has": "^1.0.3", 887 | "has-symbols": "^1.0.1" 888 | } 889 | }, 890 | "get-stream": { 891 | "version": "4.1.0", 892 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 893 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 894 | "dev": true, 895 | "requires": { 896 | "pump": "^3.0.0" 897 | } 898 | }, 899 | "glob": { 900 | "version": "7.1.7", 901 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 902 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 903 | "dev": true, 904 | "requires": { 905 | "fs.realpath": "^1.0.0", 906 | "inflight": "^1.0.4", 907 | "inherits": "2", 908 | "minimatch": "^3.0.4", 909 | "once": "^1.3.0", 910 | "path-is-absolute": "^1.0.0" 911 | } 912 | }, 913 | "glob-parent": { 914 | "version": "5.1.2", 915 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 916 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 917 | "dev": true, 918 | "requires": { 919 | "is-glob": "^4.0.1" 920 | } 921 | }, 922 | "global-dirs": { 923 | "version": "3.0.0", 924 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-3.0.0.tgz", 925 | "integrity": "sha512-v8ho2DS5RiCjftj1nD9NmnfaOzTdud7RRnVd9kFNOjqZbISlx5DQ+OrTkywgd0dIt7oFCvKetZSHoHcP3sDdiA==", 926 | "dev": true, 927 | "requires": { 928 | "ini": "2.0.0" 929 | } 930 | }, 931 | "got": { 932 | "version": "9.6.0", 933 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz", 934 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==", 935 | "dev": true, 936 | "requires": { 937 | "@sindresorhus/is": "^0.14.0", 938 | "@szmarczak/http-timer": "^1.1.2", 939 | "cacheable-request": "^6.0.0", 940 | "decompress-response": "^3.3.0", 941 | "duplexer3": "^0.1.4", 942 | "get-stream": "^4.1.0", 943 | "lowercase-keys": "^1.0.1", 944 | "mimic-response": "^1.0.1", 945 | "p-cancelable": "^1.0.0", 946 | "to-readable-stream": "^1.0.0", 947 | "url-parse-lax": "^3.0.0" 948 | } 949 | }, 950 | "graceful-fs": { 951 | "version": "4.2.8", 952 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.8.tgz", 953 | "integrity": "sha512-qkIilPUYcNhJpd33n0GBXTB1MMPp14TxEsEs0pTrsSVucApsYzW5V+Q8Qxhik6KU3evy+qkAAowTByymK0avdg==", 954 | "dev": true 955 | }, 956 | "growl": { 957 | "version": "1.10.5", 958 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 959 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 960 | "dev": true 961 | }, 962 | "has": { 963 | "version": "1.0.3", 964 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 965 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 966 | "dev": true, 967 | "requires": { 968 | "function-bind": "^1.1.1" 969 | } 970 | }, 971 | "has-flag": { 972 | "version": "4.0.0", 973 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 974 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 975 | "dev": true 976 | }, 977 | "has-symbols": { 978 | "version": "1.0.2", 979 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 980 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", 981 | "dev": true 982 | }, 983 | "has-yarn": { 984 | "version": "2.1.0", 985 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz", 986 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==", 987 | "dev": true 988 | }, 989 | "he": { 990 | "version": "1.2.0", 991 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 992 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 993 | "dev": true 994 | }, 995 | "http-cache-semantics": { 996 | "version": "4.1.0", 997 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 998 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==", 999 | "dev": true 1000 | }, 1001 | "http-errors": { 1002 | "version": "1.7.2", 1003 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 1004 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 1005 | "requires": { 1006 | "depd": "~1.1.2", 1007 | "inherits": "2.0.3", 1008 | "setprototypeof": "1.1.1", 1009 | "statuses": ">= 1.5.0 < 2", 1010 | "toidentifier": "1.0.0" 1011 | } 1012 | }, 1013 | "iconv-lite": { 1014 | "version": "0.4.24", 1015 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1016 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1017 | "requires": { 1018 | "safer-buffer": ">= 2.1.2 < 3" 1019 | } 1020 | }, 1021 | "ignore-by-default": { 1022 | "version": "1.0.1", 1023 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 1024 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 1025 | "dev": true 1026 | }, 1027 | "import-lazy": { 1028 | "version": "2.1.0", 1029 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 1030 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=", 1031 | "dev": true 1032 | }, 1033 | "imurmurhash": { 1034 | "version": "0.1.4", 1035 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1036 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1037 | "dev": true 1038 | }, 1039 | "inflight": { 1040 | "version": "1.0.6", 1041 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1042 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1043 | "dev": true, 1044 | "requires": { 1045 | "once": "^1.3.0", 1046 | "wrappy": "1" 1047 | } 1048 | }, 1049 | "inherits": { 1050 | "version": "2.0.3", 1051 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1052 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1053 | }, 1054 | "ini": { 1055 | "version": "2.0.0", 1056 | "resolved": "https://registry.npmjs.org/ini/-/ini-2.0.0.tgz", 1057 | "integrity": "sha512-7PnF4oN3CvZF23ADhA5wRaYEQpJ8qygSkbtTXWBeXWXmEVRXK+1ITciHWwHhsjv1TmW0MgacIv6hEi5pX5NQdA==", 1058 | "dev": true 1059 | }, 1060 | "ipaddr.js": { 1061 | "version": "1.9.1", 1062 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 1063 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 1064 | }, 1065 | "is-binary-path": { 1066 | "version": "2.1.0", 1067 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1068 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1069 | "dev": true, 1070 | "requires": { 1071 | "binary-extensions": "^2.0.0" 1072 | } 1073 | }, 1074 | "is-ci": { 1075 | "version": "2.0.0", 1076 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", 1077 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", 1078 | "dev": true, 1079 | "requires": { 1080 | "ci-info": "^2.0.0" 1081 | } 1082 | }, 1083 | "is-extglob": { 1084 | "version": "2.1.1", 1085 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1086 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1087 | "dev": true 1088 | }, 1089 | "is-fullwidth-code-point": { 1090 | "version": "3.0.0", 1091 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1092 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1093 | "dev": true 1094 | }, 1095 | "is-glob": { 1096 | "version": "4.0.3", 1097 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1098 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1099 | "dev": true, 1100 | "requires": { 1101 | "is-extglob": "^2.1.1" 1102 | } 1103 | }, 1104 | "is-installed-globally": { 1105 | "version": "0.4.0", 1106 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.4.0.tgz", 1107 | "integrity": "sha512-iwGqO3J21aaSkC7jWnHP/difazwS7SFeIqxv6wEtLU8Y5KlzFTjyqcSIT0d8s4+dDhKytsk9PJZ2BkS5eZwQRQ==", 1108 | "dev": true, 1109 | "requires": { 1110 | "global-dirs": "^3.0.0", 1111 | "is-path-inside": "^3.0.2" 1112 | } 1113 | }, 1114 | "is-npm": { 1115 | "version": "5.0.0", 1116 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-5.0.0.tgz", 1117 | "integrity": "sha512-WW/rQLOazUq+ST/bCAVBp/2oMERWLsR7OrKyt052dNDk4DHcDE0/7QSXITlmi+VBcV13DfIbysG3tZJm5RfdBA==", 1118 | "dev": true 1119 | }, 1120 | "is-number": { 1121 | "version": "7.0.0", 1122 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1123 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1124 | "dev": true 1125 | }, 1126 | "is-obj": { 1127 | "version": "2.0.0", 1128 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 1129 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==", 1130 | "dev": true 1131 | }, 1132 | "is-path-inside": { 1133 | "version": "3.0.3", 1134 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 1135 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 1136 | "dev": true 1137 | }, 1138 | "is-plain-obj": { 1139 | "version": "2.1.0", 1140 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 1141 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 1142 | "dev": true 1143 | }, 1144 | "is-typedarray": { 1145 | "version": "1.0.0", 1146 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1147 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1148 | "dev": true 1149 | }, 1150 | "is-unicode-supported": { 1151 | "version": "0.1.0", 1152 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 1153 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 1154 | "dev": true 1155 | }, 1156 | "is-yarn-global": { 1157 | "version": "0.3.0", 1158 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz", 1159 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==", 1160 | "dev": true 1161 | }, 1162 | "isexe": { 1163 | "version": "2.0.0", 1164 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1165 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1166 | "dev": true 1167 | }, 1168 | "js-yaml": { 1169 | "version": "4.1.0", 1170 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1171 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1172 | "dev": true, 1173 | "requires": { 1174 | "argparse": "^2.0.1" 1175 | } 1176 | }, 1177 | "json-buffer": { 1178 | "version": "3.0.0", 1179 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz", 1180 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=", 1181 | "dev": true 1182 | }, 1183 | "json5": { 1184 | "version": "1.0.1", 1185 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", 1186 | "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", 1187 | "dev": true, 1188 | "requires": { 1189 | "minimist": "^1.2.0" 1190 | } 1191 | }, 1192 | "keyv": { 1193 | "version": "3.1.0", 1194 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz", 1195 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==", 1196 | "dev": true, 1197 | "requires": { 1198 | "json-buffer": "3.0.0" 1199 | } 1200 | }, 1201 | "latest-version": { 1202 | "version": "5.1.0", 1203 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz", 1204 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==", 1205 | "dev": true, 1206 | "requires": { 1207 | "package-json": "^6.3.0" 1208 | } 1209 | }, 1210 | "locate-path": { 1211 | "version": "6.0.0", 1212 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1213 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1214 | "dev": true, 1215 | "requires": { 1216 | "p-locate": "^5.0.0" 1217 | } 1218 | }, 1219 | "log-symbols": { 1220 | "version": "4.1.0", 1221 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 1222 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 1223 | "dev": true, 1224 | "requires": { 1225 | "chalk": "^4.1.0", 1226 | "is-unicode-supported": "^0.1.0" 1227 | } 1228 | }, 1229 | "lowercase-keys": { 1230 | "version": "1.0.1", 1231 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 1232 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==", 1233 | "dev": true 1234 | }, 1235 | "lru-cache": { 1236 | "version": "6.0.0", 1237 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1238 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1239 | "dev": true, 1240 | "requires": { 1241 | "yallist": "^4.0.0" 1242 | } 1243 | }, 1244 | "make-dir": { 1245 | "version": "3.1.0", 1246 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 1247 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 1248 | "dev": true, 1249 | "requires": { 1250 | "semver": "^6.0.0" 1251 | }, 1252 | "dependencies": { 1253 | "semver": { 1254 | "version": "6.3.0", 1255 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1256 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1257 | "dev": true 1258 | } 1259 | } 1260 | }, 1261 | "make-error": { 1262 | "version": "1.3.6", 1263 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1264 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 1265 | "dev": true 1266 | }, 1267 | "media-typer": { 1268 | "version": "0.3.0", 1269 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1270 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1271 | }, 1272 | "merge-descriptors": { 1273 | "version": "1.0.1", 1274 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1275 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1276 | }, 1277 | "methods": { 1278 | "version": "1.1.2", 1279 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1280 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1281 | }, 1282 | "mime": { 1283 | "version": "1.6.0", 1284 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1285 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 1286 | }, 1287 | "mime-db": { 1288 | "version": "1.51.0", 1289 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.51.0.tgz", 1290 | "integrity": "sha512-5y8A56jg7XVQx2mbv1lu49NR4dokRnhZYTtL+KGfaa27uq4pSTXkwQkFJl4pkRMyNFz/EtYDSkiiEHx3F7UN6g==" 1291 | }, 1292 | "mime-types": { 1293 | "version": "2.1.34", 1294 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.34.tgz", 1295 | "integrity": "sha512-6cP692WwGIs9XXdOO4++N+7qjqv0rqxxVvJ3VHPh/Sc9mVZcQP+ZGhkKiTvWMQRr2tbHkJP/Yn7Y0npb3ZBs4A==", 1296 | "requires": { 1297 | "mime-db": "1.51.0" 1298 | } 1299 | }, 1300 | "mimic-response": { 1301 | "version": "1.0.1", 1302 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", 1303 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==", 1304 | "dev": true 1305 | }, 1306 | "minimatch": { 1307 | "version": "3.0.4", 1308 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1309 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1310 | "dev": true, 1311 | "requires": { 1312 | "brace-expansion": "^1.1.7" 1313 | } 1314 | }, 1315 | "minimist": { 1316 | "version": "1.2.6", 1317 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 1318 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 1319 | "dev": true 1320 | }, 1321 | "mocha": { 1322 | "version": "9.1.3", 1323 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.1.3.tgz", 1324 | "integrity": "sha512-Xcpl9FqXOAYqI3j79pEtHBBnQgVXIhpULjGQa7DVb0Po+VzmSIK9kanAiWLHoRR/dbZ2qpdPshuXr8l1VaHCzw==", 1325 | "dev": true, 1326 | "requires": { 1327 | "@ungap/promise-all-settled": "1.1.2", 1328 | "ansi-colors": "4.1.1", 1329 | "browser-stdout": "1.3.1", 1330 | "chokidar": "3.5.2", 1331 | "debug": "4.3.2", 1332 | "diff": "5.0.0", 1333 | "escape-string-regexp": "4.0.0", 1334 | "find-up": "5.0.0", 1335 | "glob": "7.1.7", 1336 | "growl": "1.10.5", 1337 | "he": "1.2.0", 1338 | "js-yaml": "4.1.0", 1339 | "log-symbols": "4.1.0", 1340 | "minimatch": "3.0.4", 1341 | "ms": "2.1.3", 1342 | "nanoid": "3.1.25", 1343 | "serialize-javascript": "6.0.0", 1344 | "strip-json-comments": "3.1.1", 1345 | "supports-color": "8.1.1", 1346 | "which": "2.0.2", 1347 | "workerpool": "6.1.5", 1348 | "yargs": "16.2.0", 1349 | "yargs-parser": "20.2.4", 1350 | "yargs-unparser": "2.0.0" 1351 | }, 1352 | "dependencies": { 1353 | "debug": { 1354 | "version": "4.3.2", 1355 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 1356 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 1357 | "dev": true, 1358 | "requires": { 1359 | "ms": "2.1.2" 1360 | }, 1361 | "dependencies": { 1362 | "ms": { 1363 | "version": "2.1.2", 1364 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1365 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1366 | "dev": true 1367 | } 1368 | } 1369 | }, 1370 | "ms": { 1371 | "version": "2.1.3", 1372 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1373 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1374 | "dev": true 1375 | } 1376 | } 1377 | }, 1378 | "ms": { 1379 | "version": "2.0.0", 1380 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1381 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1382 | }, 1383 | "nanoid": { 1384 | "version": "3.1.25", 1385 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.25.tgz", 1386 | "integrity": "sha512-rdwtIXaXCLFAQbnfqDRnI6jaRHp9fTcYBjtFKE8eezcZ7LuLjhUaQGNeMXf1HmRoCH32CLz6XwX0TtxEOS/A3Q==", 1387 | "dev": true 1388 | }, 1389 | "negotiator": { 1390 | "version": "0.6.2", 1391 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 1392 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 1393 | }, 1394 | "nodemon": { 1395 | "version": "2.0.15", 1396 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.15.tgz", 1397 | "integrity": "sha512-gdHMNx47Gw7b3kWxJV64NI+Q5nfl0y5DgDbiVtShiwa7Z0IZ07Ll4RLFo6AjrhzMtoEZn5PDE3/c2AbVsiCkpA==", 1398 | "dev": true, 1399 | "requires": { 1400 | "chokidar": "^3.5.2", 1401 | "debug": "^3.2.7", 1402 | "ignore-by-default": "^1.0.1", 1403 | "minimatch": "^3.0.4", 1404 | "pstree.remy": "^1.1.8", 1405 | "semver": "^5.7.1", 1406 | "supports-color": "^5.5.0", 1407 | "touch": "^3.1.0", 1408 | "undefsafe": "^2.0.5", 1409 | "update-notifier": "^5.1.0" 1410 | }, 1411 | "dependencies": { 1412 | "debug": { 1413 | "version": "3.2.7", 1414 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1415 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1416 | "dev": true, 1417 | "requires": { 1418 | "ms": "^2.1.1" 1419 | } 1420 | }, 1421 | "has-flag": { 1422 | "version": "3.0.0", 1423 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1424 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1425 | "dev": true 1426 | }, 1427 | "ms": { 1428 | "version": "2.1.3", 1429 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1430 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1431 | "dev": true 1432 | }, 1433 | "supports-color": { 1434 | "version": "5.5.0", 1435 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1436 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1437 | "dev": true, 1438 | "requires": { 1439 | "has-flag": "^3.0.0" 1440 | } 1441 | } 1442 | } 1443 | }, 1444 | "nopt": { 1445 | "version": "1.0.10", 1446 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1447 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 1448 | "dev": true, 1449 | "requires": { 1450 | "abbrev": "1" 1451 | } 1452 | }, 1453 | "normalize-path": { 1454 | "version": "3.0.0", 1455 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1456 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1457 | "dev": true 1458 | }, 1459 | "normalize-url": { 1460 | "version": "4.5.1", 1461 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.1.tgz", 1462 | "integrity": "sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA==", 1463 | "dev": true 1464 | }, 1465 | "object-assign": { 1466 | "version": "4.1.1", 1467 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1468 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1469 | }, 1470 | "object-inspect": { 1471 | "version": "1.11.0", 1472 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.11.0.tgz", 1473 | "integrity": "sha512-jp7ikS6Sd3GxQfZJPyH3cjcbJF6GZPClgdV+EFygjFLQ5FmW/dRUnTd9PQ9k0JhoNDabWFbpF1yCdSWCC6gexg==", 1474 | "dev": true 1475 | }, 1476 | "on-finished": { 1477 | "version": "2.3.0", 1478 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1479 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1480 | "requires": { 1481 | "ee-first": "1.1.1" 1482 | } 1483 | }, 1484 | "once": { 1485 | "version": "1.4.0", 1486 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1487 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1488 | "dev": true, 1489 | "requires": { 1490 | "wrappy": "1" 1491 | } 1492 | }, 1493 | "p-cancelable": { 1494 | "version": "1.1.0", 1495 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz", 1496 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==", 1497 | "dev": true 1498 | }, 1499 | "p-limit": { 1500 | "version": "3.1.0", 1501 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1502 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1503 | "dev": true, 1504 | "requires": { 1505 | "yocto-queue": "^0.1.0" 1506 | } 1507 | }, 1508 | "p-locate": { 1509 | "version": "5.0.0", 1510 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1511 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1512 | "dev": true, 1513 | "requires": { 1514 | "p-limit": "^3.0.2" 1515 | } 1516 | }, 1517 | "package-json": { 1518 | "version": "6.5.0", 1519 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz", 1520 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==", 1521 | "dev": true, 1522 | "requires": { 1523 | "got": "^9.6.0", 1524 | "registry-auth-token": "^4.0.0", 1525 | "registry-url": "^5.0.0", 1526 | "semver": "^6.2.0" 1527 | }, 1528 | "dependencies": { 1529 | "semver": { 1530 | "version": "6.3.0", 1531 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1532 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1533 | "dev": true 1534 | } 1535 | } 1536 | }, 1537 | "parseurl": { 1538 | "version": "1.3.3", 1539 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1540 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 1541 | }, 1542 | "path-exists": { 1543 | "version": "4.0.0", 1544 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1545 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1546 | "dev": true 1547 | }, 1548 | "path-is-absolute": { 1549 | "version": "1.0.1", 1550 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1551 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1552 | "dev": true 1553 | }, 1554 | "path-to-regexp": { 1555 | "version": "0.1.7", 1556 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1557 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1558 | }, 1559 | "pathval": { 1560 | "version": "1.1.1", 1561 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 1562 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 1563 | "dev": true 1564 | }, 1565 | "picomatch": { 1566 | "version": "2.3.0", 1567 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 1568 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 1569 | "dev": true 1570 | }, 1571 | "prepend-http": { 1572 | "version": "2.0.0", 1573 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz", 1574 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=", 1575 | "dev": true 1576 | }, 1577 | "proxy-addr": { 1578 | "version": "2.0.7", 1579 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1580 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1581 | "requires": { 1582 | "forwarded": "0.2.0", 1583 | "ipaddr.js": "1.9.1" 1584 | } 1585 | }, 1586 | "pstree.remy": { 1587 | "version": "1.1.8", 1588 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1589 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 1590 | "dev": true 1591 | }, 1592 | "pump": { 1593 | "version": "3.0.0", 1594 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1595 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1596 | "dev": true, 1597 | "requires": { 1598 | "end-of-stream": "^1.1.0", 1599 | "once": "^1.3.1" 1600 | } 1601 | }, 1602 | "pupa": { 1603 | "version": "2.1.1", 1604 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz", 1605 | "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==", 1606 | "dev": true, 1607 | "requires": { 1608 | "escape-goat": "^2.0.0" 1609 | } 1610 | }, 1611 | "qs": { 1612 | "version": "6.7.0", 1613 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 1614 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 1615 | }, 1616 | "randombytes": { 1617 | "version": "2.1.0", 1618 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1619 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1620 | "dev": true, 1621 | "requires": { 1622 | "safe-buffer": "^5.1.0" 1623 | } 1624 | }, 1625 | "range-parser": { 1626 | "version": "1.2.1", 1627 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1628 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 1629 | }, 1630 | "raw-body": { 1631 | "version": "2.4.0", 1632 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 1633 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 1634 | "requires": { 1635 | "bytes": "3.1.0", 1636 | "http-errors": "1.7.2", 1637 | "iconv-lite": "0.4.24", 1638 | "unpipe": "1.0.0" 1639 | } 1640 | }, 1641 | "rc": { 1642 | "version": "1.2.8", 1643 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1644 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1645 | "dev": true, 1646 | "requires": { 1647 | "deep-extend": "^0.6.0", 1648 | "ini": "~1.3.0", 1649 | "minimist": "^1.2.0", 1650 | "strip-json-comments": "~2.0.1" 1651 | }, 1652 | "dependencies": { 1653 | "ini": { 1654 | "version": "1.3.8", 1655 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 1656 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==", 1657 | "dev": true 1658 | }, 1659 | "strip-json-comments": { 1660 | "version": "2.0.1", 1661 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1662 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1663 | "dev": true 1664 | } 1665 | } 1666 | }, 1667 | "readable-stream": { 1668 | "version": "3.6.0", 1669 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 1670 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 1671 | "dev": true, 1672 | "requires": { 1673 | "inherits": "^2.0.3", 1674 | "string_decoder": "^1.1.1", 1675 | "util-deprecate": "^1.0.1" 1676 | } 1677 | }, 1678 | "readdirp": { 1679 | "version": "3.6.0", 1680 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1681 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1682 | "dev": true, 1683 | "requires": { 1684 | "picomatch": "^2.2.1" 1685 | } 1686 | }, 1687 | "registry-auth-token": { 1688 | "version": "4.2.1", 1689 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.1.tgz", 1690 | "integrity": "sha512-6gkSb4U6aWJB4SF2ZvLb76yCBjcvufXBqvvEx1HbmKPkutswjW1xNVRY0+daljIYRbogN7O0etYSlbiaEQyMyw==", 1691 | "dev": true, 1692 | "requires": { 1693 | "rc": "^1.2.8" 1694 | } 1695 | }, 1696 | "registry-url": { 1697 | "version": "5.1.0", 1698 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz", 1699 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==", 1700 | "dev": true, 1701 | "requires": { 1702 | "rc": "^1.2.8" 1703 | } 1704 | }, 1705 | "require-directory": { 1706 | "version": "2.1.1", 1707 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1708 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1709 | "dev": true 1710 | }, 1711 | "responselike": { 1712 | "version": "1.0.2", 1713 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz", 1714 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=", 1715 | "dev": true, 1716 | "requires": { 1717 | "lowercase-keys": "^1.0.0" 1718 | } 1719 | }, 1720 | "safe-buffer": { 1721 | "version": "5.1.2", 1722 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1723 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1724 | }, 1725 | "safer-buffer": { 1726 | "version": "2.1.2", 1727 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1728 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1729 | }, 1730 | "semver": { 1731 | "version": "5.7.1", 1732 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1733 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1734 | "dev": true 1735 | }, 1736 | "semver-diff": { 1737 | "version": "3.1.1", 1738 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz", 1739 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==", 1740 | "dev": true, 1741 | "requires": { 1742 | "semver": "^6.3.0" 1743 | }, 1744 | "dependencies": { 1745 | "semver": { 1746 | "version": "6.3.0", 1747 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1748 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1749 | "dev": true 1750 | } 1751 | } 1752 | }, 1753 | "send": { 1754 | "version": "0.17.1", 1755 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 1756 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 1757 | "requires": { 1758 | "debug": "2.6.9", 1759 | "depd": "~1.1.2", 1760 | "destroy": "~1.0.4", 1761 | "encodeurl": "~1.0.2", 1762 | "escape-html": "~1.0.3", 1763 | "etag": "~1.8.1", 1764 | "fresh": "0.5.2", 1765 | "http-errors": "~1.7.2", 1766 | "mime": "1.6.0", 1767 | "ms": "2.1.1", 1768 | "on-finished": "~2.3.0", 1769 | "range-parser": "~1.2.1", 1770 | "statuses": "~1.5.0" 1771 | }, 1772 | "dependencies": { 1773 | "ms": { 1774 | "version": "2.1.1", 1775 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1776 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1777 | } 1778 | } 1779 | }, 1780 | "serialize-javascript": { 1781 | "version": "6.0.0", 1782 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 1783 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 1784 | "dev": true, 1785 | "requires": { 1786 | "randombytes": "^2.1.0" 1787 | } 1788 | }, 1789 | "serve-static": { 1790 | "version": "1.14.1", 1791 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 1792 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 1793 | "requires": { 1794 | "encodeurl": "~1.0.2", 1795 | "escape-html": "~1.0.3", 1796 | "parseurl": "~1.3.3", 1797 | "send": "0.17.1" 1798 | } 1799 | }, 1800 | "setprototypeof": { 1801 | "version": "1.1.1", 1802 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 1803 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 1804 | }, 1805 | "side-channel": { 1806 | "version": "1.0.4", 1807 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1808 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1809 | "dev": true, 1810 | "requires": { 1811 | "call-bind": "^1.0.0", 1812 | "get-intrinsic": "^1.0.2", 1813 | "object-inspect": "^1.9.0" 1814 | } 1815 | }, 1816 | "signal-exit": { 1817 | "version": "3.0.6", 1818 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.6.tgz", 1819 | "integrity": "sha512-sDl4qMFpijcGw22U5w63KmD3cZJfBuFlVNbVMKje2keoKML7X2UzWbc4XrmEbDwg0NXJc3yv4/ox7b+JWb57kQ==", 1820 | "dev": true 1821 | }, 1822 | "statuses": { 1823 | "version": "1.5.0", 1824 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1825 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 1826 | }, 1827 | "string-width": { 1828 | "version": "4.2.3", 1829 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1830 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1831 | "dev": true, 1832 | "requires": { 1833 | "emoji-regex": "^8.0.0", 1834 | "is-fullwidth-code-point": "^3.0.0", 1835 | "strip-ansi": "^6.0.1" 1836 | } 1837 | }, 1838 | "string_decoder": { 1839 | "version": "1.3.0", 1840 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 1841 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 1842 | "dev": true, 1843 | "requires": { 1844 | "safe-buffer": "~5.2.0" 1845 | }, 1846 | "dependencies": { 1847 | "safe-buffer": { 1848 | "version": "5.2.1", 1849 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1850 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1851 | "dev": true 1852 | } 1853 | } 1854 | }, 1855 | "strip-ansi": { 1856 | "version": "6.0.1", 1857 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1858 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1859 | "dev": true, 1860 | "requires": { 1861 | "ansi-regex": "^5.0.1" 1862 | } 1863 | }, 1864 | "strip-bom": { 1865 | "version": "3.0.0", 1866 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1867 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1868 | "dev": true 1869 | }, 1870 | "strip-json-comments": { 1871 | "version": "3.1.1", 1872 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1873 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1874 | "dev": true 1875 | }, 1876 | "superagent": { 1877 | "version": "6.1.0", 1878 | "resolved": "https://registry.npmjs.org/superagent/-/superagent-6.1.0.tgz", 1879 | "integrity": "sha512-OUDHEssirmplo3F+1HWKUrUjvnQuA+nZI6i/JJBdXb5eq9IyEQwPyPpqND+SSsxf6TygpBEkUjISVRN4/VOpeg==", 1880 | "dev": true, 1881 | "requires": { 1882 | "component-emitter": "^1.3.0", 1883 | "cookiejar": "^2.1.2", 1884 | "debug": "^4.1.1", 1885 | "fast-safe-stringify": "^2.0.7", 1886 | "form-data": "^3.0.0", 1887 | "formidable": "^1.2.2", 1888 | "methods": "^1.1.2", 1889 | "mime": "^2.4.6", 1890 | "qs": "^6.9.4", 1891 | "readable-stream": "^3.6.0", 1892 | "semver": "^7.3.2" 1893 | }, 1894 | "dependencies": { 1895 | "debug": { 1896 | "version": "4.3.2", 1897 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 1898 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 1899 | "dev": true, 1900 | "requires": { 1901 | "ms": "2.1.2" 1902 | } 1903 | }, 1904 | "mime": { 1905 | "version": "2.6.0", 1906 | "resolved": "https://registry.npmjs.org/mime/-/mime-2.6.0.tgz", 1907 | "integrity": "sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg==", 1908 | "dev": true 1909 | }, 1910 | "ms": { 1911 | "version": "2.1.2", 1912 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1913 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1914 | "dev": true 1915 | }, 1916 | "qs": { 1917 | "version": "6.10.1", 1918 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.10.1.tgz", 1919 | "integrity": "sha512-M528Hph6wsSVOBiYUnGf+K/7w0hNshs/duGsNXPUCLH5XAqjEtiPGwNONLV0tBH8NoGb0mvD5JubnUTrujKDTg==", 1920 | "dev": true, 1921 | "requires": { 1922 | "side-channel": "^1.0.4" 1923 | } 1924 | }, 1925 | "semver": { 1926 | "version": "7.3.5", 1927 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 1928 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 1929 | "dev": true, 1930 | "requires": { 1931 | "lru-cache": "^6.0.0" 1932 | } 1933 | } 1934 | } 1935 | }, 1936 | "supertest": { 1937 | "version": "6.1.6", 1938 | "resolved": "https://registry.npmjs.org/supertest/-/supertest-6.1.6.tgz", 1939 | "integrity": "sha512-0hACYGNJ8OHRg8CRITeZOdbjur7NLuNs0mBjVhdpxi7hP6t3QIbOzLON5RTUmZcy2I9riuII3+Pr2C7yztrIIg==", 1940 | "dev": true, 1941 | "requires": { 1942 | "methods": "^1.1.2", 1943 | "superagent": "^6.1.0" 1944 | } 1945 | }, 1946 | "supports-color": { 1947 | "version": "8.1.1", 1948 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1949 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1950 | "dev": true, 1951 | "requires": { 1952 | "has-flag": "^4.0.0" 1953 | } 1954 | }, 1955 | "to-readable-stream": { 1956 | "version": "1.0.0", 1957 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz", 1958 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==", 1959 | "dev": true 1960 | }, 1961 | "to-regex-range": { 1962 | "version": "5.0.1", 1963 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1964 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1965 | "dev": true, 1966 | "requires": { 1967 | "is-number": "^7.0.0" 1968 | } 1969 | }, 1970 | "toidentifier": { 1971 | "version": "1.0.0", 1972 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 1973 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 1974 | }, 1975 | "touch": { 1976 | "version": "3.1.0", 1977 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1978 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1979 | "dev": true, 1980 | "requires": { 1981 | "nopt": "~1.0.10" 1982 | } 1983 | }, 1984 | "ts-node": { 1985 | "version": "10.4.0", 1986 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.4.0.tgz", 1987 | "integrity": "sha512-g0FlPvvCXSIO1JDF6S232P5jPYqBkRL9qly81ZgAOSU7rwI0stphCgd2kLiCrU9DjQCrJMWEqcNSjQL02s6d8A==", 1988 | "dev": true, 1989 | "requires": { 1990 | "@cspotcode/source-map-support": "0.7.0", 1991 | "@tsconfig/node10": "^1.0.7", 1992 | "@tsconfig/node12": "^1.0.7", 1993 | "@tsconfig/node14": "^1.0.0", 1994 | "@tsconfig/node16": "^1.0.2", 1995 | "acorn": "^8.4.1", 1996 | "acorn-walk": "^8.1.1", 1997 | "arg": "^4.1.0", 1998 | "create-require": "^1.1.0", 1999 | "diff": "^4.0.1", 2000 | "make-error": "^1.1.1", 2001 | "yn": "3.1.1" 2002 | }, 2003 | "dependencies": { 2004 | "diff": { 2005 | "version": "4.0.2", 2006 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 2007 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 2008 | "dev": true 2009 | } 2010 | } 2011 | }, 2012 | "tsconfig-paths": { 2013 | "version": "3.11.0", 2014 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.11.0.tgz", 2015 | "integrity": "sha512-7ecdYDnIdmv639mmDwslG6KQg1Z9STTz1j7Gcz0xa+nshh/gKDAHcPxRbWOsA3SPp0tXP2leTcY9Kw+NAkfZzA==", 2016 | "dev": true, 2017 | "requires": { 2018 | "@types/json5": "^0.0.29", 2019 | "json5": "^1.0.1", 2020 | "minimist": "^1.2.0", 2021 | "strip-bom": "^3.0.0" 2022 | } 2023 | }, 2024 | "type-detect": { 2025 | "version": "4.0.8", 2026 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 2027 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 2028 | "dev": true 2029 | }, 2030 | "type-fest": { 2031 | "version": "0.20.2", 2032 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 2033 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 2034 | "dev": true 2035 | }, 2036 | "type-is": { 2037 | "version": "1.6.18", 2038 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2039 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2040 | "requires": { 2041 | "media-typer": "0.3.0", 2042 | "mime-types": "~2.1.24" 2043 | } 2044 | }, 2045 | "typedarray-to-buffer": { 2046 | "version": "3.1.5", 2047 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 2048 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 2049 | "dev": true, 2050 | "requires": { 2051 | "is-typedarray": "^1.0.0" 2052 | } 2053 | }, 2054 | "typescript": { 2055 | "version": "4.5.2", 2056 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.5.2.tgz", 2057 | "integrity": "sha512-5BlMof9H1yGt0P8/WF+wPNw6GfctgGjXp5hkblpyT+8rkASSmkUKMXrxR0Xg8ThVCi/JnHQiKXeBaEwCeQwMFw==", 2058 | "dev": true 2059 | }, 2060 | "undefsafe": { 2061 | "version": "2.0.5", 2062 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 2063 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 2064 | "dev": true 2065 | }, 2066 | "unique-string": { 2067 | "version": "2.0.0", 2068 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", 2069 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", 2070 | "dev": true, 2071 | "requires": { 2072 | "crypto-random-string": "^2.0.0" 2073 | } 2074 | }, 2075 | "unpipe": { 2076 | "version": "1.0.0", 2077 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2078 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 2079 | }, 2080 | "update-notifier": { 2081 | "version": "5.1.0", 2082 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-5.1.0.tgz", 2083 | "integrity": "sha512-ItnICHbeMh9GqUy31hFPrD1kcuZ3rpxDZbf4KUDavXwS0bW5m7SLbDQpGX3UYr072cbrF5hFUs3r5tUsPwjfHw==", 2084 | "dev": true, 2085 | "requires": { 2086 | "boxen": "^5.0.0", 2087 | "chalk": "^4.1.0", 2088 | "configstore": "^5.0.1", 2089 | "has-yarn": "^2.1.0", 2090 | "import-lazy": "^2.1.0", 2091 | "is-ci": "^2.0.0", 2092 | "is-installed-globally": "^0.4.0", 2093 | "is-npm": "^5.0.0", 2094 | "is-yarn-global": "^0.3.0", 2095 | "latest-version": "^5.1.0", 2096 | "pupa": "^2.1.1", 2097 | "semver": "^7.3.4", 2098 | "semver-diff": "^3.1.1", 2099 | "xdg-basedir": "^4.0.0" 2100 | }, 2101 | "dependencies": { 2102 | "semver": { 2103 | "version": "7.3.5", 2104 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 2105 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 2106 | "dev": true, 2107 | "requires": { 2108 | "lru-cache": "^6.0.0" 2109 | } 2110 | } 2111 | } 2112 | }, 2113 | "url-parse-lax": { 2114 | "version": "3.0.0", 2115 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz", 2116 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=", 2117 | "dev": true, 2118 | "requires": { 2119 | "prepend-http": "^2.0.0" 2120 | } 2121 | }, 2122 | "util-deprecate": { 2123 | "version": "1.0.2", 2124 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2125 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2126 | "dev": true 2127 | }, 2128 | "utils-merge": { 2129 | "version": "1.0.1", 2130 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2131 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 2132 | }, 2133 | "vary": { 2134 | "version": "1.1.2", 2135 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2136 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 2137 | }, 2138 | "which": { 2139 | "version": "2.0.2", 2140 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2141 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2142 | "dev": true, 2143 | "requires": { 2144 | "isexe": "^2.0.0" 2145 | } 2146 | }, 2147 | "widest-line": { 2148 | "version": "3.1.0", 2149 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz", 2150 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==", 2151 | "dev": true, 2152 | "requires": { 2153 | "string-width": "^4.0.0" 2154 | } 2155 | }, 2156 | "workerpool": { 2157 | "version": "6.1.5", 2158 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.1.5.tgz", 2159 | "integrity": "sha512-XdKkCK0Zqc6w3iTxLckiuJ81tiD/o5rBE/m+nXpRCB+/Sq4DqkfXZ/x0jW02DG1tGsfUGXbTJyZDP+eu67haSw==", 2160 | "dev": true 2161 | }, 2162 | "wrap-ansi": { 2163 | "version": "7.0.0", 2164 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2165 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2166 | "dev": true, 2167 | "requires": { 2168 | "ansi-styles": "^4.0.0", 2169 | "string-width": "^4.1.0", 2170 | "strip-ansi": "^6.0.0" 2171 | } 2172 | }, 2173 | "wrappy": { 2174 | "version": "1.0.2", 2175 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2176 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2177 | "dev": true 2178 | }, 2179 | "write-file-atomic": { 2180 | "version": "3.0.3", 2181 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 2182 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 2183 | "dev": true, 2184 | "requires": { 2185 | "imurmurhash": "^0.1.4", 2186 | "is-typedarray": "^1.0.0", 2187 | "signal-exit": "^3.0.2", 2188 | "typedarray-to-buffer": "^3.1.5" 2189 | } 2190 | }, 2191 | "xdg-basedir": { 2192 | "version": "4.0.0", 2193 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", 2194 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==", 2195 | "dev": true 2196 | }, 2197 | "y18n": { 2198 | "version": "5.0.8", 2199 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 2200 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 2201 | "dev": true 2202 | }, 2203 | "yallist": { 2204 | "version": "4.0.0", 2205 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2206 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2207 | "dev": true 2208 | }, 2209 | "yargs": { 2210 | "version": "16.2.0", 2211 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 2212 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 2213 | "dev": true, 2214 | "requires": { 2215 | "cliui": "^7.0.2", 2216 | "escalade": "^3.1.1", 2217 | "get-caller-file": "^2.0.5", 2218 | "require-directory": "^2.1.1", 2219 | "string-width": "^4.2.0", 2220 | "y18n": "^5.0.5", 2221 | "yargs-parser": "^20.2.2" 2222 | } 2223 | }, 2224 | "yargs-parser": { 2225 | "version": "20.2.4", 2226 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 2227 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 2228 | "dev": true 2229 | }, 2230 | "yargs-unparser": { 2231 | "version": "2.0.0", 2232 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 2233 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 2234 | "dev": true, 2235 | "requires": { 2236 | "camelcase": "^6.0.0", 2237 | "decamelize": "^4.0.0", 2238 | "flat": "^5.0.2", 2239 | "is-plain-obj": "^2.1.0" 2240 | } 2241 | }, 2242 | "yn": { 2243 | "version": "3.1.1", 2244 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 2245 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 2246 | "dev": true 2247 | }, 2248 | "yocto-queue": { 2249 | "version": "0.1.0", 2250 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 2251 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 2252 | "dev": true 2253 | } 2254 | } 2255 | } 2256 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "classify", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "start": "node dist/index.js", 8 | "dev": "SET NODE_ENV=dev & nodemon -r tsconfig-paths/register src/index.ts", 9 | "build": "tsc -p .", 10 | "test": "SET NODE_ENV=test & mocha --check-leaks -r tsconfig-paths/register -r ts-node/register \"test/**/*.spec.ts\"" 11 | }, 12 | "keywords": [], 13 | "author": "cheatsnake", 14 | "license": "MIT", 15 | "devDependencies": { 16 | "@types/chai": "^4.2.22", 17 | "@types/cors": "^2.8.12", 18 | "@types/express": "^4.17.13", 19 | "@types/mocha": "^9.0.0", 20 | "@types/node": "^16.11.7", 21 | "@types/supertest": "^2.0.11", 22 | "chai": "^4.3.4", 23 | "mocha": "^9.1.3", 24 | "nodemon": "^2.0.15", 25 | "supertest": "^6.1.6", 26 | "ts-node": "^10.4.0", 27 | "tsconfig-paths": "^3.11.0", 28 | "typescript": "^4.4.4" 29 | }, 30 | "dependencies": { 31 | "cors": "^2.8.5", 32 | "dotenv": "^10.0.0", 33 | "express": "^4.17.1" 34 | } 35 | } 36 | -------------------------------------------------------------------------------- /src/controllers/crypto.controller.ts: -------------------------------------------------------------------------------- 1 | import { Request, Response } from "express"; 2 | import cryptoService from "../services/crypto.service"; 3 | 4 | type TData = String | null; 5 | 6 | class CryptoController { 7 | encryptData(req: Request, res: Response) { 8 | try { 9 | const { data, key } = req.body; 10 | const encryptedData: TData = 11 | cryptoService.encryptData(String(data), String(key)) || null; 12 | 13 | return res.json({ result: encryptedData }); 14 | } catch (error) { 15 | res.status(400).json({ message: "Invalid data" }); 16 | } 17 | } 18 | decryptData(req: Request, res: Response) { 19 | try { 20 | const { data, key } = req.body; 21 | const decryptedData: TData = 22 | cryptoService.decryptData(String(data), String(key)) || null; 23 | 24 | return res.json({ result: decryptedData }); 25 | } catch (error) { 26 | res.status(400).json({ message: "Invalid data" }); 27 | } 28 | } 29 | } 30 | 31 | export default new CryptoController(); 32 | -------------------------------------------------------------------------------- /src/controllers/keygen.controller.ts: -------------------------------------------------------------------------------- 1 | import { Request, Response } from "express"; 2 | import keygen from "../services/keygen.service"; 3 | 4 | type TKey = string | null; 5 | 6 | class KeygenController { 7 | keygen(req: Request, res: Response) { 8 | try { 9 | const length = Number(req.query.length) || 24; 10 | const symbols = Number(req.query.symbols) || 0; 11 | const key: TKey = keygen(length, symbols) || null; 12 | return res.json({ key }); 13 | } catch (error) { 14 | res.status(400).json({ message: "invalid data" }); 15 | } 16 | } 17 | } 18 | 19 | export default new KeygenController(); 20 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | import "dotenv/config"; 2 | import createServer from "./server"; 3 | 4 | const startServer = () => { 5 | const app = createServer(); 6 | const PORT: number = parseInt(process.env.PORT, 10) || 5000; 7 | 8 | app.listen(PORT, () => { 9 | console.log(`Server running on port ${PORT}`); 10 | }); 11 | }; 12 | 13 | startServer(); 14 | -------------------------------------------------------------------------------- /src/routes/api.routes.ts: -------------------------------------------------------------------------------- 1 | import cryptoController from "../controllers/crypto.controller"; 2 | import keygenController from "../controllers/keygen.controller"; 3 | import { Router } from "express"; 4 | 5 | const router: Router = Router(); 6 | 7 | router.post("/encrypt", cryptoController.encryptData); 8 | router.post("/decrypt", cryptoController.decryptData); 9 | router.get("/keygen", keygenController.keygen); 10 | 11 | export default router; 12 | -------------------------------------------------------------------------------- /src/server.ts: -------------------------------------------------------------------------------- 1 | import { Application, Request, Response } from "express"; 2 | import cors from "cors"; 3 | import apiRouter from "./routes/api.routes"; 4 | import express from "express"; 5 | 6 | export default function createServer() { 7 | const app: Application = express(); 8 | 9 | app.use(cors()); 10 | app.use(express.json()); 11 | app.use("/api", apiRouter); 12 | 13 | app.get("/", (req: Request, res: Response) => { 14 | res.send("Hello World!"); 15 | }); 16 | 17 | return app; 18 | } 19 | -------------------------------------------------------------------------------- /src/services/crypto.service.ts: -------------------------------------------------------------------------------- 1 | import { doubleCrypt, keyValidation } from "./hepler.service"; 2 | 3 | class CryptoService { 4 | encryptData(data: string, key: string): string { 5 | const validKey: string = keyValidation(data.length, key); 6 | const encryptData: number[] = []; 7 | 8 | for (let i: number = 0; i < data.length; i++) { 9 | const dataCode = data.charCodeAt(i); 10 | const keyCharCode = validKey.charCodeAt(i); 11 | const encryptedCode = dataCode ^ keyCharCode; 12 | 13 | encryptData.push(encryptedCode); 14 | } 15 | 16 | return doubleCrypt(encryptData).join(" "); 17 | } 18 | 19 | decryptData(data: string, key: string) { 20 | const validData = data.split(" ").map(Number); 21 | const encryptData: number[] = doubleCrypt(validData); 22 | const validKey: string = keyValidation(encryptData.length, key); 23 | const decryptedData: string[] = []; 24 | 25 | for (let i = 0; i < encryptData.length; i++) { 26 | const encryptedCode = encryptData[i]; 27 | const keyCharCode = validKey.charCodeAt(i); 28 | const decryptedCode = encryptedCode ^ keyCharCode; 29 | const decryptedChar = String.fromCharCode(decryptedCode); 30 | 31 | decryptedData.push(decryptedChar); 32 | } 33 | 34 | return decryptedData.join(""); 35 | } 36 | } 37 | 38 | export default new CryptoService(); -------------------------------------------------------------------------------- /src/services/hepler.service.ts: -------------------------------------------------------------------------------- 1 | import "dotenv/config"; 2 | 3 | export const randomNumber = (max: number, min = 1): number => 4 | Math.round(Math.random() * (max - min)) + min; 5 | 6 | export function keyValidation(dataLength: number, key: string): string { 7 | let validKey = key; 8 | while (validKey.length < dataLength) { 9 | validKey += key; 10 | } 11 | return validKey.slice(0, dataLength); 12 | } 13 | 14 | export function doubleCrypt(encruptData: number[]): number[] { 15 | const extraEncryptData: number[] = []; 16 | const secretKey: string = process.env.SECRET_KEY; 17 | 18 | for (let i = 0; i < encruptData.length; i++) { 19 | extraEncryptData.push(encruptData[i] ^ secretKey.charCodeAt(i)); 20 | } 21 | 22 | return extraEncryptData; 23 | } 24 | -------------------------------------------------------------------------------- /src/services/keygen.service.ts: -------------------------------------------------------------------------------- 1 | import { randomNumber } from "./hepler.service"; 2 | 3 | const symbolCodes = [58, 59, 60, 61, 62, 63, 64, 91, 92, 92, 93, 94, 95, 96]; 4 | 5 | function keygen(len: number, symbols: number): string { 6 | let key = ""; 7 | while (key.length < len) { 8 | key += randomChar(symbols); 9 | } 10 | return key; 11 | } 12 | 13 | const randomChar = (symbols: number): string => { 14 | if (symbols) return String.fromCharCode(randomNumber(126, 33)); 15 | 16 | let num: number = randomNumber(122, 48); 17 | 18 | while (symbolCodes.includes(num)) { 19 | num = randomNumber(122, 48); 20 | } 21 | 22 | return String.fromCharCode(num); 23 | }; 24 | 25 | export default keygen; 26 | -------------------------------------------------------------------------------- /test/routes/api-routes.spec.ts: -------------------------------------------------------------------------------- 1 | import request from 'supertest'; 2 | import { expect } from 'chai'; 3 | import createServer from "../../src/server"; 4 | 5 | const app = createServer(); 6 | 7 | describe('Checking API routes', function() { 8 | 9 | it('POST request to "/api/encrypt" should return encrypted data', function(done) { 10 | request(app) 11 | .post('/api/encrypt') 12 | .send({data: "data", key: "key"}) 13 | .set('Accept', 'application/json') 14 | .expect(200, {result: "86 85 76 96"}, done); 15 | }); 16 | 17 | it('POST request to "/api/decrypt" should return decrypted data', function(done) { 18 | request(app) 19 | .post('/api/decrypt') 20 | .send({data: "86 85 76 96", key: "key"}) 21 | .set('Accept', 'application/json') 22 | .expect(200, {result: "data"}, done); 23 | }); 24 | 25 | it('GET request to "/api/keygen" should return generated key', function(done) { 26 | request(app) 27 | .get('/api/keygen') 28 | .set('Accept', 'application/json') 29 | .expect(200, done); 30 | }); 31 | 32 | 33 | }); -------------------------------------------------------------------------------- /test/server.spec.ts: -------------------------------------------------------------------------------- 1 | import request from "supertest"; 2 | import { expect } from "chai"; 3 | import createServer from "../src/server"; 4 | 5 | const app = createServer(); 6 | 7 | describe("Checking server", function () { 8 | it("Server is created without error", function (done) { 9 | request(app).get("/").expect(200).end(done); 10 | }); 11 | }); 12 | -------------------------------------------------------------------------------- /test/services/crypto-service.spec.ts: -------------------------------------------------------------------------------- 1 | import cryptoService from '../../src/services/crypto.service'; 2 | import { expect } from "chai"; 3 | 4 | describe('Checking crypto service', function() { 5 | it('encrypt method should return a string of numbers', function() { 6 | const data = cryptoService.encryptData("data", "key"); 7 | expect(data).to.be.a('string'); 8 | data.split(" ").forEach((value) => expect(+value).to.be.a('number')); 9 | 10 | }); 11 | 12 | it('decrypt method should return a string', function() { 13 | const data = cryptoService.encryptData("data", "key"); 14 | expect(data).to.be.a('string'); 15 | }); 16 | }); -------------------------------------------------------------------------------- /test/services/helper-service.spec.ts: -------------------------------------------------------------------------------- 1 | import { randomNumber, doubleCrypt, keyValidation } from '../../src/services/hepler.service'; 2 | import { expect } from "chai"; 3 | 4 | describe('Checking helper service', function() { 5 | it('randomNumber with range [1,1] should return a number 1', function() { 6 | const num = randomNumber(1, 1); 7 | expect(num).equal(1); 8 | }); 9 | 10 | it('doubleCrypt should return an array of numbers', function() { 11 | const data = doubleCrypt([10, 20, 30]); 12 | expect(data).to.be.an('array'); 13 | data.forEach((value) => expect(value).to.be.a('number')); 14 | }); 15 | 16 | it('keyValidation should return a string with given length', function() { 17 | const validKey = keyValidation(12, 'test'); 18 | expect(validKey).equal('testtesttest'); 19 | }); 20 | }); -------------------------------------------------------------------------------- /test/services/keygen-service.spec.ts: -------------------------------------------------------------------------------- 1 | import keygen from '../../src/services/keygen.service'; 2 | import { expect } from "chai"; 3 | 4 | describe('Checking keygen service', function() { 5 | it('keygen function should return a string contains all characters except the space', function() { 6 | const key = keygen(100, 1); 7 | expect(key).to.be.a('string').that.not.include(' '); 8 | }); 9 | it('keygen function with argument (symbols = 0) should return a string contains only numbers and letters', function() { 10 | const key = keygen(100, 0); 11 | expect(key).match(/^[a-zA-Z0-9]+$/); 12 | }); 13 | }); -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es5", 4 | "module": "commonjs", 5 | "outDir": "./dist", 6 | "rootDir": "./src", 7 | "strict": true, 8 | "moduleResolution": "node", 9 | "baseUrl": "./src", 10 | "esModuleInterop": true, 11 | "skipLibCheck": true, 12 | "forceConsistentCasingInFileNames": true 13 | }, 14 | "exclude": [ 15 | "node_modules", 16 | "**/*.spec.ts", 17 | "dist" 18 | ] 19 | } --------------------------------------------------------------------------------