├── .env.example ├── .gitignore ├── .pretierrc ├── LICENSE ├── nodemon.json ├── package-lock.json ├── package.json ├── src ├── config │ └── db.ts ├── controllers │ ├── colorController.ts │ ├── designSystemController.ts │ ├── fontsController.ts │ ├── paletteController.ts │ ├── spacingsController.ts │ └── userController.ts ├── middleware │ ├── authMiddleware.ts │ ├── errorMiddleware.ts │ └── validateMiddleware.ts ├── models │ ├── colorModel.ts │ ├── designSystemModel.ts │ ├── fontsModel.ts │ ├── paletteModel.ts │ ├── spacingsModel.ts │ └── userModel.ts ├── routes │ ├── colorRoutes.ts │ ├── designSystemRoutes.ts │ ├── fontsRoutes.ts │ ├── paletteRoutes.ts │ ├── spacingsRoutes.ts │ └── userRoutes.ts ├── server.ts └── utils │ ├── colorFunctions.ts │ └── generateToken.ts └── tsconfig.json /.env.example: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Kosmos-Community/desma-api/82c0df5015e4c47fa7239198daf9835d18d145de/.env.example -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | lerna-debug.log* 8 | .pnpm-debug.log* 9 | 10 | # Diagnostic reports (https://nodejs.org/api/report.html) 11 | report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json 12 | 13 | # Runtime data 14 | pids 15 | *.pid 16 | *.seed 17 | *.pid.lock 18 | 19 | # Directory for instrumented libs generated by jscoverage/JSCover 20 | lib-cov 21 | 22 | # Coverage directory used by tools like istanbul 23 | coverage 24 | *.lcov 25 | 26 | # nyc test coverage 27 | .nyc_output 28 | 29 | # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) 30 | .grunt 31 | 32 | # Bower dependency directory (https://bower.io/) 33 | bower_components 34 | 35 | # node-waf configuration 36 | .lock-wscript 37 | 38 | # Compiled binary addons (https://nodejs.org/api/addons.html) 39 | build/Release 40 | 41 | # Dependency directories 42 | node_modules/ 43 | jspm_packages/ 44 | 45 | # Snowpack dependency directory (https://snowpack.dev/) 46 | web_modules/ 47 | 48 | # TypeScript cache 49 | *.tsbuildinfo 50 | 51 | # Optional npm cache directory 52 | .npm 53 | 54 | # Optional eslint cache 55 | .eslintcache 56 | 57 | # Optional stylelint cache 58 | .stylelintcache 59 | 60 | # Microbundle cache 61 | .rpt2_cache/ 62 | .rts2_cache_cjs/ 63 | .rts2_cache_es/ 64 | .rts2_cache_umd/ 65 | 66 | # Optional REPL history 67 | .node_repl_history 68 | 69 | # Output of 'npm pack' 70 | *.tgz 71 | 72 | # Yarn Integrity file 73 | .yarn-integrity 74 | 75 | # dotenv environment variable files 76 | .env 77 | .env.development.local 78 | .env.test.local 79 | .env.production.local 80 | .env.local 81 | 82 | # parcel-bundler cache (https://parceljs.org/) 83 | .cache 84 | .parcel-cache 85 | 86 | # Next.js build output 87 | .next 88 | out 89 | 90 | # Nuxt.js build / generate output 91 | .nuxt 92 | dist 93 | 94 | # Gatsby files 95 | .cache/ 96 | # Comment in the public line in if your project uses Gatsby and not Next.js 97 | # https://nextjs.org/blog/next-9-1#public-directory-support 98 | # public 99 | 100 | # vuepress build output 101 | .vuepress/dist 102 | 103 | # vuepress v2.x temp and cache directory 104 | .temp 105 | .cache 106 | 107 | # Docusaurus cache and generated files 108 | .docusaurus 109 | 110 | # Serverless directories 111 | .serverless/ 112 | 113 | # FuseBox cache 114 | .fusebox/ 115 | 116 | # DynamoDB Local files 117 | .dynamodb/ 118 | 119 | # TernJS port file 120 | .tern-port 121 | 122 | # Stores VSCode versions used for testing VSCode extensions 123 | .vscode-test 124 | 125 | # yarn v2 126 | .yarn/cache 127 | .yarn/unplugged 128 | .yarn/build-state.yml 129 | .yarn/install-state.gz 130 | .pnp.* -------------------------------------------------------------------------------- /.pretierrc: -------------------------------------------------------------------------------- 1 | { 2 | "trailingComma": "es5", 3 | "tabWidth": 2, 4 | "printWidth": 90, 5 | "semi": true, 6 | "singleQuote": true, 7 | "jsxSingleQuote": false, 8 | "bracketLine": true, 9 | "bracketSpacing": true, 10 | "arrowParens": "always" 11 | } 12 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2022 Kosmos-Community 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 | -------------------------------------------------------------------------------- /nodemon.json: -------------------------------------------------------------------------------- 1 | { 2 | "watch": ["src"], 3 | "ext": ".ts,.js", 4 | "ignore": [], 5 | "exec": "ts-node ./src/server.ts" 6 | } 7 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "desma-api", 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 | }, 12 | "@cspotcode/source-map-support": { 13 | "version": "0.7.0", 14 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.7.0.tgz", 15 | "integrity": "sha512-X4xqRHqN8ACt2aHVe51OxeA2HjbcL4MqFqXkrmQszJ1NOUuUu5u6Vqx/0lZSVNku7velL5FC/s5uEAj1lsBMhA==", 16 | "requires": { 17 | "@cspotcode/source-map-consumer": "0.8.0" 18 | } 19 | }, 20 | "@sindresorhus/is": { 21 | "version": "0.14.0", 22 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz", 23 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==" 24 | }, 25 | "@szmarczak/http-timer": { 26 | "version": "1.1.2", 27 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz", 28 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==", 29 | "requires": { 30 | "defer-to-connect": "^1.0.1" 31 | } 32 | }, 33 | "@tsconfig/node10": { 34 | "version": "1.0.8", 35 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.8.tgz", 36 | "integrity": "sha512-6XFfSQmMgq0CFLY1MslA/CPUfhIL919M1rMsa5lP2P097N2Wd1sSX0tx1u4olM16fLNhtHZpRhedZJphNJqmZg==" 37 | }, 38 | "@tsconfig/node12": { 39 | "version": "1.0.9", 40 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.9.tgz", 41 | "integrity": "sha512-/yBMcem+fbvhSREH+s14YJi18sp7J9jpuhYByADT2rypfajMZZN4WQ6zBGgBKp53NKmqI36wFYDb3yaMPurITw==" 42 | }, 43 | "@tsconfig/node14": { 44 | "version": "1.0.1", 45 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.1.tgz", 46 | "integrity": "sha512-509r2+yARFfHHE7T6Puu2jjkoycftovhXRqW328PDXTVGKihlb1P8Z9mMZH04ebyajfRY7dedfGynlrFHJUQCg==" 47 | }, 48 | "@tsconfig/node16": { 49 | "version": "1.0.2", 50 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.2.tgz", 51 | "integrity": "sha512-eZxlbI8GZscaGS7kkc/trHTT5xgrjH3/1n2JDwusC9iahPKWMRvRjJSAN5mCXviuTGQ/lHnhvv8Q1YTpnfz9gA==" 52 | }, 53 | "@types/bcryptjs": { 54 | "version": "2.4.2", 55 | "resolved": "https://registry.npmjs.org/@types/bcryptjs/-/bcryptjs-2.4.2.tgz", 56 | "integrity": "sha512-LiMQ6EOPob/4yUL66SZzu6Yh77cbzJFYll+ZfaPiPPFswtIlA/Fs1MzdKYA7JApHU49zQTbJGX3PDmCpIdDBRQ==", 57 | "dev": true 58 | }, 59 | "@types/body-parser": { 60 | "version": "1.19.2", 61 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz", 62 | "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==", 63 | "dev": true, 64 | "requires": { 65 | "@types/connect": "*", 66 | "@types/node": "*" 67 | } 68 | }, 69 | "@types/connect": { 70 | "version": "3.4.35", 71 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", 72 | "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", 73 | "dev": true, 74 | "requires": { 75 | "@types/node": "*" 76 | } 77 | }, 78 | "@types/cors": { 79 | "version": "2.8.12", 80 | "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.12.tgz", 81 | "integrity": "sha512-vt+kDhq/M2ayberEtJcIN/hxXy1Pk+59g2FV/ZQceeaTyCtCucjL2Q7FXlFjtWn4n15KCr1NE2lNNFhp0lEThw==", 82 | "dev": true 83 | }, 84 | "@types/express": { 85 | "version": "4.17.13", 86 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz", 87 | "integrity": "sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA==", 88 | "dev": true, 89 | "requires": { 90 | "@types/body-parser": "*", 91 | "@types/express-serve-static-core": "^4.17.18", 92 | "@types/qs": "*", 93 | "@types/serve-static": "*" 94 | } 95 | }, 96 | "@types/express-serve-static-core": { 97 | "version": "4.17.28", 98 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.28.tgz", 99 | "integrity": "sha512-P1BJAEAW3E2DJUlkgq4tOL3RyMunoWXqbSCygWo5ZIWTjUgN1YnaXWW4VWl/oc8vs/XoYibEGBKP0uZyF4AHig==", 100 | "dev": true, 101 | "requires": { 102 | "@types/node": "*", 103 | "@types/qs": "*", 104 | "@types/range-parser": "*" 105 | } 106 | }, 107 | "@types/jsonwebtoken": { 108 | "version": "8.5.8", 109 | "resolved": "https://registry.npmjs.org/@types/jsonwebtoken/-/jsonwebtoken-8.5.8.tgz", 110 | "integrity": "sha512-zm6xBQpFDIDM6o9r6HSgDeIcLy82TKWctCXEPbJJcXb5AKmi5BNNdLXneixK4lplX3PqIVcwLBCGE/kAGnlD4A==", 111 | "dev": true, 112 | "requires": { 113 | "@types/node": "*" 114 | } 115 | }, 116 | "@types/lodash": { 117 | "version": "4.14.179", 118 | "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.179.tgz", 119 | "integrity": "sha512-uwc1x90yCKqGcIOAT6DwOSuxnrAbpkdPsUOZtwrXb4D/6wZs+6qG7QnIawDuZWg0sWpxl+ltIKCaLoMlna678w==", 120 | "dev": true 121 | }, 122 | "@types/mime": { 123 | "version": "1.3.2", 124 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", 125 | "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==", 126 | "dev": true 127 | }, 128 | "@types/node": { 129 | "version": "17.0.17", 130 | "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.17.tgz", 131 | "integrity": "sha512-e8PUNQy1HgJGV3iU/Bp2+D/DXh3PYeyli8LgIwsQcs1Ar1LoaWHSIT6Rw+H2rNJmiq6SNWiDytfx8+gYj7wDHw==" 132 | }, 133 | "@types/qs": { 134 | "version": "6.9.7", 135 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 136 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==", 137 | "dev": true 138 | }, 139 | "@types/range-parser": { 140 | "version": "1.2.4", 141 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", 142 | "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==", 143 | "dev": true 144 | }, 145 | "@types/serve-static": { 146 | "version": "1.13.10", 147 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz", 148 | "integrity": "sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ==", 149 | "dev": true, 150 | "requires": { 151 | "@types/mime": "^1", 152 | "@types/node": "*" 153 | } 154 | }, 155 | "@types/webidl-conversions": { 156 | "version": "6.1.1", 157 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-6.1.1.tgz", 158 | "integrity": "sha512-XAahCdThVuCFDQLT7R7Pk/vqeObFNL3YqRyFZg+AqAP/W1/w3xHaIxuW7WszQqTbIBOPRcItYJIou3i/mppu3Q==" 159 | }, 160 | "@types/whatwg-url": { 161 | "version": "8.2.1", 162 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-8.2.1.tgz", 163 | "integrity": "sha512-2YubE1sjj5ifxievI5Ge1sckb9k/Er66HyR2c+3+I6VDUUg1TLPdYYTEbQ+DjRkS4nTxMJhgWfSfMRD2sl2EYQ==", 164 | "requires": { 165 | "@types/node": "*", 166 | "@types/webidl-conversions": "*" 167 | } 168 | }, 169 | "abbrev": { 170 | "version": "1.1.1", 171 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 172 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 173 | }, 174 | "accepts": { 175 | "version": "1.3.8", 176 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 177 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 178 | "requires": { 179 | "mime-types": "~2.1.34", 180 | "negotiator": "0.6.3" 181 | } 182 | }, 183 | "acorn": { 184 | "version": "8.7.0", 185 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.0.tgz", 186 | "integrity": "sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ==" 187 | }, 188 | "acorn-walk": { 189 | "version": "8.2.0", 190 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 191 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==" 192 | }, 193 | "ansi-align": { 194 | "version": "3.0.1", 195 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.1.tgz", 196 | "integrity": "sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w==", 197 | "requires": { 198 | "string-width": "^4.1.0" 199 | } 200 | }, 201 | "ansi-regex": { 202 | "version": "5.0.1", 203 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 204 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==" 205 | }, 206 | "ansi-styles": { 207 | "version": "4.3.0", 208 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 209 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 210 | "requires": { 211 | "color-convert": "^2.0.1" 212 | } 213 | }, 214 | "anymatch": { 215 | "version": "3.1.2", 216 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 217 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 218 | "requires": { 219 | "normalize-path": "^3.0.0", 220 | "picomatch": "^2.0.4" 221 | } 222 | }, 223 | "arg": { 224 | "version": "4.1.3", 225 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 226 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==" 227 | }, 228 | "array-flatten": { 229 | "version": "1.1.1", 230 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 231 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 232 | }, 233 | "balanced-match": { 234 | "version": "1.0.2", 235 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 236 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 237 | }, 238 | "base64-js": { 239 | "version": "1.5.1", 240 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 241 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==" 242 | }, 243 | "bcryptjs": { 244 | "version": "2.4.3", 245 | "resolved": "https://registry.npmjs.org/bcryptjs/-/bcryptjs-2.4.3.tgz", 246 | "integrity": "sha1-mrVie5PmBiH/fNrF2pczAn3x0Ms=" 247 | }, 248 | "binary-extensions": { 249 | "version": "2.2.0", 250 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 251 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==" 252 | }, 253 | "body-parser": { 254 | "version": "1.19.1", 255 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.1.tgz", 256 | "integrity": "sha512-8ljfQi5eBk8EJfECMrgqNGWPEY5jWP+1IzkzkGdFFEwFQZZyaZ21UqdaHktgiMlH0xLHqIFtE/u2OYE5dOtViA==", 257 | "requires": { 258 | "bytes": "3.1.1", 259 | "content-type": "~1.0.4", 260 | "debug": "2.6.9", 261 | "depd": "~1.1.2", 262 | "http-errors": "1.8.1", 263 | "iconv-lite": "0.4.24", 264 | "on-finished": "~2.3.0", 265 | "qs": "6.9.6", 266 | "raw-body": "2.4.2", 267 | "type-is": "~1.6.18" 268 | } 269 | }, 270 | "boxen": { 271 | "version": "5.1.2", 272 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-5.1.2.tgz", 273 | "integrity": "sha512-9gYgQKXx+1nP8mP7CzFyaUARhg7D3n1dF/FnErWmu9l6JvGpNUN278h0aSb+QjoiKSWG+iZ3uHrcqk0qrY9RQQ==", 274 | "requires": { 275 | "ansi-align": "^3.0.0", 276 | "camelcase": "^6.2.0", 277 | "chalk": "^4.1.0", 278 | "cli-boxes": "^2.2.1", 279 | "string-width": "^4.2.2", 280 | "type-fest": "^0.20.2", 281 | "widest-line": "^3.1.0", 282 | "wrap-ansi": "^7.0.0" 283 | } 284 | }, 285 | "brace-expansion": { 286 | "version": "1.1.11", 287 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 288 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 289 | "requires": { 290 | "balanced-match": "^1.0.0", 291 | "concat-map": "0.0.1" 292 | } 293 | }, 294 | "braces": { 295 | "version": "3.0.2", 296 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 297 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 298 | "requires": { 299 | "fill-range": "^7.0.1" 300 | } 301 | }, 302 | "bson": { 303 | "version": "4.6.1", 304 | "resolved": "https://registry.npmjs.org/bson/-/bson-4.6.1.tgz", 305 | "integrity": "sha512-I1LQ7Hz5zgwR4QquilLNZwbhPw0Apx7i7X9kGMBTsqPdml/03Q9NBtD9nt/19ahjlphktQImrnderxqpzeVDjw==", 306 | "requires": { 307 | "buffer": "^5.6.0" 308 | } 309 | }, 310 | "buffer": { 311 | "version": "5.7.1", 312 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", 313 | "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", 314 | "requires": { 315 | "base64-js": "^1.3.1", 316 | "ieee754": "^1.1.13" 317 | } 318 | }, 319 | "buffer-equal-constant-time": { 320 | "version": "1.0.1", 321 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 322 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 323 | }, 324 | "bytes": { 325 | "version": "3.1.1", 326 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.1.tgz", 327 | "integrity": "sha512-dWe4nWO/ruEOY7HkUJ5gFt1DCFV9zPRoJr8pV0/ASQermOZjtq8jMjOprC0Kd10GLN+l7xaUPvxzJFWtxGu8Fg==" 328 | }, 329 | "cacheable-request": { 330 | "version": "6.1.0", 331 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz", 332 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==", 333 | "requires": { 334 | "clone-response": "^1.0.2", 335 | "get-stream": "^5.1.0", 336 | "http-cache-semantics": "^4.0.0", 337 | "keyv": "^3.0.0", 338 | "lowercase-keys": "^2.0.0", 339 | "normalize-url": "^4.1.0", 340 | "responselike": "^1.0.2" 341 | }, 342 | "dependencies": { 343 | "get-stream": { 344 | "version": "5.2.0", 345 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", 346 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", 347 | "requires": { 348 | "pump": "^3.0.0" 349 | } 350 | }, 351 | "lowercase-keys": { 352 | "version": "2.0.0", 353 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", 354 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==" 355 | } 356 | } 357 | }, 358 | "camelcase": { 359 | "version": "6.3.0", 360 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 361 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==" 362 | }, 363 | "chalk": { 364 | "version": "4.1.2", 365 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 366 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 367 | "requires": { 368 | "ansi-styles": "^4.1.0", 369 | "supports-color": "^7.1.0" 370 | }, 371 | "dependencies": { 372 | "has-flag": { 373 | "version": "4.0.0", 374 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 375 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" 376 | }, 377 | "supports-color": { 378 | "version": "7.2.0", 379 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 380 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 381 | "requires": { 382 | "has-flag": "^4.0.0" 383 | } 384 | } 385 | } 386 | }, 387 | "chokidar": { 388 | "version": "3.5.3", 389 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 390 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 391 | "requires": { 392 | "anymatch": "~3.1.2", 393 | "braces": "~3.0.2", 394 | "fsevents": "~2.3.2", 395 | "glob-parent": "~5.1.2", 396 | "is-binary-path": "~2.1.0", 397 | "is-glob": "~4.0.1", 398 | "normalize-path": "~3.0.0", 399 | "readdirp": "~3.6.0" 400 | } 401 | }, 402 | "ci-info": { 403 | "version": "2.0.0", 404 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 405 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==" 406 | }, 407 | "cli-boxes": { 408 | "version": "2.2.1", 409 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz", 410 | "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==" 411 | }, 412 | "clone-response": { 413 | "version": "1.0.2", 414 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz", 415 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=", 416 | "requires": { 417 | "mimic-response": "^1.0.0" 418 | } 419 | }, 420 | "color-convert": { 421 | "version": "2.0.1", 422 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 423 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 424 | "requires": { 425 | "color-name": "~1.1.4" 426 | } 427 | }, 428 | "color-name": { 429 | "version": "1.1.4", 430 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 431 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 432 | }, 433 | "concat-map": { 434 | "version": "0.0.1", 435 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 436 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 437 | }, 438 | "configstore": { 439 | "version": "5.0.1", 440 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz", 441 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==", 442 | "requires": { 443 | "dot-prop": "^5.2.0", 444 | "graceful-fs": "^4.1.2", 445 | "make-dir": "^3.0.0", 446 | "unique-string": "^2.0.0", 447 | "write-file-atomic": "^3.0.0", 448 | "xdg-basedir": "^4.0.0" 449 | } 450 | }, 451 | "content-disposition": { 452 | "version": "0.5.4", 453 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 454 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 455 | "requires": { 456 | "safe-buffer": "5.2.1" 457 | } 458 | }, 459 | "content-type": { 460 | "version": "1.0.4", 461 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 462 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 463 | }, 464 | "cookie": { 465 | "version": "0.4.1", 466 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz", 467 | "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA==" 468 | }, 469 | "cookie-signature": { 470 | "version": "1.0.6", 471 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 472 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 473 | }, 474 | "cors": { 475 | "version": "2.8.5", 476 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 477 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 478 | "requires": { 479 | "object-assign": "^4", 480 | "vary": "^1" 481 | } 482 | }, 483 | "create-require": { 484 | "version": "1.1.1", 485 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 486 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==" 487 | }, 488 | "crypto-random-string": { 489 | "version": "2.0.0", 490 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", 491 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==" 492 | }, 493 | "debug": { 494 | "version": "2.6.9", 495 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 496 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 497 | "requires": { 498 | "ms": "2.0.0" 499 | } 500 | }, 501 | "decompress-response": { 502 | "version": "3.3.0", 503 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz", 504 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=", 505 | "requires": { 506 | "mimic-response": "^1.0.0" 507 | } 508 | }, 509 | "deep-extend": { 510 | "version": "0.6.0", 511 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 512 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==" 513 | }, 514 | "defer-to-connect": { 515 | "version": "1.1.3", 516 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz", 517 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==" 518 | }, 519 | "denque": { 520 | "version": "2.0.1", 521 | "resolved": "https://registry.npmjs.org/denque/-/denque-2.0.1.tgz", 522 | "integrity": "sha512-tfiWc6BQLXNLpNiR5iGd0Ocu3P3VpxfzFiqubLgMfhfOw9WyvgJBd46CClNn9k3qfbjvT//0cf7AlYRX/OslMQ==" 523 | }, 524 | "depd": { 525 | "version": "1.1.2", 526 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 527 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 528 | }, 529 | "destroy": { 530 | "version": "1.0.4", 531 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 532 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 533 | }, 534 | "diff": { 535 | "version": "4.0.2", 536 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 537 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==" 538 | }, 539 | "dot-prop": { 540 | "version": "5.3.0", 541 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz", 542 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==", 543 | "requires": { 544 | "is-obj": "^2.0.0" 545 | } 546 | }, 547 | "dotenv": { 548 | "version": "16.0.0", 549 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.0.tgz", 550 | "integrity": "sha512-qD9WU0MPM4SWLPJy/r2Be+2WgQj8plChsyrCNQzW/0WjvcJQiKQJ9mH3ZgB3fxbUUxgc/11ZJ0Fi5KiimWGz2Q==" 551 | }, 552 | "duplexer3": { 553 | "version": "0.1.4", 554 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 555 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=" 556 | }, 557 | "ecdsa-sig-formatter": { 558 | "version": "1.0.11", 559 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 560 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 561 | "requires": { 562 | "safe-buffer": "^5.0.1" 563 | } 564 | }, 565 | "ee-first": { 566 | "version": "1.1.1", 567 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 568 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 569 | }, 570 | "emoji-regex": { 571 | "version": "8.0.0", 572 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 573 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 574 | }, 575 | "encodeurl": { 576 | "version": "1.0.2", 577 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 578 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 579 | }, 580 | "end-of-stream": { 581 | "version": "1.4.4", 582 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 583 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 584 | "requires": { 585 | "once": "^1.4.0" 586 | } 587 | }, 588 | "escape-goat": { 589 | "version": "2.1.1", 590 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz", 591 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==" 592 | }, 593 | "escape-html": { 594 | "version": "1.0.3", 595 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 596 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 597 | }, 598 | "etag": { 599 | "version": "1.8.1", 600 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 601 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 602 | }, 603 | "express": { 604 | "version": "4.17.2", 605 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.2.tgz", 606 | "integrity": "sha512-oxlxJxcQlYwqPWKVJJtvQiwHgosH/LrLSPA+H4UxpyvSS6jC5aH+5MoHFM+KABgTOt0APue4w66Ha8jCUo9QGg==", 607 | "requires": { 608 | "accepts": "~1.3.7", 609 | "array-flatten": "1.1.1", 610 | "body-parser": "1.19.1", 611 | "content-disposition": "0.5.4", 612 | "content-type": "~1.0.4", 613 | "cookie": "0.4.1", 614 | "cookie-signature": "1.0.6", 615 | "debug": "2.6.9", 616 | "depd": "~1.1.2", 617 | "encodeurl": "~1.0.2", 618 | "escape-html": "~1.0.3", 619 | "etag": "~1.8.1", 620 | "finalhandler": "~1.1.2", 621 | "fresh": "0.5.2", 622 | "merge-descriptors": "1.0.1", 623 | "methods": "~1.1.2", 624 | "on-finished": "~2.3.0", 625 | "parseurl": "~1.3.3", 626 | "path-to-regexp": "0.1.7", 627 | "proxy-addr": "~2.0.7", 628 | "qs": "6.9.6", 629 | "range-parser": "~1.2.1", 630 | "safe-buffer": "5.2.1", 631 | "send": "0.17.2", 632 | "serve-static": "1.14.2", 633 | "setprototypeof": "1.2.0", 634 | "statuses": "~1.5.0", 635 | "type-is": "~1.6.18", 636 | "utils-merge": "1.0.1", 637 | "vary": "~1.1.2" 638 | } 639 | }, 640 | "fill-range": { 641 | "version": "7.0.1", 642 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 643 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 644 | "requires": { 645 | "to-regex-range": "^5.0.1" 646 | } 647 | }, 648 | "finalhandler": { 649 | "version": "1.1.2", 650 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 651 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 652 | "requires": { 653 | "debug": "2.6.9", 654 | "encodeurl": "~1.0.2", 655 | "escape-html": "~1.0.3", 656 | "on-finished": "~2.3.0", 657 | "parseurl": "~1.3.3", 658 | "statuses": "~1.5.0", 659 | "unpipe": "~1.0.0" 660 | } 661 | }, 662 | "forwarded": { 663 | "version": "0.2.0", 664 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 665 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 666 | }, 667 | "fresh": { 668 | "version": "0.5.2", 669 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 670 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 671 | }, 672 | "fsevents": { 673 | "version": "2.3.2", 674 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 675 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 676 | "optional": true 677 | }, 678 | "get-stream": { 679 | "version": "4.1.0", 680 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 681 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 682 | "requires": { 683 | "pump": "^3.0.0" 684 | } 685 | }, 686 | "glob-parent": { 687 | "version": "5.1.2", 688 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 689 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 690 | "requires": { 691 | "is-glob": "^4.0.1" 692 | } 693 | }, 694 | "global-dirs": { 695 | "version": "3.0.0", 696 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-3.0.0.tgz", 697 | "integrity": "sha512-v8ho2DS5RiCjftj1nD9NmnfaOzTdud7RRnVd9kFNOjqZbISlx5DQ+OrTkywgd0dIt7oFCvKetZSHoHcP3sDdiA==", 698 | "requires": { 699 | "ini": "2.0.0" 700 | } 701 | }, 702 | "got": { 703 | "version": "9.6.0", 704 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz", 705 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==", 706 | "requires": { 707 | "@sindresorhus/is": "^0.14.0", 708 | "@szmarczak/http-timer": "^1.1.2", 709 | "cacheable-request": "^6.0.0", 710 | "decompress-response": "^3.3.0", 711 | "duplexer3": "^0.1.4", 712 | "get-stream": "^4.1.0", 713 | "lowercase-keys": "^1.0.1", 714 | "mimic-response": "^1.0.1", 715 | "p-cancelable": "^1.0.0", 716 | "to-readable-stream": "^1.0.0", 717 | "url-parse-lax": "^3.0.0" 718 | } 719 | }, 720 | "graceful-fs": { 721 | "version": "4.2.9", 722 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz", 723 | "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==" 724 | }, 725 | "has-flag": { 726 | "version": "3.0.0", 727 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 728 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 729 | }, 730 | "has-yarn": { 731 | "version": "2.1.0", 732 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz", 733 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==" 734 | }, 735 | "http-cache-semantics": { 736 | "version": "4.1.0", 737 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 738 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==" 739 | }, 740 | "http-errors": { 741 | "version": "1.8.1", 742 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz", 743 | "integrity": "sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g==", 744 | "requires": { 745 | "depd": "~1.1.2", 746 | "inherits": "2.0.4", 747 | "setprototypeof": "1.2.0", 748 | "statuses": ">= 1.5.0 < 2", 749 | "toidentifier": "1.0.1" 750 | } 751 | }, 752 | "iconv-lite": { 753 | "version": "0.4.24", 754 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 755 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 756 | "requires": { 757 | "safer-buffer": ">= 2.1.2 < 3" 758 | } 759 | }, 760 | "ieee754": { 761 | "version": "1.2.1", 762 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 763 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==" 764 | }, 765 | "ignore-by-default": { 766 | "version": "1.0.1", 767 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 768 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=" 769 | }, 770 | "import-lazy": { 771 | "version": "2.1.0", 772 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 773 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=" 774 | }, 775 | "imurmurhash": { 776 | "version": "0.1.4", 777 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 778 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=" 779 | }, 780 | "inherits": { 781 | "version": "2.0.4", 782 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 783 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 784 | }, 785 | "ini": { 786 | "version": "2.0.0", 787 | "resolved": "https://registry.npmjs.org/ini/-/ini-2.0.0.tgz", 788 | "integrity": "sha512-7PnF4oN3CvZF23ADhA5wRaYEQpJ8qygSkbtTXWBeXWXmEVRXK+1ITciHWwHhsjv1TmW0MgacIv6hEi5pX5NQdA==" 789 | }, 790 | "ip": { 791 | "version": "1.1.5", 792 | "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.5.tgz", 793 | "integrity": "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=" 794 | }, 795 | "ipaddr.js": { 796 | "version": "1.9.1", 797 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 798 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 799 | }, 800 | "is-binary-path": { 801 | "version": "2.1.0", 802 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 803 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 804 | "requires": { 805 | "binary-extensions": "^2.0.0" 806 | } 807 | }, 808 | "is-ci": { 809 | "version": "2.0.0", 810 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", 811 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", 812 | "requires": { 813 | "ci-info": "^2.0.0" 814 | } 815 | }, 816 | "is-extglob": { 817 | "version": "2.1.1", 818 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 819 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" 820 | }, 821 | "is-fullwidth-code-point": { 822 | "version": "3.0.0", 823 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 824 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" 825 | }, 826 | "is-glob": { 827 | "version": "4.0.3", 828 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 829 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 830 | "requires": { 831 | "is-extglob": "^2.1.1" 832 | } 833 | }, 834 | "is-installed-globally": { 835 | "version": "0.4.0", 836 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.4.0.tgz", 837 | "integrity": "sha512-iwGqO3J21aaSkC7jWnHP/difazwS7SFeIqxv6wEtLU8Y5KlzFTjyqcSIT0d8s4+dDhKytsk9PJZ2BkS5eZwQRQ==", 838 | "requires": { 839 | "global-dirs": "^3.0.0", 840 | "is-path-inside": "^3.0.2" 841 | } 842 | }, 843 | "is-npm": { 844 | "version": "5.0.0", 845 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-5.0.0.tgz", 846 | "integrity": "sha512-WW/rQLOazUq+ST/bCAVBp/2oMERWLsR7OrKyt052dNDk4DHcDE0/7QSXITlmi+VBcV13DfIbysG3tZJm5RfdBA==" 847 | }, 848 | "is-number": { 849 | "version": "7.0.0", 850 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 851 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==" 852 | }, 853 | "is-obj": { 854 | "version": "2.0.0", 855 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 856 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==" 857 | }, 858 | "is-path-inside": { 859 | "version": "3.0.3", 860 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 861 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==" 862 | }, 863 | "is-typedarray": { 864 | "version": "1.0.0", 865 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 866 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 867 | }, 868 | "is-yarn-global": { 869 | "version": "0.3.0", 870 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz", 871 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==" 872 | }, 873 | "json-buffer": { 874 | "version": "3.0.0", 875 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz", 876 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=" 877 | }, 878 | "jsonwebtoken": { 879 | "version": "8.5.1", 880 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", 881 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", 882 | "requires": { 883 | "jws": "^3.2.2", 884 | "lodash.includes": "^4.3.0", 885 | "lodash.isboolean": "^3.0.3", 886 | "lodash.isinteger": "^4.0.4", 887 | "lodash.isnumber": "^3.0.3", 888 | "lodash.isplainobject": "^4.0.6", 889 | "lodash.isstring": "^4.0.1", 890 | "lodash.once": "^4.0.0", 891 | "ms": "^2.1.1", 892 | "semver": "^5.6.0" 893 | }, 894 | "dependencies": { 895 | "ms": { 896 | "version": "2.1.3", 897 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 898 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 899 | } 900 | } 901 | }, 902 | "jwa": { 903 | "version": "1.4.1", 904 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 905 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 906 | "requires": { 907 | "buffer-equal-constant-time": "1.0.1", 908 | "ecdsa-sig-formatter": "1.0.11", 909 | "safe-buffer": "^5.0.1" 910 | } 911 | }, 912 | "jws": { 913 | "version": "3.2.2", 914 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 915 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 916 | "requires": { 917 | "jwa": "^1.4.1", 918 | "safe-buffer": "^5.0.1" 919 | } 920 | }, 921 | "kareem": { 922 | "version": "2.3.3", 923 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.3.tgz", 924 | "integrity": "sha512-uESCXM2KdtOQ8LOvKyTUXEeg0MkYp4wGglTIpGcYHvjJcS5sn2Wkfrfit8m4xSbaNDAw2KdI9elgkOxZbrFYbg==" 925 | }, 926 | "keyv": { 927 | "version": "3.1.0", 928 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz", 929 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==", 930 | "requires": { 931 | "json-buffer": "3.0.0" 932 | } 933 | }, 934 | "latest-version": { 935 | "version": "5.1.0", 936 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz", 937 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==", 938 | "requires": { 939 | "package-json": "^6.3.0" 940 | } 941 | }, 942 | "lodash": { 943 | "version": "4.17.21", 944 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 945 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 946 | }, 947 | "lodash.includes": { 948 | "version": "4.3.0", 949 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 950 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 951 | }, 952 | "lodash.isboolean": { 953 | "version": "3.0.3", 954 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 955 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 956 | }, 957 | "lodash.isinteger": { 958 | "version": "4.0.4", 959 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 960 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 961 | }, 962 | "lodash.isnumber": { 963 | "version": "3.0.3", 964 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 965 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 966 | }, 967 | "lodash.isplainobject": { 968 | "version": "4.0.6", 969 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 970 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 971 | }, 972 | "lodash.isstring": { 973 | "version": "4.0.1", 974 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 975 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 976 | }, 977 | "lodash.once": { 978 | "version": "4.1.1", 979 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 980 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 981 | }, 982 | "lowercase-keys": { 983 | "version": "1.0.1", 984 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 985 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==" 986 | }, 987 | "lru-cache": { 988 | "version": "6.0.0", 989 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 990 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 991 | "requires": { 992 | "yallist": "^4.0.0" 993 | } 994 | }, 995 | "make-dir": { 996 | "version": "3.1.0", 997 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 998 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 999 | "requires": { 1000 | "semver": "^6.0.0" 1001 | }, 1002 | "dependencies": { 1003 | "semver": { 1004 | "version": "6.3.0", 1005 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1006 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 1007 | } 1008 | } 1009 | }, 1010 | "make-error": { 1011 | "version": "1.3.6", 1012 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1013 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==" 1014 | }, 1015 | "media-typer": { 1016 | "version": "0.3.0", 1017 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1018 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1019 | }, 1020 | "memory-pager": { 1021 | "version": "1.5.0", 1022 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1023 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 1024 | "optional": true 1025 | }, 1026 | "merge-descriptors": { 1027 | "version": "1.0.1", 1028 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1029 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1030 | }, 1031 | "methods": { 1032 | "version": "1.1.2", 1033 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1034 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1035 | }, 1036 | "mime": { 1037 | "version": "1.6.0", 1038 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1039 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 1040 | }, 1041 | "mime-db": { 1042 | "version": "1.51.0", 1043 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.51.0.tgz", 1044 | "integrity": "sha512-5y8A56jg7XVQx2mbv1lu49NR4dokRnhZYTtL+KGfaa27uq4pSTXkwQkFJl4pkRMyNFz/EtYDSkiiEHx3F7UN6g==" 1045 | }, 1046 | "mime-types": { 1047 | "version": "2.1.34", 1048 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.34.tgz", 1049 | "integrity": "sha512-6cP692WwGIs9XXdOO4++N+7qjqv0rqxxVvJ3VHPh/Sc9mVZcQP+ZGhkKiTvWMQRr2tbHkJP/Yn7Y0npb3ZBs4A==", 1050 | "requires": { 1051 | "mime-db": "1.51.0" 1052 | } 1053 | }, 1054 | "mimic-response": { 1055 | "version": "1.0.1", 1056 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", 1057 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==" 1058 | }, 1059 | "minimatch": { 1060 | "version": "3.0.5", 1061 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.5.tgz", 1062 | "integrity": "sha512-tUpxzX0VAzJHjLu0xUfFv1gwVp9ba3IOuRAVH2EGuRW8a5emA2FlACLqiT/lDVtS1W+TGNwqz3sWaNyLgDJWuw==", 1063 | "requires": { 1064 | "brace-expansion": "^1.1.7" 1065 | } 1066 | }, 1067 | "minimist": { 1068 | "version": "1.2.5", 1069 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1070 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 1071 | }, 1072 | "mongodb": { 1073 | "version": "4.3.1", 1074 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-4.3.1.tgz", 1075 | "integrity": "sha512-sNa8APSIk+r4x31ZwctKjuPSaeKuvUeNb/fu/3B6dRM02HpEgig7hTHM8A/PJQTlxuC/KFWlDlQjhsk/S43tBg==", 1076 | "requires": { 1077 | "bson": "^4.6.1", 1078 | "denque": "^2.0.1", 1079 | "mongodb-connection-string-url": "^2.4.1", 1080 | "saslprep": "^1.0.3", 1081 | "socks": "^2.6.1" 1082 | } 1083 | }, 1084 | "mongodb-connection-string-url": { 1085 | "version": "2.4.2", 1086 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-2.4.2.tgz", 1087 | "integrity": "sha512-mZUXF6nUzRWk5J3h41MsPv13ukWlH4jOMSk6astVeoZ1EbdTJyF5I3wxKkvqBAOoVtzLgyEYUvDjrGdcPlKjAw==", 1088 | "requires": { 1089 | "@types/whatwg-url": "^8.2.1", 1090 | "whatwg-url": "^11.0.0" 1091 | } 1092 | }, 1093 | "mongoose": { 1094 | "version": "6.2.1", 1095 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-6.2.1.tgz", 1096 | "integrity": "sha512-VxY1wvlc4uBQKyKNVDoEkTU3/ayFOD//qVXYP+sFyvTRbAj9/M53UWTERd84pWogs2TqAC6DTvZbxCs2LoOd3Q==", 1097 | "requires": { 1098 | "bson": "^4.2.2", 1099 | "kareem": "2.3.3", 1100 | "mongodb": "4.3.1", 1101 | "mpath": "0.8.4", 1102 | "mquery": "4.0.2", 1103 | "ms": "2.1.2", 1104 | "sift": "13.5.2" 1105 | }, 1106 | "dependencies": { 1107 | "ms": { 1108 | "version": "2.1.2", 1109 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1110 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1111 | } 1112 | } 1113 | }, 1114 | "mongoose-referrence-validator": { 1115 | "version": "1.0.0", 1116 | "resolved": "https://registry.npmjs.org/mongoose-referrence-validator/-/mongoose-referrence-validator-1.0.0.tgz", 1117 | "integrity": "sha512-FYsfNAOHrvZQWpQoQRLKkgqigPNe5Jfqh/cpvG6/V2LWoKkcGgUL6+O5cMFyfMesACyDl2hHGhf8vPse5LsV+Q==" 1118 | }, 1119 | "mpath": { 1120 | "version": "0.8.4", 1121 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.8.4.tgz", 1122 | "integrity": "sha512-DTxNZomBcTWlrMW76jy1wvV37X/cNNxPW1y2Jzd4DZkAaC5ZGsm8bfGfNOthcDuRJujXLqiuS6o3Tpy0JEoh7g==" 1123 | }, 1124 | "mquery": { 1125 | "version": "4.0.2", 1126 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-4.0.2.tgz", 1127 | "integrity": "sha512-oAVF0Nil1mT3rxty6Zln4YiD6x6QsUWYz927jZzjMxOK2aqmhEz5JQ7xmrKK7xRFA2dwV+YaOpKU/S+vfNqKxA==", 1128 | "requires": { 1129 | "debug": "4.x" 1130 | }, 1131 | "dependencies": { 1132 | "debug": { 1133 | "version": "4.3.3", 1134 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 1135 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 1136 | "requires": { 1137 | "ms": "2.1.2" 1138 | } 1139 | }, 1140 | "ms": { 1141 | "version": "2.1.2", 1142 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1143 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1144 | } 1145 | } 1146 | }, 1147 | "ms": { 1148 | "version": "2.0.0", 1149 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1150 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1151 | }, 1152 | "negotiator": { 1153 | "version": "0.6.3", 1154 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1155 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==" 1156 | }, 1157 | "nodemon": { 1158 | "version": "2.0.15", 1159 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.15.tgz", 1160 | "integrity": "sha512-gdHMNx47Gw7b3kWxJV64NI+Q5nfl0y5DgDbiVtShiwa7Z0IZ07Ll4RLFo6AjrhzMtoEZn5PDE3/c2AbVsiCkpA==", 1161 | "requires": { 1162 | "chokidar": "^3.5.2", 1163 | "debug": "^3.2.7", 1164 | "ignore-by-default": "^1.0.1", 1165 | "minimatch": "^3.0.4", 1166 | "pstree.remy": "^1.1.8", 1167 | "semver": "^5.7.1", 1168 | "supports-color": "^5.5.0", 1169 | "touch": "^3.1.0", 1170 | "undefsafe": "^2.0.5", 1171 | "update-notifier": "^5.1.0" 1172 | }, 1173 | "dependencies": { 1174 | "debug": { 1175 | "version": "3.2.7", 1176 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1177 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1178 | "requires": { 1179 | "ms": "^2.1.1" 1180 | } 1181 | }, 1182 | "ms": { 1183 | "version": "2.1.3", 1184 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1185 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1186 | } 1187 | } 1188 | }, 1189 | "nopt": { 1190 | "version": "1.0.10", 1191 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1192 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 1193 | "requires": { 1194 | "abbrev": "1" 1195 | } 1196 | }, 1197 | "normalize-path": { 1198 | "version": "3.0.0", 1199 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1200 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==" 1201 | }, 1202 | "normalize-url": { 1203 | "version": "4.5.1", 1204 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.1.tgz", 1205 | "integrity": "sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA==" 1206 | }, 1207 | "object-assign": { 1208 | "version": "4.1.1", 1209 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1210 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1211 | }, 1212 | "on-finished": { 1213 | "version": "2.3.0", 1214 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1215 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1216 | "requires": { 1217 | "ee-first": "1.1.1" 1218 | } 1219 | }, 1220 | "once": { 1221 | "version": "1.4.0", 1222 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1223 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1224 | "requires": { 1225 | "wrappy": "1" 1226 | } 1227 | }, 1228 | "p-cancelable": { 1229 | "version": "1.1.0", 1230 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz", 1231 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==" 1232 | }, 1233 | "package-json": { 1234 | "version": "6.5.0", 1235 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz", 1236 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==", 1237 | "requires": { 1238 | "got": "^9.6.0", 1239 | "registry-auth-token": "^4.0.0", 1240 | "registry-url": "^5.0.0", 1241 | "semver": "^6.2.0" 1242 | }, 1243 | "dependencies": { 1244 | "semver": { 1245 | "version": "6.3.0", 1246 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1247 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 1248 | } 1249 | } 1250 | }, 1251 | "parseurl": { 1252 | "version": "1.3.3", 1253 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1254 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 1255 | }, 1256 | "path-to-regexp": { 1257 | "version": "0.1.7", 1258 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1259 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1260 | }, 1261 | "picomatch": { 1262 | "version": "2.3.1", 1263 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1264 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==" 1265 | }, 1266 | "prepend-http": { 1267 | "version": "2.0.0", 1268 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz", 1269 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=" 1270 | }, 1271 | "proxy-addr": { 1272 | "version": "2.0.7", 1273 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1274 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1275 | "requires": { 1276 | "forwarded": "0.2.0", 1277 | "ipaddr.js": "1.9.1" 1278 | } 1279 | }, 1280 | "pstree.remy": { 1281 | "version": "1.1.8", 1282 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1283 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==" 1284 | }, 1285 | "pump": { 1286 | "version": "3.0.0", 1287 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1288 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1289 | "requires": { 1290 | "end-of-stream": "^1.1.0", 1291 | "once": "^1.3.1" 1292 | } 1293 | }, 1294 | "punycode": { 1295 | "version": "2.1.1", 1296 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1297 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" 1298 | }, 1299 | "pupa": { 1300 | "version": "2.1.1", 1301 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz", 1302 | "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==", 1303 | "requires": { 1304 | "escape-goat": "^2.0.0" 1305 | } 1306 | }, 1307 | "qs": { 1308 | "version": "6.9.6", 1309 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.9.6.tgz", 1310 | "integrity": "sha512-TIRk4aqYLNoJUbd+g2lEdz5kLWIuTMRagAXxl78Q0RiVjAOugHmeKNGdd3cwo/ktpf9aL9epCfFqWDEKysUlLQ==" 1311 | }, 1312 | "range-parser": { 1313 | "version": "1.2.1", 1314 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1315 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 1316 | }, 1317 | "raw-body": { 1318 | "version": "2.4.2", 1319 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.2.tgz", 1320 | "integrity": "sha512-RPMAFUJP19WIet/99ngh6Iv8fzAbqum4Li7AD6DtGaW2RpMB/11xDoalPiJMTbu6I3hkbMVkATvZrqb9EEqeeQ==", 1321 | "requires": { 1322 | "bytes": "3.1.1", 1323 | "http-errors": "1.8.1", 1324 | "iconv-lite": "0.4.24", 1325 | "unpipe": "1.0.0" 1326 | } 1327 | }, 1328 | "rc": { 1329 | "version": "1.2.8", 1330 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1331 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1332 | "requires": { 1333 | "deep-extend": "^0.6.0", 1334 | "ini": "~1.3.0", 1335 | "minimist": "^1.2.0", 1336 | "strip-json-comments": "~2.0.1" 1337 | }, 1338 | "dependencies": { 1339 | "ini": { 1340 | "version": "1.3.8", 1341 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 1342 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==" 1343 | } 1344 | } 1345 | }, 1346 | "readdirp": { 1347 | "version": "3.6.0", 1348 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1349 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1350 | "requires": { 1351 | "picomatch": "^2.2.1" 1352 | } 1353 | }, 1354 | "registry-auth-token": { 1355 | "version": "4.2.1", 1356 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.1.tgz", 1357 | "integrity": "sha512-6gkSb4U6aWJB4SF2ZvLb76yCBjcvufXBqvvEx1HbmKPkutswjW1xNVRY0+daljIYRbogN7O0etYSlbiaEQyMyw==", 1358 | "requires": { 1359 | "rc": "^1.2.8" 1360 | } 1361 | }, 1362 | "registry-url": { 1363 | "version": "5.1.0", 1364 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz", 1365 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==", 1366 | "requires": { 1367 | "rc": "^1.2.8" 1368 | } 1369 | }, 1370 | "responselike": { 1371 | "version": "1.0.2", 1372 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz", 1373 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=", 1374 | "requires": { 1375 | "lowercase-keys": "^1.0.0" 1376 | } 1377 | }, 1378 | "safe-buffer": { 1379 | "version": "5.2.1", 1380 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1381 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 1382 | }, 1383 | "safer-buffer": { 1384 | "version": "2.1.2", 1385 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1386 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1387 | }, 1388 | "saslprep": { 1389 | "version": "1.0.3", 1390 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 1391 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 1392 | "optional": true, 1393 | "requires": { 1394 | "sparse-bitfield": "^3.0.3" 1395 | } 1396 | }, 1397 | "semver": { 1398 | "version": "5.7.1", 1399 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1400 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 1401 | }, 1402 | "semver-diff": { 1403 | "version": "3.1.1", 1404 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz", 1405 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==", 1406 | "requires": { 1407 | "semver": "^6.3.0" 1408 | }, 1409 | "dependencies": { 1410 | "semver": { 1411 | "version": "6.3.0", 1412 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1413 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 1414 | } 1415 | } 1416 | }, 1417 | "send": { 1418 | "version": "0.17.2", 1419 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.2.tgz", 1420 | "integrity": "sha512-UJYB6wFSJE3G00nEivR5rgWp8c2xXvJ3OPWPhmuteU0IKj8nKbG3DrjiOmLwpnHGYWAVwA69zmTm++YG0Hmwww==", 1421 | "requires": { 1422 | "debug": "2.6.9", 1423 | "depd": "~1.1.2", 1424 | "destroy": "~1.0.4", 1425 | "encodeurl": "~1.0.2", 1426 | "escape-html": "~1.0.3", 1427 | "etag": "~1.8.1", 1428 | "fresh": "0.5.2", 1429 | "http-errors": "1.8.1", 1430 | "mime": "1.6.0", 1431 | "ms": "2.1.3", 1432 | "on-finished": "~2.3.0", 1433 | "range-parser": "~1.2.1", 1434 | "statuses": "~1.5.0" 1435 | }, 1436 | "dependencies": { 1437 | "ms": { 1438 | "version": "2.1.3", 1439 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1440 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1441 | } 1442 | } 1443 | }, 1444 | "serve-static": { 1445 | "version": "1.14.2", 1446 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.2.tgz", 1447 | "integrity": "sha512-+TMNA9AFxUEGuC0z2mevogSnn9MXKb4fa7ngeRMJaaGv8vTwnIEkKi+QGvPt33HSnf8pRS+WGM0EbMtCJLKMBQ==", 1448 | "requires": { 1449 | "encodeurl": "~1.0.2", 1450 | "escape-html": "~1.0.3", 1451 | "parseurl": "~1.3.3", 1452 | "send": "0.17.2" 1453 | } 1454 | }, 1455 | "setprototypeof": { 1456 | "version": "1.2.0", 1457 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1458 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1459 | }, 1460 | "sift": { 1461 | "version": "13.5.2", 1462 | "resolved": "https://registry.npmjs.org/sift/-/sift-13.5.2.tgz", 1463 | "integrity": "sha512-+gxdEOMA2J+AI+fVsCqeNn7Tgx3M9ZN9jdi95939l1IJ8cZsqS8sqpJyOkic2SJk+1+98Uwryt/gL6XDaV+UZA==" 1464 | }, 1465 | "signal-exit": { 1466 | "version": "3.0.7", 1467 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 1468 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==" 1469 | }, 1470 | "smart-buffer": { 1471 | "version": "4.2.0", 1472 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 1473 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==" 1474 | }, 1475 | "socks": { 1476 | "version": "2.6.2", 1477 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.6.2.tgz", 1478 | "integrity": "sha512-zDZhHhZRY9PxRruRMR7kMhnf3I8hDs4S3f9RecfnGxvcBHQcKcIH/oUcEWffsfl1XxdYlA7nnlGbbTvPz9D8gA==", 1479 | "requires": { 1480 | "ip": "^1.1.5", 1481 | "smart-buffer": "^4.2.0" 1482 | } 1483 | }, 1484 | "sparse-bitfield": { 1485 | "version": "3.0.3", 1486 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 1487 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 1488 | "optional": true, 1489 | "requires": { 1490 | "memory-pager": "^1.0.2" 1491 | } 1492 | }, 1493 | "statuses": { 1494 | "version": "1.5.0", 1495 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1496 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 1497 | }, 1498 | "string-width": { 1499 | "version": "4.2.3", 1500 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1501 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1502 | "requires": { 1503 | "emoji-regex": "^8.0.0", 1504 | "is-fullwidth-code-point": "^3.0.0", 1505 | "strip-ansi": "^6.0.1" 1506 | } 1507 | }, 1508 | "strip-ansi": { 1509 | "version": "6.0.1", 1510 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1511 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1512 | "requires": { 1513 | "ansi-regex": "^5.0.1" 1514 | } 1515 | }, 1516 | "strip-json-comments": { 1517 | "version": "2.0.1", 1518 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1519 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 1520 | }, 1521 | "supports-color": { 1522 | "version": "5.5.0", 1523 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1524 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1525 | "requires": { 1526 | "has-flag": "^3.0.0" 1527 | } 1528 | }, 1529 | "to-readable-stream": { 1530 | "version": "1.0.0", 1531 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz", 1532 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==" 1533 | }, 1534 | "to-regex-range": { 1535 | "version": "5.0.1", 1536 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1537 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1538 | "requires": { 1539 | "is-number": "^7.0.0" 1540 | } 1541 | }, 1542 | "toidentifier": { 1543 | "version": "1.0.1", 1544 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1545 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==" 1546 | }, 1547 | "touch": { 1548 | "version": "3.1.0", 1549 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1550 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1551 | "requires": { 1552 | "nopt": "~1.0.10" 1553 | } 1554 | }, 1555 | "tr46": { 1556 | "version": "3.0.0", 1557 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz", 1558 | "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==", 1559 | "requires": { 1560 | "punycode": "^2.1.1" 1561 | } 1562 | }, 1563 | "ts-node": { 1564 | "version": "10.5.0", 1565 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.5.0.tgz", 1566 | "integrity": "sha512-6kEJKwVxAJ35W4akuiysfKwKmjkbYxwQMTBaAxo9KKAx/Yd26mPUyhGz3ji+EsJoAgrLqVsYHNuuYwQe22lbtw==", 1567 | "requires": { 1568 | "@cspotcode/source-map-support": "0.7.0", 1569 | "@tsconfig/node10": "^1.0.7", 1570 | "@tsconfig/node12": "^1.0.7", 1571 | "@tsconfig/node14": "^1.0.0", 1572 | "@tsconfig/node16": "^1.0.2", 1573 | "acorn": "^8.4.1", 1574 | "acorn-walk": "^8.1.1", 1575 | "arg": "^4.1.0", 1576 | "create-require": "^1.1.0", 1577 | "diff": "^4.0.1", 1578 | "make-error": "^1.1.1", 1579 | "v8-compile-cache-lib": "^3.0.0", 1580 | "yn": "3.1.1" 1581 | } 1582 | }, 1583 | "type-fest": { 1584 | "version": "0.20.2", 1585 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1586 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==" 1587 | }, 1588 | "type-is": { 1589 | "version": "1.6.18", 1590 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1591 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1592 | "requires": { 1593 | "media-typer": "0.3.0", 1594 | "mime-types": "~2.1.24" 1595 | } 1596 | }, 1597 | "typedarray-to-buffer": { 1598 | "version": "3.1.5", 1599 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 1600 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 1601 | "requires": { 1602 | "is-typedarray": "^1.0.0" 1603 | } 1604 | }, 1605 | "typescript": { 1606 | "version": "4.5.5", 1607 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.5.5.tgz", 1608 | "integrity": "sha512-TCTIul70LyWe6IJWT8QSYeA54WQe8EjQFU4wY52Fasj5UKx88LNYKCgBEHcOMOrFF1rKGbD8v/xcNWVUq9SymA==", 1609 | "dev": true 1610 | }, 1611 | "undefsafe": { 1612 | "version": "2.0.5", 1613 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 1614 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==" 1615 | }, 1616 | "unique-string": { 1617 | "version": "2.0.0", 1618 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", 1619 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", 1620 | "requires": { 1621 | "crypto-random-string": "^2.0.0" 1622 | } 1623 | }, 1624 | "unpipe": { 1625 | "version": "1.0.0", 1626 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1627 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 1628 | }, 1629 | "update-notifier": { 1630 | "version": "5.1.0", 1631 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-5.1.0.tgz", 1632 | "integrity": "sha512-ItnICHbeMh9GqUy31hFPrD1kcuZ3rpxDZbf4KUDavXwS0bW5m7SLbDQpGX3UYr072cbrF5hFUs3r5tUsPwjfHw==", 1633 | "requires": { 1634 | "boxen": "^5.0.0", 1635 | "chalk": "^4.1.0", 1636 | "configstore": "^5.0.1", 1637 | "has-yarn": "^2.1.0", 1638 | "import-lazy": "^2.1.0", 1639 | "is-ci": "^2.0.0", 1640 | "is-installed-globally": "^0.4.0", 1641 | "is-npm": "^5.0.0", 1642 | "is-yarn-global": "^0.3.0", 1643 | "latest-version": "^5.1.0", 1644 | "pupa": "^2.1.1", 1645 | "semver": "^7.3.4", 1646 | "semver-diff": "^3.1.1", 1647 | "xdg-basedir": "^4.0.0" 1648 | }, 1649 | "dependencies": { 1650 | "semver": { 1651 | "version": "7.3.5", 1652 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 1653 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 1654 | "requires": { 1655 | "lru-cache": "^6.0.0" 1656 | } 1657 | } 1658 | } 1659 | }, 1660 | "url-parse-lax": { 1661 | "version": "3.0.0", 1662 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz", 1663 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=", 1664 | "requires": { 1665 | "prepend-http": "^2.0.0" 1666 | } 1667 | }, 1668 | "utils-merge": { 1669 | "version": "1.0.1", 1670 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1671 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 1672 | }, 1673 | "v8-compile-cache-lib": { 1674 | "version": "3.0.0", 1675 | "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.0.tgz", 1676 | "integrity": "sha512-mpSYqfsFvASnSn5qMiwrr4VKfumbPyONLCOPmsR3A6pTY/r0+tSaVbgPWSAIuzbk3lCTa+FForeTiO+wBQGkjA==" 1677 | }, 1678 | "vary": { 1679 | "version": "1.1.2", 1680 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1681 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 1682 | }, 1683 | "webidl-conversions": { 1684 | "version": "7.0.0", 1685 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 1686 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==" 1687 | }, 1688 | "whatwg-url": { 1689 | "version": "11.0.0", 1690 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz", 1691 | "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==", 1692 | "requires": { 1693 | "tr46": "^3.0.0", 1694 | "webidl-conversions": "^7.0.0" 1695 | } 1696 | }, 1697 | "widest-line": { 1698 | "version": "3.1.0", 1699 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz", 1700 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==", 1701 | "requires": { 1702 | "string-width": "^4.0.0" 1703 | } 1704 | }, 1705 | "wrap-ansi": { 1706 | "version": "7.0.0", 1707 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1708 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1709 | "requires": { 1710 | "ansi-styles": "^4.0.0", 1711 | "string-width": "^4.1.0", 1712 | "strip-ansi": "^6.0.0" 1713 | } 1714 | }, 1715 | "wrappy": { 1716 | "version": "1.0.2", 1717 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1718 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1719 | }, 1720 | "write-file-atomic": { 1721 | "version": "3.0.3", 1722 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 1723 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 1724 | "requires": { 1725 | "imurmurhash": "^0.1.4", 1726 | "is-typedarray": "^1.0.0", 1727 | "signal-exit": "^3.0.2", 1728 | "typedarray-to-buffer": "^3.1.5" 1729 | } 1730 | }, 1731 | "xdg-basedir": { 1732 | "version": "4.0.0", 1733 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", 1734 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==" 1735 | }, 1736 | "yallist": { 1737 | "version": "4.0.0", 1738 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1739 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1740 | }, 1741 | "yn": { 1742 | "version": "3.1.1", 1743 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 1744 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==" 1745 | } 1746 | } 1747 | } 1748 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "desma-api", 3 | "version": "1.0.0", 4 | "description": "The Desma project backend", 5 | "main": "src/server.ts", 6 | "dependencies": { 7 | "bcryptjs": "^2.4.3", 8 | "cors": "^2.8.5", 9 | "dotenv": "^16.0.0", 10 | "express": "^4.17.2", 11 | "jsonwebtoken": "^8.5.1", 12 | "lodash": "^4.17.21", 13 | "mongoose": "^6.2.1", 14 | "mongoose-referrence-validator": "^1.0.0", 15 | "nodemon": "^2.0.15", 16 | "ts-node": "^10.5.0" 17 | }, 18 | "devDependencies": { 19 | "@types/bcryptjs": "^2.4.2", 20 | "@types/cors": "^2.8.12", 21 | "@types/express": "^4.17.13", 22 | "@types/jsonwebtoken": "^8.5.8", 23 | "@types/lodash": "^4.14.179", 24 | "typescript": "^4.5.5" 25 | }, 26 | "scripts": { 27 | "serve": "nodemon", 28 | "build": "npm install && tsc", 29 | "start": "node dist/server.js", 30 | "test": "echo \"Error: no test specified\" && exit 1" 31 | }, 32 | "repository": { 33 | "type": "git", 34 | "url": "git+https://github.com/Kosmos-Community/desma-api.git" 35 | }, 36 | "author": "", 37 | "license": "ISC", 38 | "bugs": { 39 | "url": "https://github.com/Kosmos-Community/desma-api/issues" 40 | }, 41 | "homepage": "https://github.com/Kosmos-Community/desma-api#readme" 42 | } 43 | -------------------------------------------------------------------------------- /src/config/db.ts: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | 3 | export const connectDB = async () => { 4 | try { 5 | const conn = await mongoose.connect(process.env.MONGO_URI!); 6 | console.log(`MongoDB Connected to: ${conn.connection.host}`); 7 | } catch (err: any) { 8 | console.error(`Error: ${err.message}`); 9 | process.exit(1); 10 | } 11 | }; 12 | -------------------------------------------------------------------------------- /src/controllers/colorController.ts: -------------------------------------------------------------------------------- 1 | import { Request, Response, NextFunction } from 'express'; 2 | import { insertManyColors, deleteManyColors } from '../utils/colorFunctions'; 3 | 4 | export const createColors = async ( 5 | req: Request, 6 | res: Response, 7 | next: NextFunction 8 | ) => { 9 | try { 10 | const data = req.body; 11 | const colors = await insertManyColors(data); 12 | res.status(200).json(colors); 13 | } catch (error) { 14 | next(error); 15 | } 16 | }; 17 | 18 | export const deleteColors = async ( 19 | req: Request, 20 | res: Response, 21 | next: NextFunction 22 | ) => { 23 | try { 24 | const { ids } = req.body; 25 | const deletedColors = await deleteManyColors(ids); 26 | res.status(200).json(deletedColors); 27 | } catch (error) { 28 | next(error); 29 | } 30 | }; 31 | -------------------------------------------------------------------------------- /src/controllers/designSystemController.ts: -------------------------------------------------------------------------------- 1 | import { NextFunction, Request, Response } from 'express'; 2 | import mongoose from 'mongoose'; 3 | import { DesignSystem } from '../models/designSystemModel'; 4 | 5 | export const getUserDesignSystems = async ( 6 | req: Request, 7 | res: Response, 8 | next: NextFunction 9 | ) => { 10 | try { 11 | const { id: userId } = req.params; 12 | const designSystems = await DesignSystem.find({ userId: userId }); 13 | 14 | if (designSystems.length < 1) { 15 | return res.status(200).json({ message: 'No design systems found' }); 16 | } 17 | 18 | res.status(200).json({ data: designSystems }); 19 | } catch (error) { 20 | if (error instanceof mongoose.Error.CastError) { 21 | return res.status(400).json({ message: 'Invalid fonts id syntax' }); 22 | } 23 | next(error); 24 | } 25 | }; 26 | 27 | export const getDesignSystems = async ( 28 | req: Request, 29 | res: Response, 30 | next: NextFunction 31 | ) => { 32 | try { 33 | const designSystems = await DesignSystem.find( 34 | { isPublic: true }, 35 | { 36 | _id: true, 37 | name: true, 38 | paletteId: true, 39 | fontsId: true, 40 | spacingsId: true, 41 | } 42 | ); 43 | 44 | if (designSystems.length < 1) { 45 | return res.status(200).json({ message: 'No design systems found' }); 46 | } 47 | 48 | res.status(200).json({ data: designSystems }); 49 | } catch (error) { 50 | next(error); 51 | } 52 | }; 53 | 54 | export const getDesignSystemById = async ( 55 | req: Request, 56 | res: Response, 57 | next: NextFunction 58 | ) => { 59 | try { 60 | const { id } = req.params; 61 | const designSystem = await DesignSystem.findById(id); 62 | if (!designSystem) { 63 | return res.status(404).json({ message: 'No design system found' }); 64 | } 65 | res.status(200).json({ data: designSystem }); 66 | } catch (error) { 67 | if (error instanceof mongoose.Error.CastError) { 68 | return res 69 | .status(400) 70 | .json({ message: 'Invalid design system id syntax' }); 71 | } 72 | next(error); 73 | } 74 | }; 75 | 76 | export const createDesignSystem = async ( 77 | req: Request, 78 | res: Response, 79 | next: NextFunction 80 | ) => { 81 | try { 82 | const { userId, name, paletteId, fontsId, spacingsId, isPublic } = req.body; 83 | 84 | const designSystem = await DesignSystem.create({ 85 | userId: userId, 86 | name: name, 87 | paletteId: paletteId, 88 | fontsId: fontsId, 89 | spacingsId: spacingsId, 90 | isPublic: isPublic, 91 | }); 92 | 93 | if (!designSystem) { 94 | return res.status(400).json({ message: 'Invalid design system data' }); 95 | } 96 | res.status(201).json({ 97 | message: 'Design system created successfully', 98 | data: designSystem, 99 | }); 100 | } catch (error) { 101 | if (error instanceof mongoose.Error.ValidationError) { 102 | return res.status(400).json({ message: error.message }); 103 | } 104 | next(error); 105 | } 106 | }; 107 | 108 | export const updateDesignSystem = async ( 109 | req: Request, 110 | res: Response, 111 | next: NextFunction 112 | ) => { 113 | try { 114 | const { id } = req.params; 115 | const { name, isPublic } = req.body; 116 | 117 | const updatedDesignSystem = await DesignSystem.findByIdAndUpdate( 118 | id, 119 | { 120 | name: name, 121 | isPublic: isPublic, 122 | }, 123 | { new: true } 124 | ); 125 | if (!updatedDesignSystem) { 126 | return res.status(200).json({ message: 'Design system not found' }); 127 | } 128 | res.status(200).json({ 129 | message: 'Design system updated successfully', 130 | data: updatedDesignSystem, 131 | }); 132 | } catch (error) { 133 | if (error instanceof mongoose.Error.CastError) { 134 | return res 135 | .status(400) 136 | .json({ message: 'Invalid design system id or fields syntax' }); 137 | } 138 | if (error instanceof mongoose.Error.ValidationError) { 139 | return res.status(400).json({ message: error.message }); 140 | } 141 | next(error); 142 | } 143 | }; 144 | 145 | export const deleteDesignSystem = async ( 146 | req: Request, 147 | res: Response, 148 | next: NextFunction 149 | ) => { 150 | try { 151 | const { id } = req.params; 152 | const deletedDesignSystem = await DesignSystem.deleteOne({ _id: id }); 153 | if (deletedDesignSystem.deletedCount < 1) { 154 | return res.status(200).json({ message: 'Design system not found' }); 155 | } 156 | res.status(200).json({ 157 | message: 'Design system deleted successfully', 158 | data: deletedDesignSystem, 159 | }); 160 | } catch (error) { 161 | if (error instanceof mongoose.Error.CastError) { 162 | return res.status(400).json({ 163 | message: 'Invalid design system id syntax or fonts not found', 164 | }); 165 | } 166 | if (error instanceof mongoose.Error.ValidationError) { 167 | return res.status(400).json({ message: error.message }); 168 | } 169 | next(error); 170 | } 171 | }; 172 | -------------------------------------------------------------------------------- /src/controllers/fontsController.ts: -------------------------------------------------------------------------------- 1 | import { NextFunction, Request, Response } from 'express'; 2 | import mongoose from 'mongoose'; 3 | import { Fonts } from '../models/fontsModel'; 4 | 5 | export const getFonts = async ( 6 | req: Request, 7 | res: Response, 8 | next: NextFunction 9 | ) => { 10 | try { 11 | const { id } = req.params; 12 | const fonts = await Fonts.findById(id); 13 | 14 | if (!fonts) { 15 | return res.status(404).json({ message: 'No fonts found' }); 16 | } 17 | 18 | res.status(200).json({ data: fonts }); 19 | } catch (error) { 20 | if (error instanceof mongoose.Error.CastError) { 21 | return res.status(400).json({ message: 'Invalid fonts id syntax' }); 22 | } 23 | next(error); 24 | } 25 | }; 26 | 27 | export const createFonts = async ( 28 | req: Request, 29 | res: Response, 30 | next: NextFunction 31 | ) => { 32 | try { 33 | const { headingFontName, parragraphFontName, baseSize, scaleFactor } = 34 | req.body; 35 | 36 | const fonts = await Fonts.create({ 37 | headingFontName: headingFontName, 38 | parragraphFontName: parragraphFontName, 39 | baseSize: baseSize, 40 | scaleFactor: scaleFactor, 41 | }); 42 | 43 | if (!fonts) { 44 | return res.status(400).json({ message: 'Invalid fonts data' }); 45 | } 46 | 47 | res 48 | .status(201) 49 | .json({ message: 'Fonts created successfully', data: fonts }); 50 | } catch (error) { 51 | if (error instanceof mongoose.Error.ValidationError) { 52 | return res.status(400).json({ message: error.message }); 53 | } 54 | next(error); 55 | } 56 | }; 57 | 58 | export const updateFonts = async ( 59 | req: Request, 60 | res: Response, 61 | next: NextFunction 62 | ) => { 63 | try { 64 | const { id } = req.params; 65 | const { headingFontName, parragraphFontName, baseSize, scaleFactor } = 66 | req.body; 67 | 68 | const updatedFonts = await Fonts.findByIdAndUpdate( 69 | id, 70 | { 71 | headingFontName: headingFontName, 72 | parragraphFontName: parragraphFontName, 73 | baseSize: baseSize, 74 | scaleFactor: scaleFactor, 75 | }, 76 | { new: true } 77 | ); 78 | 79 | if (!updatedFonts) { 80 | return res.status(404).json({ message: 'Fonts not found' }); 81 | } 82 | 83 | res 84 | .status(200) 85 | .json({ message: 'Fonts updated successfully', data: updatedFonts }); 86 | } catch (error) { 87 | if (error instanceof mongoose.Error.CastError) { 88 | return res 89 | .status(400) 90 | .json({ message: 'Invalid fonts id or fields syntax' }); 91 | } 92 | if (error instanceof mongoose.Error.ValidationError) { 93 | return res.status(400).json({ message: error.message }); 94 | } 95 | next(error); 96 | } 97 | }; 98 | 99 | export const deleteFonts = async ( 100 | req: Request, 101 | res: Response, 102 | next: NextFunction 103 | ) => { 104 | try { 105 | const { id } = req.params; 106 | 107 | const deletedFonts = await Fonts.deleteOne({ _id: id }); 108 | 109 | if (deletedFonts.deletedCount < 1) { 110 | return res.status(404).json({ message: 'Fonts not found' }); 111 | } 112 | 113 | res 114 | .status(200) 115 | .json({ message: 'Fonts deleted successfully', data: deletedFonts }); 116 | } catch (error) { 117 | if (error instanceof mongoose.Error.CastError) { 118 | return res 119 | .status(400) 120 | .json({ message: 'Invalid fonts id syntax or fonts not found' }); 121 | } 122 | if (error instanceof mongoose.Error.ValidationError) { 123 | return res.status(400).json({ message: error.message }); 124 | } 125 | next(error); 126 | } 127 | }; 128 | -------------------------------------------------------------------------------- /src/controllers/paletteController.ts: -------------------------------------------------------------------------------- 1 | import { Request, Response, NextFunction } from 'express'; 2 | import mongoose, { mongo } from 'mongoose'; 3 | import { Palette } from '../models/paletteModel'; 4 | import _ from 'lodash'; 5 | import { 6 | deleteManyColors, 7 | insertManyColors, 8 | bulkUpdateColors, 9 | } from '../utils/colorFunctions'; 10 | 11 | export const createPalette = async ( 12 | req: Request, 13 | res: Response, 14 | next: NextFunction 15 | ) => { 16 | try { 17 | const request = req.body; 18 | const individualColors = []; 19 | 20 | // prepare data for insert colors in color collection 21 | for (let field in request) { 22 | for (let color in request[field]) { 23 | individualColors.push({ 24 | type: field, 25 | hexCode: request[field][color].hexCode, 26 | }); 27 | } 28 | } 29 | 30 | const colorsInserted = await insertManyColors(individualColors); // insert at Color collection 31 | 32 | const paletteInsert: Record = {}; // create ids array per field 33 | let type: string = ''; 34 | for (let color in colorsInserted) { 35 | type = colorsInserted[color].type; 36 | paletteInsert[type] 37 | ? paletteInsert[type].push(colorsInserted[color]._id) 38 | : (paletteInsert[type] = [colorsInserted[color]._id]); 39 | } 40 | 41 | const paletteData = await Palette.create(paletteInsert); // insert at Color collection 42 | 43 | res.status(201).json(paletteData); 44 | } catch (error) { 45 | if (error instanceof mongoose.Error.CastError) { 46 | return res.status(400).json({ message: 'Invalid fields syntax' }); 47 | } 48 | if (error instanceof mongoose.Error.ValidationError) { 49 | return res.status(400).json({ message: error.message }); 50 | } 51 | next(error); 52 | } 53 | }; 54 | 55 | export const getPalette = async ( 56 | req: Request, 57 | res: Response, 58 | next: NextFunction 59 | ) => { 60 | try { 61 | const { id: paletteId } = req.params; 62 | await Palette.findOne( 63 | { _id: paletteId }, 64 | { createdAt: false, updatedAt: false, __v: false } 65 | ) 66 | .populate([ 67 | { path: 'primaryColor', select: '_id hexCode' }, 68 | { path: 'secondaryColor', select: '_id hexCode' }, 69 | { path: 'textColor', select: '_id hexCode' }, 70 | { path: 'backgroundColors', select: '_id hexCode' }, 71 | { path: 'extraColors', select: '_id hexCode' }, 72 | ]) 73 | .then((palette) => { 74 | res.status(200).json({ ...palette._doc }); 75 | }); 76 | } catch (error) { 77 | if (error instanceof mongoose.Error.CastError) { 78 | return res.status(400).json({ message: 'Invalid fields syntax' }); 79 | } 80 | if (error instanceof mongoose.Error.ValidationError) { 81 | return res.status(400).json({ message: error.message }); 82 | } 83 | next(error); 84 | } 85 | }; 86 | 87 | export const updatePalette = async ( 88 | req: Request, 89 | res: Response, 90 | next: NextFunction 91 | ) => { 92 | try { 93 | const { id: paletteId } = req.params; 94 | const request = req.body; 95 | const colorOpts = []; 96 | const paletteUpdate: Record = {}; 97 | let colorId: string | object; 98 | 99 | delete request._id; 100 | const palette = await Palette.findOne( 101 | { _id: paletteId }, 102 | { _id: false, createdAt: false, updatedAt: false, __v: false } 103 | ); 104 | 105 | if (!palette) 106 | return res 107 | .status(404) 108 | .json({ message: `No palette with id : ${paletteId}` }); 109 | 110 | // Prepare data to insert colors 111 | for (let field in request) { 112 | for (let color in request[field]) { 113 | // Data to update color 114 | colorId = request[field][color]._id || new mongoose.Types.ObjectId(); 115 | colorOpts.push({ 116 | updateOne: { 117 | filter: { _id: colorId }, 118 | update: { 119 | $set: { 120 | type: field, 121 | hexCode: request[field][color].hexCode, 122 | }, 123 | }, 124 | upsert: true, 125 | }, 126 | }); 127 | colorOpts.push({ 128 | updateOne: { 129 | filter: { _id: paletteId }, 130 | update: { 131 | $pullAll: {}, 132 | }, 133 | }, 134 | }); 135 | // Data to update palette 136 | paletteUpdate[field] 137 | ? paletteUpdate[field].push(colorId) 138 | : (paletteUpdate[field] = [colorId]); 139 | } 140 | } 141 | 142 | Object.keys(palette._doc).map((field) => { 143 | !paletteUpdate[field] && (paletteUpdate[field] = []); 144 | palette._doc[field] = palette._doc[field].map((color: any) => 145 | color.toString() 146 | ); 147 | }); 148 | 149 | await bulkUpdateColors(colorOpts); // Update and upsert colors 150 | 151 | const updatedPalette = await Palette.updateOne( 152 | { _id: paletteId }, 153 | paletteUpdate 154 | ); // Update palette 155 | 156 | res.status(200).json(updatedPalette); 157 | } catch (error) { 158 | if (error instanceof mongoose.Error.CastError) { 159 | return res.status(400).json({ message: 'Invalid fields syntax' }); 160 | } 161 | if (error instanceof mongoose.Error.ValidationError) { 162 | return res.status(400).json({ message: error.message }); 163 | } 164 | next(error); 165 | } 166 | }; 167 | 168 | export const deletePalette = async ( 169 | req: Request, 170 | res: Response, 171 | next: NextFunction 172 | ) => { 173 | try { 174 | const { id: paletteId } = req.params; 175 | const request = req.body; 176 | let response: string | object; 177 | 178 | let palette = await Palette.findOne( 179 | { _id: paletteId }, 180 | { 181 | _id: true, 182 | primaryColor: true, 183 | secondaryColor: true, 184 | textColor: true, 185 | backgroundColors: true, 186 | extraColors: true, 187 | } 188 | ); 189 | 190 | if (!palette) 191 | return res 192 | .status(404) 193 | .json({ message: `No palette with id : ${paletteId}` }); 194 | 195 | const paletteData = palette._doc; 196 | const ids = []; 197 | 198 | // delete complete palette 199 | await palette.remove(); 200 | 201 | for (let field in paletteData) ids.push(...paletteData[field]); 202 | response = `Palette with id : ${paletteId} successfully removed`; 203 | await deleteManyColors(ids); // delete of color 204 | 205 | res.status(200).json({ msg: response }); 206 | } catch (error) { 207 | if (error instanceof mongoose.Error.CastError) { 208 | return res.status(400).json({ message: 'Invalid fields syntax' }); 209 | } 210 | if (error instanceof mongoose.Error.ValidationError) { 211 | return res.status(400).json({ message: error.message }); 212 | } 213 | next(error); 214 | } 215 | }; 216 | 217 | function missing(array1: any[], array2: any[]) { 218 | const copy = array1.slice(); 219 | return array2.some((element) => { 220 | const index = copy.indexOf(element); 221 | if (index >= 0) copy.splice(index, 1); 222 | return index < 0; 223 | }); 224 | } 225 | -------------------------------------------------------------------------------- /src/controllers/spacingsController.ts: -------------------------------------------------------------------------------- 1 | import { NextFunction, Request, Response } from 'express'; 2 | import mongoose from 'mongoose'; 3 | import { Spacings } from '../models/spacingsModel'; 4 | 5 | export const getSpacings = async ( 6 | req: Request, 7 | res: Response, 8 | next: NextFunction 9 | ) => { 10 | try { 11 | const { id } = req.params; 12 | const spacings = await Spacings.findById(id); 13 | 14 | if (!spacings) { 15 | return res.status(404).json({ message: 'No spacings found' }); 16 | } 17 | 18 | res.status(200).json({ data: spacings }); 19 | } catch (error) { 20 | if (error instanceof mongoose.Error.CastError) { 21 | return res.status(400).json({ message: 'Invalid spacings id syntax' }); 22 | } 23 | next(error); 24 | } 25 | }; 26 | 27 | export const createSpacings = async ( 28 | req: Request, 29 | res: Response, 30 | next: NextFunction 31 | ) => { 32 | try { 33 | const { baseSize, scaleFactor } = req.body; 34 | 35 | const spacings = await Spacings.create({ 36 | baseSize: baseSize, 37 | scaleFactor: scaleFactor, 38 | }); 39 | 40 | if (!spacings) { 41 | return res.status(400).json({ message: 'Invalid spacings data' }); 42 | } 43 | 44 | res 45 | .status(201) 46 | .json({ message: 'Spacings created successfully', data: spacings }); 47 | } catch (error) { 48 | if (error instanceof mongoose.Error.ValidationError) { 49 | return res.status(400).json({ message: error.message }); 50 | } 51 | next(error); 52 | } 53 | }; 54 | 55 | export const updateSpacings = async ( 56 | req: Request, 57 | res: Response, 58 | next: NextFunction 59 | ) => { 60 | try { 61 | const { id } = req.params; 62 | const { baseSize, scaleFactor } = req.body; 63 | 64 | const updatedSpacings = await Spacings.findByIdAndUpdate( 65 | id, 66 | { 67 | baseSize: baseSize, 68 | scaleFactor: scaleFactor, 69 | }, 70 | { new: true } 71 | ); 72 | 73 | if (!updatedSpacings) { 74 | return res.status(404).json({ message: 'Spacings not found' }); 75 | } 76 | 77 | res.status(200).json({ 78 | message: 'Spacings updated successfully', 79 | data: updatedSpacings, 80 | }); 81 | } catch (error) { 82 | if (error instanceof mongoose.Error.CastError) { 83 | console.log(error); 84 | return res 85 | .status(400) 86 | .json({ message: 'Invalid spacings id or fields syntax' }); 87 | } 88 | if (error instanceof mongoose.Error.ValidationError) { 89 | return res.status(400).json({ message: error.message }); 90 | } 91 | next(error); 92 | } 93 | }; 94 | 95 | export const deleteSpacings = async ( 96 | req: Request, 97 | res: Response, 98 | next: NextFunction 99 | ) => { 100 | try { 101 | const { id } = req.params; 102 | 103 | const deletedSpacings = await Spacings.deleteOne({ _id: id }); 104 | 105 | if (deletedSpacings.deletedCount < 1) { 106 | return res.status(404).json({ message: 'Spacings not found' }); 107 | } 108 | 109 | res.status(200).json({ 110 | message: 'Spacings deleted successfully', 111 | data: deletedSpacings, 112 | }); 113 | } catch (error) { 114 | if (error instanceof mongoose.Error.CastError) { 115 | return res 116 | .status(400) 117 | .json({ message: 'Invalid spacings id syntax or spacings not found' }); 118 | } 119 | if (error instanceof mongoose.Error.ValidationError) { 120 | return res.status(400).json({ message: error.message }); 121 | } 122 | next(error); 123 | } 124 | }; 125 | -------------------------------------------------------------------------------- /src/controllers/userController.ts: -------------------------------------------------------------------------------- 1 | import { NextFunction, Request, Response } from 'express'; 2 | import mongoose from 'mongoose'; 3 | import { User } from '../models/userModel'; 4 | import { generateToken } from '../utils/generateToken'; 5 | 6 | export const authUser = async (req: Request, res: Response) => { 7 | const { email, password } = req.body; 8 | 9 | if (!email || !password) { 10 | return res 11 | .status(400) 12 | .json({ message: 'Some user data fields are missing' }); 13 | } 14 | 15 | const user = await User.findOne({ email }); 16 | 17 | if (user && (await user.matchPassword(password))) { 18 | res.status(200).json({ 19 | _id: user._id, 20 | name: user.name, 21 | email: user.email, 22 | token: generateToken(user._id), 23 | }); 24 | } else { 25 | res.status(400).json({ message: 'Invalid email or password' }); 26 | } 27 | }; 28 | 29 | export const registerUser = async ( 30 | req: Request, 31 | res: Response, 32 | next: NextFunction 33 | ) => { 34 | const { name, email, password } = req.body; 35 | 36 | const userExists = await User.findOne({ email }); 37 | 38 | if (userExists) { 39 | return res.status(400).json({ 40 | message: 'The email is already associated with a Desma account', 41 | }); 42 | } 43 | 44 | try { 45 | const user = await User.create({ name, email, password }); 46 | 47 | res.status(201).json({ 48 | _id: user._id, 49 | name: user.name, 50 | email: user.email, 51 | token: generateToken(user._id), 52 | }); 53 | } catch (error) { 54 | if (error instanceof mongoose.Error.ValidationError) { 55 | return res.status(400).json({ message: error.message }); 56 | } 57 | next(error); 58 | } 59 | }; 60 | -------------------------------------------------------------------------------- /src/middleware/authMiddleware.ts: -------------------------------------------------------------------------------- 1 | import { NextFunction, Request, Response } from 'express'; 2 | import jwt from 'jsonwebtoken'; 3 | import { User } from '../models/userModel'; 4 | 5 | export const protect = async (req: any, res: Response, next: NextFunction) => { 6 | let token; 7 | 8 | if ( 9 | req.headers.authorization && 10 | req.headers.authorization.startsWith('Bearer') 11 | ) { 12 | try { 13 | token = req.headers.authorization.split(' ')[1]; 14 | const decoded: any = jwt.verify(token, process.env.JWT_SECRET!); 15 | 16 | req.user = await User.findById(decoded.id); 17 | 18 | next(); 19 | } catch (err) { 20 | return res.status(401).json({ message: 'Not authorized, token failed' }); 21 | } 22 | } 23 | 24 | if (!token) { 25 | res.status(401).json({ message: 'Not authorized, no token' }); 26 | } 27 | }; 28 | -------------------------------------------------------------------------------- /src/middleware/errorMiddleware.ts: -------------------------------------------------------------------------------- 1 | import { NextFunction, Request, Response } from 'express'; 2 | 3 | export const notFound = (req: Request, res: Response) => { 4 | res.status(404); 5 | throw new Error(`Route not found - ${req.originalUrl}`); 6 | }; 7 | 8 | export const errorHandler = ( 9 | err: Error, 10 | req: Request, 11 | res: Response, 12 | next: NextFunction 13 | ) => { 14 | const statusCode = res.statusCode === 200 ? 500 : res.statusCode; 15 | res.status(statusCode).json({ 16 | message: err.message, 17 | stack: process.env.NODE_ENV === 'production' ? null : err.stack, 18 | }); 19 | }; 20 | -------------------------------------------------------------------------------- /src/middleware/validateMiddleware.ts: -------------------------------------------------------------------------------- 1 | import { NextFunction, Request, Response } from 'express'; 2 | 3 | export const validateRequest = (requestParams: any[]) => { 4 | return (req: Request, res: Response, next: NextFunction) => { 5 | for (let param of requestParams) { 6 | if (checkParamPresent(Object.keys(req.body), param)) { 7 | let reqParam:any = req.body[param.param_key]; 8 | if (!checkParamType(reqParam, param)) { 9 | return res.status(400).json({ 10 | result: `${param.param_key} is of type ` + 11 | `${typeof reqParam} but should be ${param.type}` 12 | }); 13 | } else { 14 | if (!runValidators(reqParam, param)) { 15 | return res.status(400).json({ 16 | result: `Validation failed for ${param.param_key}` 17 | }); 18 | } 19 | } 20 | } else if (param.required){ 21 | return res.status(400).json({ 22 | result: `Missing Parameter ${param.param_key}` 23 | }); 24 | } 25 | } 26 | next(); 27 | } 28 | }; 29 | 30 | const checkParamPresent = (reqParams: any, paramObj: any) => { 31 | return (reqParams.includes(paramObj.param_key)); 32 | }; 33 | 34 | const checkParamType = (reqParam: any, paramObj: any) => { 35 | const reqParamType = typeof reqParam; 36 | return reqParamType === paramObj.type; 37 | }; 38 | 39 | const runValidators = (reqParam: any, paramObj: any) => { 40 | if (paramObj.hasOwnProperty('validator_functions')) 41 | for (let validator of paramObj.validator_functions) 42 | if (!validator(reqParam)) 43 | return false 44 | return true; 45 | }; 46 | -------------------------------------------------------------------------------- /src/models/colorModel.ts: -------------------------------------------------------------------------------- 1 | import mongoose from 'mongoose'; 2 | 3 | const colorSchema = new mongoose.Schema( 4 | { 5 | type: {type: String, required: true}, 6 | hexCode: { type: String, required: true } 7 | }, 8 | { 9 | timestamps: true, 10 | } 11 | ); 12 | 13 | export const Color = mongoose.model('Color', colorSchema); -------------------------------------------------------------------------------- /src/models/designSystemModel.ts: -------------------------------------------------------------------------------- 1 | import mongoose from 'mongoose'; 2 | const referrenceValidator = require('mongoose-referrence-validator'); 3 | 4 | const designSystemSchema = new mongoose.Schema( 5 | { 6 | userId: { 7 | type: mongoose.Schema.Types.ObjectId, 8 | ref: 'User', 9 | required: true, 10 | }, 11 | name: { type: String, required: true }, 12 | paletteId: { 13 | type: mongoose.Schema.Types.ObjectId, 14 | ref: 'Palette', 15 | required: true, 16 | }, 17 | fontsId: { 18 | type: mongoose.Schema.Types.ObjectId, 19 | ref: 'Fonts', 20 | required: true, 21 | }, 22 | spacingsId: { 23 | type: mongoose.Schema.Types.ObjectId, 24 | ref: 'Spacings', 25 | required: true, 26 | }, 27 | isPublic: { type: Boolean, required: true }, 28 | }, 29 | { 30 | timestamps: true, 31 | } 32 | ); 33 | 34 | designSystemSchema.plugin(referrenceValidator); 35 | 36 | export const DesignSystem = mongoose.model('DesignSystem', designSystemSchema); 37 | -------------------------------------------------------------------------------- /src/models/fontsModel.ts: -------------------------------------------------------------------------------- 1 | import mongoose from 'mongoose'; 2 | 3 | const fontsSchema = new mongoose.Schema( 4 | { 5 | headingFontName: { type: String, required: true }, 6 | parragraphFontName: { type: String, required: true }, 7 | baseSize: { type: Number, required: true }, 8 | scaleFactor: { type: String, required: true }, 9 | }, 10 | { 11 | timestamps: true, 12 | } 13 | ); 14 | 15 | export const Fonts = mongoose.model('Fonts', fontsSchema); 16 | -------------------------------------------------------------------------------- /src/models/paletteModel.ts: -------------------------------------------------------------------------------- 1 | import mongoose from 'mongoose'; 2 | 3 | 4 | const paletteSchema = new mongoose.Schema( 5 | { 6 | primaryColor: [{ 7 | type: mongoose.Schema.Types.ObjectId, 8 | ref: 'Color' 9 | }], 10 | secondaryColor: [{ 11 | type: mongoose.Schema.Types.ObjectId, 12 | ref: 'Color' 13 | }], 14 | textColor: [{ 15 | type: mongoose.Schema.Types.ObjectId, 16 | ref: 'Color' 17 | }], 18 | backgroundColors: [{ 19 | type: mongoose.Schema.Types.ObjectId, 20 | ref: 'Color' 21 | }], 22 | extraColors: [{ 23 | type: mongoose.Schema.Types.ObjectId, 24 | ref: 'Color' 25 | }], 26 | }, 27 | { 28 | timestamps: true 29 | } 30 | ); 31 | 32 | export const Palette = mongoose.model('Palette', paletteSchema); -------------------------------------------------------------------------------- /src/models/spacingsModel.ts: -------------------------------------------------------------------------------- 1 | import mongoose from 'mongoose'; 2 | 3 | const spacingsSchema = new mongoose.Schema( 4 | { 5 | baseSize: { type: Number, required: true }, 6 | scaleFactor: { type: String, required: true }, 7 | }, 8 | { 9 | timestamps: true, 10 | } 11 | ); 12 | 13 | export const Spacings = mongoose.model('Spacings', spacingsSchema); 14 | -------------------------------------------------------------------------------- /src/models/userModel.ts: -------------------------------------------------------------------------------- 1 | import mongoose from 'mongoose'; 2 | import bcrypt from 'bcryptjs'; 3 | 4 | const userSchema = new mongoose.Schema( 5 | { 6 | name: { type: String, required: true }, 7 | email: { 8 | type: String, 9 | required: true, 10 | lowercase: true, 11 | unique: true, 12 | match: [ 13 | /^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w{2,3})+$/, 14 | 'Invalid email syntax', 15 | ], 16 | }, 17 | password: { type: String, required: true }, 18 | }, 19 | { 20 | timestamps: true, 21 | } 22 | ); 23 | 24 | userSchema.methods.matchPassword = async function (enteredPassword: string) { 25 | return await bcrypt.compare(enteredPassword, this.password); 26 | }; 27 | 28 | userSchema.pre('save', async function (next) { 29 | if (!this.isModified('password')) { 30 | next(); 31 | } 32 | 33 | const salt = await bcrypt.genSalt(10); 34 | this.password = await bcrypt.hash(this.password, salt); 35 | }); 36 | 37 | export const User = mongoose.model('User', userSchema); 38 | -------------------------------------------------------------------------------- /src/routes/colorRoutes.ts: -------------------------------------------------------------------------------- 1 | import express, { Router } from 'express'; 2 | import { protect } from '../middleware/authMiddleware'; 3 | import { 4 | createColors, 5 | deleteColors 6 | } from '../controllers/colorController'; 7 | 8 | const router: Router = express.Router(); 9 | 10 | router 11 | .route('/') 12 | .post(protect, createColors) 13 | router 14 | .route('/:id') 15 | .delete(protect, deleteColors); 16 | 17 | export { router as colorRoutes }; 18 | -------------------------------------------------------------------------------- /src/routes/designSystemRoutes.ts: -------------------------------------------------------------------------------- 1 | import express, { Router } from 'express'; 2 | import { 3 | getUserDesignSystems, 4 | getDesignSystems, 5 | getDesignSystemById, 6 | createDesignSystem, 7 | updateDesignSystem, 8 | deleteDesignSystem, 9 | } from '../controllers/designSystemController'; 10 | import { protect } from '../middleware/authMiddleware'; 11 | 12 | const router: Router = express.Router(); 13 | 14 | router 15 | .route('/:id') 16 | .get(protect, getDesignSystemById) 17 | .put(protect, updateDesignSystem) 18 | .delete(protect, deleteDesignSystem); 19 | router.get('/users/:id', protect, getUserDesignSystems); 20 | router.post('/', protect, createDesignSystem); 21 | router.get('/', protect, getDesignSystems); 22 | 23 | export { router as designSystemRoutes }; 24 | -------------------------------------------------------------------------------- /src/routes/fontsRoutes.ts: -------------------------------------------------------------------------------- 1 | import express, { Router } from 'express'; 2 | import { 3 | getFonts, 4 | createFonts, 5 | updateFonts, 6 | deleteFonts, 7 | } from '../controllers/fontsController'; 8 | import { protect } from '../middleware/authMiddleware'; 9 | 10 | const router: Router = express.Router(); 11 | 12 | router 13 | .route('/:id') 14 | .get(protect, getFonts) 15 | .put(protect, updateFonts) 16 | .delete(protect, deleteFonts); 17 | router.post('/', protect, createFonts); 18 | 19 | export { router as fontsRoutes }; 20 | -------------------------------------------------------------------------------- /src/routes/paletteRoutes.ts: -------------------------------------------------------------------------------- 1 | import express, { Router } from 'express'; 2 | import { protect } from '../middleware/authMiddleware'; 3 | import { validateRequest } from '../middleware/validateMiddleware'; 4 | import { 5 | createPalette, 6 | getPalette, 7 | updatePalette, 8 | deletePalette 9 | } from '../controllers/paletteController'; 10 | 11 | const router: Router = express.Router(); 12 | 13 | router 14 | .route('/') 15 | .post(protect, validateRequest([ 16 | { param_key: 'primaryColor', required: true, type: 'object' }, 17 | { param_key: 'secondaryColor', required: true, type: 'object' }, 18 | { param_key: 'textColor', required: true, type: 'object' }, 19 | { param_key: 'backgroundColors', required: true, type: 'object' }, 20 | { param_key: 'extraColors', required: true, type: 'object' }, 21 | ]), createPalette); 22 | router 23 | .route('/:id') 24 | .get(protect, getPalette) 25 | .patch(protect, validateRequest([ 26 | { param_key: 'primaryColor', required: false, type: 'object' }, 27 | { param_key: 'secondaryColor', required: false, type: 'object' }, 28 | { param_key: 'textColor', required: false, type: 'object' }, 29 | { param_key: 'backgroundColors', required: false, type: 'object' }, 30 | { param_key: 'extraColors', required: false, type: 'object' }, 31 | ]), updatePalette) 32 | .delete(protect, deletePalette); 33 | 34 | export { router as paletteRoutes }; 35 | -------------------------------------------------------------------------------- /src/routes/spacingsRoutes.ts: -------------------------------------------------------------------------------- 1 | import express, { Router } from 'express'; 2 | import { 3 | getSpacings, 4 | createSpacings, 5 | updateSpacings, 6 | deleteSpacings, 7 | } from '../controllers/spacingsController'; 8 | import { protect } from '../middleware/authMiddleware'; 9 | 10 | const router: Router = express.Router(); 11 | 12 | router 13 | .route('/:id') 14 | .get(protect, getSpacings) 15 | .put(protect, updateSpacings) 16 | .delete(protect, deleteSpacings); 17 | router.post('/', protect, createSpacings); 18 | 19 | export { router as spacingsRoutes }; 20 | -------------------------------------------------------------------------------- /src/routes/userRoutes.ts: -------------------------------------------------------------------------------- 1 | import express, { Router } from 'express'; 2 | import { authUser, registerUser } from '../controllers/userController'; 3 | 4 | const router: Router = express.Router(); 5 | 6 | router.route('/').post(registerUser); 7 | router.post('/login', authUser); 8 | 9 | export { router as userRoutes }; 10 | -------------------------------------------------------------------------------- /src/server.ts: -------------------------------------------------------------------------------- 1 | import express, { Application, Request, Response } from 'express'; 2 | import dotenv from 'dotenv'; 3 | import cors from 'cors'; 4 | import { connectDB } from './config/db'; 5 | import { errorHandler, notFound } from './middleware/errorMiddleware'; 6 | import { userRoutes } from './routes/userRoutes'; 7 | import { paletteRoutes } from './routes/paletteRoutes'; 8 | import { colorRoutes } from './routes/colorRoutes'; 9 | import { fontsRoutes } from './routes/fontsRoutes'; 10 | import { spacingsRoutes } from './routes/spacingsRoutes'; 11 | import { designSystemRoutes } from './routes/designSystemRoutes'; 12 | 13 | dotenv.config(); 14 | connectDB(); 15 | 16 | const app: Application = express(); 17 | const PORT = process.env.PORT || 8000; 18 | 19 | app.use(cors()); 20 | app.use(express.json()); 21 | 22 | app.use('/api/users', userRoutes); 23 | app.use('/api/color', colorRoutes); 24 | app.use('/api/palette', paletteRoutes); 25 | app.use('/api/fonts', fontsRoutes); 26 | app.use('/api/spacings', spacingsRoutes); 27 | app.use('/api/designSystem', designSystemRoutes); 28 | 29 | app.use(notFound); 30 | app.use(errorHandler); 31 | 32 | app.listen(PORT, () => { 33 | console.log(`Server started at http://localhost:${PORT}`); 34 | }); 35 | -------------------------------------------------------------------------------- /src/utils/colorFunctions.ts: -------------------------------------------------------------------------------- 1 | import { Color } from "../models/colorModel" 2 | 3 | 4 | export const insertManyColors = async (data: object[]) => { 5 | const colors = await Color.insertMany(data) 6 | .catch((err) => { 7 | throw new Error(err) 8 | }) 9 | return colors 10 | } 11 | 12 | export const deleteManyColors = async (ids: string[]) => { 13 | const deletedColors = await Color.deleteMany( {_id: {$in: ids}} ) 14 | .catch((err) => { 15 | throw new Error(err.message) 16 | }) 17 | return deletedColors 18 | } 19 | 20 | export const bulkUpdateColors = async (colorOpts: object[]) => { 21 | const colorsUpdated = await Color.bulkWrite(colorOpts) 22 | .catch((err) => { 23 | throw new Error(err.message) 24 | }) 25 | return colorsUpdated 26 | } -------------------------------------------------------------------------------- /src/utils/generateToken.ts: -------------------------------------------------------------------------------- 1 | import jwt from 'jsonwebtoken'; 2 | 3 | export const generateToken = (id: string) => { 4 | const JWT_SECRET: string = process.env.JWT_SECRET!; 5 | return jwt.sign({ id }, JWT_SECRET, { 6 | expiresIn: '30d', 7 | }); 8 | }; 9 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es5", 4 | "module": "commonjs", 5 | "lib": ["es6"], 6 | "allowJs": true, 7 | "outDir": "dist", 8 | "rootDir": "src", 9 | "strict": true, 10 | "noImplicitAny": true, 11 | "esModuleInterop": true, 12 | "resolveJsonModule": true 13 | } 14 | } 15 | --------------------------------------------------------------------------------