├── .gitignore ├── LICENSE ├── README.md ├── package-lock.json ├── package.json ├── prettier.config.js ├── src ├── index.ts ├── module │ ├── dynamodb.config.ts │ ├── dynamodb.constants.ts │ ├── dynamodb.coremodule.ts │ ├── dynamodb.decorators.ts │ ├── dynamodb.interfaces.ts │ ├── dynamodb.module.ts │ └── dynamodb.providers.ts └── util │ ├── convertToClassWithOptions.ts │ ├── getKeys.ts │ ├── getModelForClass.ts │ ├── getSchema.ts │ ├── getTable.ts │ ├── getTokens.ts │ └── index.ts └── tsconfig.json /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | lerna-debug.log* 8 | 9 | # Diagnostic reports (https://nodejs.org/api/report.html) 10 | report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json 11 | 12 | # Runtime data 13 | pids 14 | *.pid 15 | *.seed 16 | *.pid.lock 17 | 18 | # Directory for instrumented libs generated by jscoverage/JSCover 19 | lib-cov 20 | 21 | # Coverage directory used by tools like istanbul 22 | coverage 23 | *.lcov 24 | 25 | # nyc test coverage 26 | .nyc_output 27 | 28 | # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) 29 | .grunt 30 | 31 | # Bower dependency directory (https://bower.io/) 32 | bower_components 33 | 34 | # node-waf configuration 35 | .lock-wscript 36 | 37 | # Compiled binary addons (https://nodejs.org/api/addons.html) 38 | build/Release 39 | 40 | # Dependency directories 41 | node_modules/ 42 | jspm_packages/ 43 | 44 | # TypeScript v1 declaration files 45 | typings/ 46 | 47 | # TypeScript cache 48 | *.tsbuildinfo 49 | 50 | # Optional npm cache directory 51 | .npm 52 | 53 | # Optional eslint cache 54 | .eslintcache 55 | 56 | # Microbundle cache 57 | .rpt2_cache/ 58 | .rts2_cache_cjs/ 59 | .rts2_cache_es/ 60 | .rts2_cache_umd/ 61 | 62 | # Optional REPL history 63 | .node_repl_history 64 | 65 | # Output of 'npm pack' 66 | *.tgz 67 | 68 | # Yarn Integrity file 69 | .yarn-integrity 70 | 71 | # dotenv environment variables file 72 | .env 73 | .env.test 74 | 75 | # parcel-bundler cache (https://parceljs.org/) 76 | .cache 77 | 78 | # Next.js build output 79 | .next 80 | 81 | # Nuxt.js build / generate output 82 | .nuxt 83 | dist 84 | 85 | # Gatsby files 86 | .cache/ 87 | # Comment in the public line in if your project uses Gatsby and *not* Next.js 88 | # https://nextjs.org/blog/next-9-1#public-directory-support 89 | # public 90 | 91 | # vuepress build output 92 | .vuepress/dist 93 | 94 | # Serverless directories 95 | .serverless/ 96 | 97 | # FuseBox cache 98 | .fusebox/ 99 | 100 | # DynamoDB Local files 101 | .dynamodb/ 102 | 103 | # TernJS port file 104 | .tern-port 105 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2020 SkyPress, LLC 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # SkyPress NestJS DynamoDB 2 | 3 | ## Description 4 | 5 | Opinated way to use DynamoDB with NestJS and typescript, heavily inspired by [nestjs-typed-dynamodb](https://www.npmjs.com/package/nestjs-typed-dynamodb) 6 | 7 | ## Getting Started 8 | 9 | First install this module 10 | 11 | `npm install @skypress/nestjs-dynamodb` 12 | 13 | Notice that it will install [dynamodb-data-mapper-annotations](https://github.com/awslabs/dynamodb-data-mapper-js/tree/master/packages/dynamodb-data-mapper-annotations) as a dependency 14 | 15 | ## Usage 16 | 17 | In order to create a DynamoDB connection 18 | 19 | **app.module.ts** 20 | 21 | ```typescript 22 | import { Module } from '@nestjs/common' 23 | import { DynamoDBModule } from '@skypress/nestjs-dynamodb' 24 | import { CatsModule } from './cat.module.ts' 25 | 26 | @Module({ 27 | imports: [ 28 | DynamoDBModule.forRoot({ 29 | AWSConfig: { 30 | region: 'local', 31 | accessKeyId: 'null', 32 | secretAccessKey: 'null', 33 | }, 34 | dynamoDBOptions: { 35 | endpoint: 'localhost:8000', 36 | sslEnabled: false, 37 | region: 'local-env', 38 | }, 39 | }), 40 | CatsModule, 41 | ], 42 | }) 43 | export class ApplicationModule {} 44 | ``` 45 | 46 | To insert records to Dynamo, you first need to create your table, for this we use [dynamodb-data-mapper-annotations](https://github.com/awslabs/dynamodb-data-mapper-js/tree/master/packages/dynamodb-data-mapper-annotations) (under the hood). Every decorator in that package is exposed in this package as well **BUT CAPITALIZED** . 47 | 48 | **cat.schema.ts** 49 | 50 | ```typescript 51 | import { 52 | Attribute, 53 | AutoGeneratedHashKey, 54 | RangeKey, 55 | Table, 56 | VersionAttribute, 57 | } from '@skypress/nestjs-dynamodb' 58 | import * as nanoid from 'nanoid' 59 | 60 | @Table('cat') 61 | class Cat { 62 | @RangeKey({ defaultProvider: nanoid }) 63 | id: string 64 | 65 | @HashKey() 66 | breed: string 67 | 68 | @Attribute() 69 | age: number 70 | 71 | @Attribute() 72 | alive?: boolean 73 | 74 | // This property will not be saved to DynamoDB. 75 | notPersistedToDynamoDb: string 76 | } 77 | ``` 78 | 79 | Note: nanoid is only used a way to assign a random id, feel free to use whatever you want 80 | 81 | **cats.service.ts** 82 | 83 | ```typescript 84 | import { Injectable } from '@nestjs/common' 85 | import { ReturnModel, InjectModel } from '@skypress/nestjs-dynamodb' 86 | import { Cat } from './cat.schema' 87 | import { CatInput } from './cat.input' 88 | 89 | const ReturnModel = ReturnModel() 90 | 91 | @Injectable() 92 | export class CatsService { 93 | constructor( 94 | @InjectModel(Cat) 95 | private readonly catModel: typeof ReturnModel, 96 | ) {} 97 | 98 | async findAll(): Promise { 99 | return this.catModel.find() 100 | } 101 | 102 | async findById(id: string): Promise { 103 | return this.catModel.findById(id) 104 | } 105 | 106 | async create(input: CatInput): Promise { 107 | return this.catModel.create(input) 108 | } 109 | 110 | async delete(input: string): Promise { 111 | return this.catModel.findByIdAndDelete(input) 112 | } 113 | 114 | async update(id: string, item: CatInput): Promise { 115 | return this.catModel.findByIdAndUpdate(id, item) 116 | } 117 | 118 | async find(input: Partial): Promise { 119 | return this.catModel.find(input) 120 | } 121 | } 122 | ``` 123 | 124 | Now you can use your service as you wish! 125 | 126 | ## Async configuration 127 | 128 | **app.module.ts** 129 | 130 | ```typescript 131 | import { Module } from '@nestjs/common' 132 | import { DynamoDBModule } from '@skypress/nestjs-dynamodb' 133 | import { Cats } from './cat.schema' 134 | 135 | @Module({ 136 | imports: [ 137 | DynamoDBModule.forRootAsync({ 138 | imports: [ConfigModule], 139 | useFactory: async (config: ConfigService) => ({ 140 | AWSConfig: { 141 | region: 'local', 142 | accessKeyId: 'null', 143 | secretAccessKey: 'null', 144 | }, 145 | dynamoDBOptions: { 146 | endpoint: config.get('DYNAMODB_URL', 'localhost:8000'), 147 | sslEnabled: false, 148 | region: 'local-env', 149 | }, 150 | }), 151 | inject: [ConfigService], 152 | }), 153 | ], 154 | }) 155 | export class ApplicationModule {} 156 | ``` 157 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@skypress/nestjs-dynamodb", 3 | "version": "0.1.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@aws/dynamodb-auto-marshaller": { 8 | "version": "0.7.1", 9 | "resolved": "https://registry.npmjs.org/@aws/dynamodb-auto-marshaller/-/dynamodb-auto-marshaller-0.7.1.tgz", 10 | "integrity": "sha512-LeURlf6/avrfFo9+4Yht9J3CUTJ72yoBpm1FOUmlexuHNW4Ka61tG30w3ZDCXXXmCO2rG0k3ywAgNJEo3WPbyw==", 11 | "requires": { 12 | "tslib": "^1.8.1" 13 | } 14 | }, 15 | "@aws/dynamodb-batch-iterator": { 16 | "version": "0.7.1", 17 | "resolved": "https://registry.npmjs.org/@aws/dynamodb-batch-iterator/-/dynamodb-batch-iterator-0.7.1.tgz", 18 | "integrity": "sha512-SdwBFnjN+ncIl+MOogTeEh1/C6O0jAcqD5YA3AujcH5JPWiMescKAefO4VQbgR0Q9ohcYcMnwL3q6mCdUpyJ9w==", 19 | "requires": { 20 | "tslib": "^1.8.1", 21 | "utf8-bytes": "^0.0.1" 22 | } 23 | }, 24 | "@aws/dynamodb-data-mapper": { 25 | "version": "0.7.3", 26 | "resolved": "https://registry.npmjs.org/@aws/dynamodb-data-mapper/-/dynamodb-data-mapper-0.7.3.tgz", 27 | "integrity": "sha512-2DYHoF2jvO7L2TfwfJoTfdJz0M6qSVJ0wM0zQ97ehrTyVSz/yWDO3GqMA9jsUqf0fZl3CIItHBhiXdddsH5cpA==", 28 | "requires": { 29 | "@aws/dynamodb-auto-marshaller": "^0.7.1", 30 | "@aws/dynamodb-batch-iterator": "^0.7.1", 31 | "@aws/dynamodb-data-marshaller": "^0.7.3", 32 | "@aws/dynamodb-expressions": "^0.7.3", 33 | "@aws/dynamodb-query-iterator": "^0.7.1", 34 | "tslib": "^1.8.1" 35 | } 36 | }, 37 | "@aws/dynamodb-data-mapper-annotations": { 38 | "version": "0.7.3", 39 | "resolved": "https://registry.npmjs.org/@aws/dynamodb-data-mapper-annotations/-/dynamodb-data-mapper-annotations-0.7.3.tgz", 40 | "integrity": "sha512-RROw+6EIJd0bJsl/76wxfvDkv/irY9pfpp/VRlmEIVixKW2UtMqpni+Hs0XuBRtmGKGfFrWB2WGYiikSnfv4FA==", 41 | "requires": { 42 | "@aws/dynamodb-auto-marshaller": "^0.7.1", 43 | "@aws/dynamodb-data-mapper": "^0.7.3", 44 | "@aws/dynamodb-data-marshaller": "^0.7.3", 45 | "reflect-metadata": "^0.1.10", 46 | "tslib": "^1.8.1", 47 | "uuid": "^3.0.0" 48 | } 49 | }, 50 | "@aws/dynamodb-data-marshaller": { 51 | "version": "0.7.3", 52 | "resolved": "https://registry.npmjs.org/@aws/dynamodb-data-marshaller/-/dynamodb-data-marshaller-0.7.3.tgz", 53 | "integrity": "sha512-ea9PR19J2uY7lNSUo2bEcbfI8GiD0n66dISoBHZFrHjgCO2ao2P6UlyG/k0EMhr2zNzTWYNd08VYgTSYz5GBAA==", 54 | "requires": { 55 | "@aws/dynamodb-auto-marshaller": "^0.7.1", 56 | "@aws/dynamodb-expressions": "^0.7.3", 57 | "tslib": "^1.8.1", 58 | "utf8-bytes": "^0.0.1" 59 | } 60 | }, 61 | "@aws/dynamodb-expressions": { 62 | "version": "0.7.3", 63 | "resolved": "https://registry.npmjs.org/@aws/dynamodb-expressions/-/dynamodb-expressions-0.7.3.tgz", 64 | "integrity": "sha512-63vaCyNKmO8BE/JWlQ3DSFG+qCAWgO5MGif31E5CPdWKaBt5yBG5qnh5w5oFelKRK6/1M6cYKl/Yui08wimUig==", 65 | "requires": { 66 | "@aws/dynamodb-auto-marshaller": "^0.7.1", 67 | "tslib": "^1.8.1" 68 | } 69 | }, 70 | "@aws/dynamodb-query-iterator": { 71 | "version": "0.7.1", 72 | "resolved": "https://registry.npmjs.org/@aws/dynamodb-query-iterator/-/dynamodb-query-iterator-0.7.1.tgz", 73 | "integrity": "sha512-x28lcgj2HDadxszYEwQjAJyGMrdy3aznLM2TSEeQxqCxKzFT1qewmKxgWSMslH+CiLuuqs9H1FaIwvP15b6UHQ==", 74 | "requires": { 75 | "tslib": "^1.8.1" 76 | } 77 | }, 78 | "@babel/code-frame": { 79 | "version": "7.10.4", 80 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.4.tgz", 81 | "integrity": "sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg==", 82 | "dev": true, 83 | "requires": { 84 | "@babel/highlight": "^7.10.4" 85 | } 86 | }, 87 | "@babel/generator": { 88 | "version": "7.10.5", 89 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.10.5.tgz", 90 | "integrity": "sha512-3vXxr3FEW7E7lJZiWQ3bM4+v/Vyr9C+hpolQ8BGFr9Y8Ri2tFLWTixmwKBafDujO1WVah4fhZBeU1bieKdghig==", 91 | "dev": true, 92 | "requires": { 93 | "@babel/types": "^7.10.5", 94 | "jsesc": "^2.5.1", 95 | "source-map": "^0.5.0" 96 | } 97 | }, 98 | "@babel/helper-function-name": { 99 | "version": "7.10.4", 100 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.10.4.tgz", 101 | "integrity": "sha512-YdaSyz1n8gY44EmN7x44zBn9zQ1Ry2Y+3GTA+3vH6Mizke1Vw0aWDM66FOYEPw8//qKkmqOckrGgTYa+6sceqQ==", 102 | "dev": true, 103 | "requires": { 104 | "@babel/helper-get-function-arity": "^7.10.4", 105 | "@babel/template": "^7.10.4", 106 | "@babel/types": "^7.10.4" 107 | } 108 | }, 109 | "@babel/helper-get-function-arity": { 110 | "version": "7.10.4", 111 | "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.10.4.tgz", 112 | "integrity": "sha512-EkN3YDB+SRDgiIUnNgcmiD361ti+AVbL3f3Henf6dqqUyr5dMsorno0lJWJuLhDhkI5sYEpgj6y9kB8AOU1I2A==", 113 | "dev": true, 114 | "requires": { 115 | "@babel/types": "^7.10.4" 116 | } 117 | }, 118 | "@babel/helper-split-export-declaration": { 119 | "version": "7.10.4", 120 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.10.4.tgz", 121 | "integrity": "sha512-pySBTeoUff56fL5CBU2hWm9TesA4r/rOkI9DyJLvvgz09MB9YtfIYe3iBriVaYNaPe+Alua0vBIOVOLs2buWhg==", 122 | "dev": true, 123 | "requires": { 124 | "@babel/types": "^7.10.4" 125 | } 126 | }, 127 | "@babel/helper-validator-identifier": { 128 | "version": "7.10.4", 129 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz", 130 | "integrity": "sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==", 131 | "dev": true 132 | }, 133 | "@babel/highlight": { 134 | "version": "7.10.4", 135 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", 136 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", 137 | "dev": true, 138 | "requires": { 139 | "@babel/helper-validator-identifier": "^7.10.4", 140 | "chalk": "^2.0.0", 141 | "js-tokens": "^4.0.0" 142 | } 143 | }, 144 | "@babel/parser": { 145 | "version": "7.10.5", 146 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.10.5.tgz", 147 | "integrity": "sha512-wfryxy4bE1UivvQKSQDU4/X6dr+i8bctjUjj8Zyt3DQy7NtPizJXT8M52nqpNKL+nq2PW8lxk4ZqLj0fD4B4hQ==", 148 | "dev": true 149 | }, 150 | "@babel/template": { 151 | "version": "7.10.4", 152 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.10.4.tgz", 153 | "integrity": "sha512-ZCjD27cGJFUB6nmCB1Enki3r+L5kJveX9pq1SvAUKoICy6CZ9yD8xO086YXdYhvNjBdnekm4ZnaP5yC8Cs/1tA==", 154 | "dev": true, 155 | "requires": { 156 | "@babel/code-frame": "^7.10.4", 157 | "@babel/parser": "^7.10.4", 158 | "@babel/types": "^7.10.4" 159 | } 160 | }, 161 | "@babel/traverse": { 162 | "version": "7.10.5", 163 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.10.5.tgz", 164 | "integrity": "sha512-yc/fyv2gUjPqzTz0WHeRJH2pv7jA9kA7mBX2tXl/x5iOE81uaVPuGPtaYk7wmkx4b67mQ7NqI8rmT2pF47KYKQ==", 165 | "dev": true, 166 | "requires": { 167 | "@babel/code-frame": "^7.10.4", 168 | "@babel/generator": "^7.10.5", 169 | "@babel/helper-function-name": "^7.10.4", 170 | "@babel/helper-split-export-declaration": "^7.10.4", 171 | "@babel/parser": "^7.10.5", 172 | "@babel/types": "^7.10.5", 173 | "debug": "^4.1.0", 174 | "globals": "^11.1.0", 175 | "lodash": "^4.17.19" 176 | }, 177 | "dependencies": { 178 | "debug": { 179 | "version": "4.1.1", 180 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 181 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 182 | "dev": true, 183 | "requires": { 184 | "ms": "^2.1.1" 185 | } 186 | }, 187 | "ms": { 188 | "version": "2.1.2", 189 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 190 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 191 | "dev": true 192 | } 193 | } 194 | }, 195 | "@babel/types": { 196 | "version": "7.10.5", 197 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.10.5.tgz", 198 | "integrity": "sha512-ixV66KWfCI6GKoA/2H9v6bQdbfXEwwpOdQ8cRvb4F+eyvhlaHxWFMQB4+3d9QFJXZsiiiqVrewNV0DFEQpyT4Q==", 199 | "dev": true, 200 | "requires": { 201 | "@babel/helper-validator-identifier": "^7.10.4", 202 | "lodash": "^4.17.19", 203 | "to-fast-properties": "^2.0.0" 204 | } 205 | }, 206 | "@nestjs/common": { 207 | "version": "6.11.11", 208 | "resolved": "https://registry.npmjs.org/@nestjs/common/-/common-6.11.11.tgz", 209 | "integrity": "sha512-K4wuK/V2M82AsoudtY0UYV+M1nYDSSb10t8AkMwFiP+AWMuxCJNtE8qLc9jUe2aTKMbhBiQUfsbZFmg/MRinPg==", 210 | "requires": { 211 | "axios": "0.19.2", 212 | "cli-color": "2.0.0", 213 | "tslib": "1.11.1", 214 | "uuid": "7.0.1" 215 | }, 216 | "dependencies": { 217 | "tslib": { 218 | "version": "1.11.1", 219 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", 220 | "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==" 221 | }, 222 | "uuid": { 223 | "version": "7.0.1", 224 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-7.0.1.tgz", 225 | "integrity": "sha512-yqjRXZzSJm9Dbl84H2VDHpM3zMjzSJQ+hn6C4zqd5ilW+7P4ZmLEEqwho9LjP+tGuZlF4xrHQXT0h9QZUS/pWA==" 226 | } 227 | } 228 | }, 229 | "@types/color-name": { 230 | "version": "1.1.1", 231 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 232 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 233 | "dev": true 234 | }, 235 | "@types/json5": { 236 | "version": "0.0.29", 237 | "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", 238 | "integrity": "sha1-7ihweulOEdK4J7y+UnC86n8+ce4=", 239 | "dev": true 240 | }, 241 | "acorn": { 242 | "version": "7.3.1", 243 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.3.1.tgz", 244 | "integrity": "sha512-tLc0wSnatxAQHVHUapaHdz72pi9KUyHjq5KyHjGg9Y8Ifdc79pTh2XvI6I1/chZbnM7QtNKzh66ooDogPZSleA==", 245 | "dev": true 246 | }, 247 | "acorn-jsx": { 248 | "version": "5.2.0", 249 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.2.0.tgz", 250 | "integrity": "sha512-HiUX/+K2YpkpJ+SzBffkM/AQ2YE03S0U1kjTLVpoJdhZMOWy8qvXVN9JdLqv2QsaQ6MPYQIuNmwD8zOiYUofLQ==", 251 | "dev": true 252 | }, 253 | "ajv": { 254 | "version": "6.12.3", 255 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.3.tgz", 256 | "integrity": "sha512-4K0cK3L1hsqk9xIb2z9vs/XU+PGJZ9PNpJRDS9YLzmNdX6jmVPfamLvTJr0aDAusnHyCHO6MjzlkAsgtqp9teA==", 257 | "dev": true, 258 | "requires": { 259 | "fast-deep-equal": "^3.1.1", 260 | "fast-json-stable-stringify": "^2.0.0", 261 | "json-schema-traverse": "^0.4.1", 262 | "uri-js": "^4.2.2" 263 | } 264 | }, 265 | "ansi-colors": { 266 | "version": "4.1.1", 267 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 268 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 269 | "dev": true 270 | }, 271 | "ansi-escapes": { 272 | "version": "4.3.1", 273 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.1.tgz", 274 | "integrity": "sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA==", 275 | "dev": true, 276 | "requires": { 277 | "type-fest": "^0.11.0" 278 | }, 279 | "dependencies": { 280 | "type-fest": { 281 | "version": "0.11.0", 282 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.11.0.tgz", 283 | "integrity": "sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ==", 284 | "dev": true 285 | } 286 | } 287 | }, 288 | "ansi-regex": { 289 | "version": "2.1.1", 290 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 291 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 292 | }, 293 | "ansi-styles": { 294 | "version": "3.2.1", 295 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 296 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 297 | "dev": true, 298 | "requires": { 299 | "color-convert": "^1.9.0" 300 | } 301 | }, 302 | "argparse": { 303 | "version": "1.0.10", 304 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 305 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 306 | "dev": true, 307 | "requires": { 308 | "sprintf-js": "~1.0.2" 309 | } 310 | }, 311 | "array-includes": { 312 | "version": "3.1.1", 313 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.1.tgz", 314 | "integrity": "sha512-c2VXaCHl7zPsvpkFsw4nxvFie4fh1ur9bpcgsVkIjqn0H/Xwdg+7fv3n2r/isyS8EBj5b06M9kHyZuIr4El6WQ==", 315 | "dev": true, 316 | "requires": { 317 | "define-properties": "^1.1.3", 318 | "es-abstract": "^1.17.0", 319 | "is-string": "^1.0.5" 320 | } 321 | }, 322 | "array.prototype.flat": { 323 | "version": "1.2.3", 324 | "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.2.3.tgz", 325 | "integrity": "sha512-gBlRZV0VSmfPIeWfuuy56XZMvbVfbEUnOXUvt3F/eUUUSyzlgLxhEX4YAEpxNAogRGehPSnfXyPtYyKAhkzQhQ==", 326 | "dev": true, 327 | "requires": { 328 | "define-properties": "^1.1.3", 329 | "es-abstract": "^1.17.0-next.1" 330 | } 331 | }, 332 | "array.prototype.flatmap": { 333 | "version": "1.2.3", 334 | "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.2.3.tgz", 335 | "integrity": "sha512-OOEk+lkePcg+ODXIpvuU9PAryCikCJyo7GlDG1upleEpQRx6mzL9puEBkozQ5iAx20KV0l3DbyQwqciJtqe5Pg==", 336 | "dev": true, 337 | "requires": { 338 | "define-properties": "^1.1.3", 339 | "es-abstract": "^1.17.0-next.1", 340 | "function-bind": "^1.1.1" 341 | } 342 | }, 343 | "astral-regex": { 344 | "version": "1.0.0", 345 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 346 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 347 | "dev": true 348 | }, 349 | "aws-sdk": { 350 | "version": "2.713.0", 351 | "resolved": "https://registry.npmjs.org/aws-sdk/-/aws-sdk-2.713.0.tgz", 352 | "integrity": "sha512-axR1eOVn134KXJc1IT+Au2TXcK6oswY+4nvGe5GfU3pXeehhe0xNeP9Bw9yF36TRBxuvu4IJ2hRHDKma05smgA==", 353 | "requires": { 354 | "buffer": "4.9.2", 355 | "events": "1.1.1", 356 | "ieee754": "1.1.13", 357 | "jmespath": "0.15.0", 358 | "querystring": "0.2.0", 359 | "sax": "1.2.1", 360 | "url": "0.10.3", 361 | "uuid": "3.3.2", 362 | "xml2js": "0.4.19" 363 | }, 364 | "dependencies": { 365 | "uuid": { 366 | "version": "3.3.2", 367 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 368 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==" 369 | } 370 | } 371 | }, 372 | "axios": { 373 | "version": "0.19.2", 374 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.19.2.tgz", 375 | "integrity": "sha512-fjgm5MvRHLhx+osE2xoekY70AhARk3a6hkN+3Io1jc00jtquGvxYlKlsFUhmUET0V5te6CcZI7lcv2Ym61mjHA==", 376 | "requires": { 377 | "follow-redirects": "1.5.10" 378 | } 379 | }, 380 | "babel-eslint": { 381 | "version": "10.1.0", 382 | "resolved": "https://registry.npmjs.org/babel-eslint/-/babel-eslint-10.1.0.tgz", 383 | "integrity": "sha512-ifWaTHQ0ce+448CYop8AdrQiBsGrnC+bMgfyKFdi6EsPLTAWG+QfyDeM6OH+FmWnKvEq5NnBMLvlBUPKQZoDSg==", 384 | "dev": true, 385 | "requires": { 386 | "@babel/code-frame": "^7.0.0", 387 | "@babel/parser": "^7.7.0", 388 | "@babel/traverse": "^7.7.0", 389 | "@babel/types": "^7.7.0", 390 | "eslint-visitor-keys": "^1.0.0", 391 | "resolve": "^1.12.0" 392 | } 393 | }, 394 | "balanced-match": { 395 | "version": "1.0.0", 396 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 397 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 398 | "dev": true 399 | }, 400 | "base64-js": { 401 | "version": "1.3.1", 402 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.3.1.tgz", 403 | "integrity": "sha512-mLQ4i2QO1ytvGWFWmcngKO//JXAQueZvwEKtjgQFM4jIK0kU+ytMfplL8j+n5mspOfjHwoAg+9yhb7BwAHm36g==" 404 | }, 405 | "brace-expansion": { 406 | "version": "1.1.11", 407 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 408 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 409 | "dev": true, 410 | "requires": { 411 | "balanced-match": "^1.0.0", 412 | "concat-map": "0.0.1" 413 | } 414 | }, 415 | "buffer": { 416 | "version": "4.9.2", 417 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.2.tgz", 418 | "integrity": "sha512-xq+q3SRMOxGivLhBNaUdC64hDTQwejJ+H0T/NB1XMtTVEwNTrfFF3gAxiyW0Bu/xWEGhjVKgUcMhCrUy2+uCWg==", 419 | "requires": { 420 | "base64-js": "^1.0.2", 421 | "ieee754": "^1.1.4", 422 | "isarray": "^1.0.0" 423 | } 424 | }, 425 | "callsites": { 426 | "version": "3.1.0", 427 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 428 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 429 | "dev": true 430 | }, 431 | "chalk": { 432 | "version": "2.4.2", 433 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 434 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 435 | "dev": true, 436 | "requires": { 437 | "ansi-styles": "^3.2.1", 438 | "escape-string-regexp": "^1.0.5", 439 | "supports-color": "^5.3.0" 440 | } 441 | }, 442 | "chardet": { 443 | "version": "0.7.0", 444 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 445 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 446 | "dev": true 447 | }, 448 | "cli-color": { 449 | "version": "2.0.0", 450 | "resolved": "https://registry.npmjs.org/cli-color/-/cli-color-2.0.0.tgz", 451 | "integrity": "sha512-a0VZ8LeraW0jTuCkuAGMNufareGHhyZU9z8OGsW0gXd1hZGi1SRuNRXdbGkraBBKnhyUhyebFWnRbp+dIn0f0A==", 452 | "requires": { 453 | "ansi-regex": "^2.1.1", 454 | "d": "^1.0.1", 455 | "es5-ext": "^0.10.51", 456 | "es6-iterator": "^2.0.3", 457 | "memoizee": "^0.4.14", 458 | "timers-ext": "^0.1.7" 459 | } 460 | }, 461 | "cli-cursor": { 462 | "version": "3.1.0", 463 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 464 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 465 | "dev": true, 466 | "requires": { 467 | "restore-cursor": "^3.1.0" 468 | } 469 | }, 470 | "cli-width": { 471 | "version": "3.0.0", 472 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-3.0.0.tgz", 473 | "integrity": "sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==", 474 | "dev": true 475 | }, 476 | "color-convert": { 477 | "version": "1.9.3", 478 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 479 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 480 | "dev": true, 481 | "requires": { 482 | "color-name": "1.1.3" 483 | } 484 | }, 485 | "color-name": { 486 | "version": "1.1.3", 487 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 488 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 489 | "dev": true 490 | }, 491 | "concat-map": { 492 | "version": "0.0.1", 493 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 494 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 495 | "dev": true 496 | }, 497 | "contains-path": { 498 | "version": "0.1.0", 499 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 500 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 501 | "dev": true 502 | }, 503 | "cross-spawn": { 504 | "version": "6.0.5", 505 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 506 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 507 | "dev": true, 508 | "requires": { 509 | "nice-try": "^1.0.4", 510 | "path-key": "^2.0.1", 511 | "semver": "^5.5.0", 512 | "shebang-command": "^1.2.0", 513 | "which": "^1.2.9" 514 | }, 515 | "dependencies": { 516 | "semver": { 517 | "version": "5.7.1", 518 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 519 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 520 | "dev": true 521 | } 522 | } 523 | }, 524 | "d": { 525 | "version": "1.0.1", 526 | "resolved": "https://registry.npmjs.org/d/-/d-1.0.1.tgz", 527 | "integrity": "sha512-m62ShEObQ39CfralilEQRjH6oAMtNCV1xJyEx5LpRYUVN+EviphDgUc/F3hnYbADmkiNs67Y+3ylmlG7Lnu+FA==", 528 | "requires": { 529 | "es5-ext": "^0.10.50", 530 | "type": "^1.0.1" 531 | } 532 | }, 533 | "debug": { 534 | "version": "3.1.0", 535 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 536 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 537 | "requires": { 538 | "ms": "2.0.0" 539 | } 540 | }, 541 | "deep-is": { 542 | "version": "0.1.3", 543 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 544 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 545 | "dev": true 546 | }, 547 | "define-properties": { 548 | "version": "1.1.3", 549 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 550 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 551 | "dev": true, 552 | "requires": { 553 | "object-keys": "^1.0.12" 554 | } 555 | }, 556 | "doctrine": { 557 | "version": "3.0.0", 558 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 559 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 560 | "dev": true, 561 | "requires": { 562 | "esutils": "^2.0.2" 563 | } 564 | }, 565 | "emoji-regex": { 566 | "version": "8.0.0", 567 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 568 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 569 | "dev": true 570 | }, 571 | "enquirer": { 572 | "version": "2.3.6", 573 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 574 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 575 | "dev": true, 576 | "requires": { 577 | "ansi-colors": "^4.1.1" 578 | } 579 | }, 580 | "error-ex": { 581 | "version": "1.3.2", 582 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 583 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 584 | "dev": true, 585 | "requires": { 586 | "is-arrayish": "^0.2.1" 587 | } 588 | }, 589 | "es-abstract": { 590 | "version": "1.17.6", 591 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.6.tgz", 592 | "integrity": "sha512-Fr89bON3WFyUi5EvAeI48QTWX0AyekGgLA8H+c+7fbfCkJwRWRMLd8CQedNEyJuoYYhmtEqY92pgte1FAhBlhw==", 593 | "dev": true, 594 | "requires": { 595 | "es-to-primitive": "^1.2.1", 596 | "function-bind": "^1.1.1", 597 | "has": "^1.0.3", 598 | "has-symbols": "^1.0.1", 599 | "is-callable": "^1.2.0", 600 | "is-regex": "^1.1.0", 601 | "object-inspect": "^1.7.0", 602 | "object-keys": "^1.1.1", 603 | "object.assign": "^4.1.0", 604 | "string.prototype.trimend": "^1.0.1", 605 | "string.prototype.trimstart": "^1.0.1" 606 | } 607 | }, 608 | "es-to-primitive": { 609 | "version": "1.2.1", 610 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 611 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 612 | "dev": true, 613 | "requires": { 614 | "is-callable": "^1.1.4", 615 | "is-date-object": "^1.0.1", 616 | "is-symbol": "^1.0.2" 617 | } 618 | }, 619 | "es5-ext": { 620 | "version": "0.10.53", 621 | "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.53.tgz", 622 | "integrity": "sha512-Xs2Stw6NiNHWypzRTY1MtaG/uJlwCk8kH81920ma8mvN8Xq1gsfhZvpkImLQArw8AHnv8MT2I45J3c0R8slE+Q==", 623 | "requires": { 624 | "es6-iterator": "~2.0.3", 625 | "es6-symbol": "~3.1.3", 626 | "next-tick": "~1.0.0" 627 | } 628 | }, 629 | "es6-iterator": { 630 | "version": "2.0.3", 631 | "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.3.tgz", 632 | "integrity": "sha1-p96IkUGgWpSwhUQDstCg+/qY87c=", 633 | "requires": { 634 | "d": "1", 635 | "es5-ext": "^0.10.35", 636 | "es6-symbol": "^3.1.1" 637 | } 638 | }, 639 | "es6-symbol": { 640 | "version": "3.1.3", 641 | "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.3.tgz", 642 | "integrity": "sha512-NJ6Yn3FuDinBaBRWl/q5X/s4koRHBrgKAu+yGI6JCBeiu3qrcbJhwT2GeR/EXVfylRk8dpQVJoLEFhK+Mu31NA==", 643 | "requires": { 644 | "d": "^1.0.1", 645 | "ext": "^1.1.2" 646 | } 647 | }, 648 | "es6-weak-map": { 649 | "version": "2.0.3", 650 | "resolved": "https://registry.npmjs.org/es6-weak-map/-/es6-weak-map-2.0.3.tgz", 651 | "integrity": "sha512-p5um32HOTO1kP+w7PRnB+5lQ43Z6muuMuIMffvDN8ZB4GcnjLBV6zGStpbASIMk4DCAvEaamhe2zhyCb/QXXsA==", 652 | "requires": { 653 | "d": "1", 654 | "es5-ext": "^0.10.46", 655 | "es6-iterator": "^2.0.3", 656 | "es6-symbol": "^3.1.1" 657 | } 658 | }, 659 | "escape-string-regexp": { 660 | "version": "1.0.5", 661 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 662 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 663 | "dev": true 664 | }, 665 | "eslint": { 666 | "version": "6.8.0", 667 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.8.0.tgz", 668 | "integrity": "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==", 669 | "dev": true, 670 | "requires": { 671 | "@babel/code-frame": "^7.0.0", 672 | "ajv": "^6.10.0", 673 | "chalk": "^2.1.0", 674 | "cross-spawn": "^6.0.5", 675 | "debug": "^4.0.1", 676 | "doctrine": "^3.0.0", 677 | "eslint-scope": "^5.0.0", 678 | "eslint-utils": "^1.4.3", 679 | "eslint-visitor-keys": "^1.1.0", 680 | "espree": "^6.1.2", 681 | "esquery": "^1.0.1", 682 | "esutils": "^2.0.2", 683 | "file-entry-cache": "^5.0.1", 684 | "functional-red-black-tree": "^1.0.1", 685 | "glob-parent": "^5.0.0", 686 | "globals": "^12.1.0", 687 | "ignore": "^4.0.6", 688 | "import-fresh": "^3.0.0", 689 | "imurmurhash": "^0.1.4", 690 | "inquirer": "^7.0.0", 691 | "is-glob": "^4.0.0", 692 | "js-yaml": "^3.13.1", 693 | "json-stable-stringify-without-jsonify": "^1.0.1", 694 | "levn": "^0.3.0", 695 | "lodash": "^4.17.14", 696 | "minimatch": "^3.0.4", 697 | "mkdirp": "^0.5.1", 698 | "natural-compare": "^1.4.0", 699 | "optionator": "^0.8.3", 700 | "progress": "^2.0.0", 701 | "regexpp": "^2.0.1", 702 | "semver": "^6.1.2", 703 | "strip-ansi": "^5.2.0", 704 | "strip-json-comments": "^3.0.1", 705 | "table": "^5.2.3", 706 | "text-table": "^0.2.0", 707 | "v8-compile-cache": "^2.0.3" 708 | }, 709 | "dependencies": { 710 | "debug": { 711 | "version": "4.1.1", 712 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 713 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 714 | "dev": true, 715 | "requires": { 716 | "ms": "^2.1.1" 717 | } 718 | }, 719 | "globals": { 720 | "version": "12.4.0", 721 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 722 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 723 | "dev": true, 724 | "requires": { 725 | "type-fest": "^0.8.1" 726 | } 727 | }, 728 | "ms": { 729 | "version": "2.1.2", 730 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 731 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 732 | "dev": true 733 | } 734 | } 735 | }, 736 | "eslint-config-prettier": { 737 | "version": "6.11.0", 738 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-6.11.0.tgz", 739 | "integrity": "sha512-oB8cpLWSAjOVFEJhhyMZh6NOEOtBVziaqdDQ86+qhDHFbZXoRTM7pNSvFRfW/W/L/LrQ38C99J5CGuRBBzBsdA==", 740 | "dev": true, 741 | "requires": { 742 | "get-stdin": "^6.0.0" 743 | } 744 | }, 745 | "eslint-config-rokket-labs": { 746 | "version": "0.1.5", 747 | "resolved": "https://registry.npmjs.org/eslint-config-rokket-labs/-/eslint-config-rokket-labs-0.1.5.tgz", 748 | "integrity": "sha512-uMCdMWbroaLmE4Fq4mgJSQC0lXE8NEtVMttCMMdJ9jYPF+Q4re/BGTLWCt2tQz8KPd5e6Y8OxoMEEDXz+pBayw==", 749 | "dev": true, 750 | "requires": { 751 | "eslint": "^7.4.0", 752 | "eslint-config-prettier": "^6.11.0", 753 | "eslint-plugin-import": "^2.22.0", 754 | "eslint-plugin-prettier": "^3.1.4", 755 | "eslint-plugin-react": "^7.20.3", 756 | "eslint-plugin-react-hooks": "^4.0.5", 757 | "eslint-plugin-react-native": "^3.8.1", 758 | "prettier": "^2.0.5" 759 | }, 760 | "dependencies": { 761 | "ansi-regex": { 762 | "version": "5.0.0", 763 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 764 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 765 | "dev": true 766 | }, 767 | "ansi-styles": { 768 | "version": "4.2.1", 769 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 770 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 771 | "dev": true, 772 | "requires": { 773 | "@types/color-name": "^1.1.1", 774 | "color-convert": "^2.0.1" 775 | } 776 | }, 777 | "chalk": { 778 | "version": "4.1.0", 779 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 780 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 781 | "dev": true, 782 | "requires": { 783 | "ansi-styles": "^4.1.0", 784 | "supports-color": "^7.1.0" 785 | } 786 | }, 787 | "color-convert": { 788 | "version": "2.0.1", 789 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 790 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 791 | "dev": true, 792 | "requires": { 793 | "color-name": "~1.1.4" 794 | } 795 | }, 796 | "color-name": { 797 | "version": "1.1.4", 798 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 799 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 800 | "dev": true 801 | }, 802 | "cross-spawn": { 803 | "version": "7.0.3", 804 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 805 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 806 | "dev": true, 807 | "requires": { 808 | "path-key": "^3.1.0", 809 | "shebang-command": "^2.0.0", 810 | "which": "^2.0.1" 811 | } 812 | }, 813 | "debug": { 814 | "version": "4.1.1", 815 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 816 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 817 | "dev": true, 818 | "requires": { 819 | "ms": "^2.1.1" 820 | } 821 | }, 822 | "eslint": { 823 | "version": "7.4.0", 824 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.4.0.tgz", 825 | "integrity": "sha512-gU+lxhlPHu45H3JkEGgYhWhkR9wLHHEXC9FbWFnTlEkbKyZKWgWRLgf61E8zWmBuI6g5xKBph9ltg3NtZMVF8g==", 826 | "dev": true, 827 | "requires": { 828 | "@babel/code-frame": "^7.0.0", 829 | "ajv": "^6.10.0", 830 | "chalk": "^4.0.0", 831 | "cross-spawn": "^7.0.2", 832 | "debug": "^4.0.1", 833 | "doctrine": "^3.0.0", 834 | "enquirer": "^2.3.5", 835 | "eslint-scope": "^5.1.0", 836 | "eslint-utils": "^2.0.0", 837 | "eslint-visitor-keys": "^1.2.0", 838 | "espree": "^7.1.0", 839 | "esquery": "^1.2.0", 840 | "esutils": "^2.0.2", 841 | "file-entry-cache": "^5.0.1", 842 | "functional-red-black-tree": "^1.0.1", 843 | "glob-parent": "^5.0.0", 844 | "globals": "^12.1.0", 845 | "ignore": "^4.0.6", 846 | "import-fresh": "^3.0.0", 847 | "imurmurhash": "^0.1.4", 848 | "is-glob": "^4.0.0", 849 | "js-yaml": "^3.13.1", 850 | "json-stable-stringify-without-jsonify": "^1.0.1", 851 | "levn": "^0.4.1", 852 | "lodash": "^4.17.14", 853 | "minimatch": "^3.0.4", 854 | "natural-compare": "^1.4.0", 855 | "optionator": "^0.9.1", 856 | "progress": "^2.0.0", 857 | "regexpp": "^3.1.0", 858 | "semver": "^7.2.1", 859 | "strip-ansi": "^6.0.0", 860 | "strip-json-comments": "^3.1.0", 861 | "table": "^5.2.3", 862 | "text-table": "^0.2.0", 863 | "v8-compile-cache": "^2.0.3" 864 | } 865 | }, 866 | "eslint-utils": { 867 | "version": "2.1.0", 868 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 869 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 870 | "dev": true, 871 | "requires": { 872 | "eslint-visitor-keys": "^1.1.0" 873 | } 874 | }, 875 | "espree": { 876 | "version": "7.1.0", 877 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.1.0.tgz", 878 | "integrity": "sha512-dcorZSyfmm4WTuTnE5Y7MEN1DyoPYy1ZR783QW1FJoenn7RailyWFsq/UL6ZAAA7uXurN9FIpYyUs3OfiIW+Qw==", 879 | "dev": true, 880 | "requires": { 881 | "acorn": "^7.2.0", 882 | "acorn-jsx": "^5.2.0", 883 | "eslint-visitor-keys": "^1.2.0" 884 | } 885 | }, 886 | "globals": { 887 | "version": "12.4.0", 888 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 889 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 890 | "dev": true, 891 | "requires": { 892 | "type-fest": "^0.8.1" 893 | } 894 | }, 895 | "has-flag": { 896 | "version": "4.0.0", 897 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 898 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 899 | "dev": true 900 | }, 901 | "levn": { 902 | "version": "0.4.1", 903 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 904 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 905 | "dev": true, 906 | "requires": { 907 | "prelude-ls": "^1.2.1", 908 | "type-check": "~0.4.0" 909 | } 910 | }, 911 | "ms": { 912 | "version": "2.1.2", 913 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 914 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 915 | "dev": true 916 | }, 917 | "optionator": { 918 | "version": "0.9.1", 919 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 920 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 921 | "dev": true, 922 | "requires": { 923 | "deep-is": "^0.1.3", 924 | "fast-levenshtein": "^2.0.6", 925 | "levn": "^0.4.1", 926 | "prelude-ls": "^1.2.1", 927 | "type-check": "^0.4.0", 928 | "word-wrap": "^1.2.3" 929 | } 930 | }, 931 | "path-key": { 932 | "version": "3.1.1", 933 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 934 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 935 | "dev": true 936 | }, 937 | "prelude-ls": { 938 | "version": "1.2.1", 939 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 940 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 941 | "dev": true 942 | }, 943 | "regexpp": { 944 | "version": "3.1.0", 945 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 946 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 947 | "dev": true 948 | }, 949 | "semver": { 950 | "version": "7.3.2", 951 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 952 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 953 | "dev": true 954 | }, 955 | "shebang-command": { 956 | "version": "2.0.0", 957 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 958 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 959 | "dev": true, 960 | "requires": { 961 | "shebang-regex": "^3.0.0" 962 | } 963 | }, 964 | "shebang-regex": { 965 | "version": "3.0.0", 966 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 967 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 968 | "dev": true 969 | }, 970 | "strip-ansi": { 971 | "version": "6.0.0", 972 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 973 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 974 | "dev": true, 975 | "requires": { 976 | "ansi-regex": "^5.0.0" 977 | } 978 | }, 979 | "supports-color": { 980 | "version": "7.1.0", 981 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 982 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 983 | "dev": true, 984 | "requires": { 985 | "has-flag": "^4.0.0" 986 | } 987 | }, 988 | "type-check": { 989 | "version": "0.4.0", 990 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 991 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 992 | "dev": true, 993 | "requires": { 994 | "prelude-ls": "^1.2.1" 995 | } 996 | }, 997 | "which": { 998 | "version": "2.0.2", 999 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1000 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1001 | "dev": true, 1002 | "requires": { 1003 | "isexe": "^2.0.0" 1004 | } 1005 | } 1006 | } 1007 | }, 1008 | "eslint-import-resolver-node": { 1009 | "version": "0.3.4", 1010 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.4.tgz", 1011 | "integrity": "sha512-ogtf+5AB/O+nM6DIeBUNr2fuT7ot9Qg/1harBfBtaP13ekEWFQEEMP94BCB7zaNW3gyY+8SHYF00rnqYwXKWOA==", 1012 | "dev": true, 1013 | "requires": { 1014 | "debug": "^2.6.9", 1015 | "resolve": "^1.13.1" 1016 | }, 1017 | "dependencies": { 1018 | "debug": { 1019 | "version": "2.6.9", 1020 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1021 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1022 | "dev": true, 1023 | "requires": { 1024 | "ms": "2.0.0" 1025 | } 1026 | } 1027 | } 1028 | }, 1029 | "eslint-module-utils": { 1030 | "version": "2.6.0", 1031 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.6.0.tgz", 1032 | "integrity": "sha512-6j9xxegbqe8/kZY8cYpcp0xhbK0EgJlg3g9mib3/miLaExuuwc3n5UEfSnU6hWMbT0FAYVvDbL9RrRgpUeQIvA==", 1033 | "dev": true, 1034 | "requires": { 1035 | "debug": "^2.6.9", 1036 | "pkg-dir": "^2.0.0" 1037 | }, 1038 | "dependencies": { 1039 | "debug": { 1040 | "version": "2.6.9", 1041 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1042 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1043 | "dev": true, 1044 | "requires": { 1045 | "ms": "2.0.0" 1046 | } 1047 | } 1048 | } 1049 | }, 1050 | "eslint-plugin-import": { 1051 | "version": "2.22.0", 1052 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.22.0.tgz", 1053 | "integrity": "sha512-66Fpf1Ln6aIS5Gr/55ts19eUuoDhAbZgnr6UxK5hbDx6l/QgQgx61AePq+BV4PP2uXQFClgMVzep5zZ94qqsxg==", 1054 | "dev": true, 1055 | "requires": { 1056 | "array-includes": "^3.1.1", 1057 | "array.prototype.flat": "^1.2.3", 1058 | "contains-path": "^0.1.0", 1059 | "debug": "^2.6.9", 1060 | "doctrine": "1.5.0", 1061 | "eslint-import-resolver-node": "^0.3.3", 1062 | "eslint-module-utils": "^2.6.0", 1063 | "has": "^1.0.3", 1064 | "minimatch": "^3.0.4", 1065 | "object.values": "^1.1.1", 1066 | "read-pkg-up": "^2.0.0", 1067 | "resolve": "^1.17.0", 1068 | "tsconfig-paths": "^3.9.0" 1069 | }, 1070 | "dependencies": { 1071 | "debug": { 1072 | "version": "2.6.9", 1073 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1074 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1075 | "dev": true, 1076 | "requires": { 1077 | "ms": "2.0.0" 1078 | } 1079 | }, 1080 | "doctrine": { 1081 | "version": "1.5.0", 1082 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 1083 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 1084 | "dev": true, 1085 | "requires": { 1086 | "esutils": "^2.0.2", 1087 | "isarray": "^1.0.0" 1088 | } 1089 | } 1090 | } 1091 | }, 1092 | "eslint-plugin-prettier": { 1093 | "version": "3.1.4", 1094 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.1.4.tgz", 1095 | "integrity": "sha512-jZDa8z76klRqo+TdGDTFJSavwbnWK2ZpqGKNZ+VvweMW516pDUMmQ2koXvxEE4JhzNvTv+radye/bWGBmA6jmg==", 1096 | "dev": true, 1097 | "requires": { 1098 | "prettier-linter-helpers": "^1.0.0" 1099 | } 1100 | }, 1101 | "eslint-plugin-react": { 1102 | "version": "7.20.3", 1103 | "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.20.3.tgz", 1104 | "integrity": "sha512-txbo090buDeyV0ugF3YMWrzLIUqpYTsWSDZV9xLSmExE1P/Kmgg9++PD931r+KEWS66O1c9R4srLVVHmeHpoAg==", 1105 | "dev": true, 1106 | "requires": { 1107 | "array-includes": "^3.1.1", 1108 | "array.prototype.flatmap": "^1.2.3", 1109 | "doctrine": "^2.1.0", 1110 | "has": "^1.0.3", 1111 | "jsx-ast-utils": "^2.4.1", 1112 | "object.entries": "^1.1.2", 1113 | "object.fromentries": "^2.0.2", 1114 | "object.values": "^1.1.1", 1115 | "prop-types": "^15.7.2", 1116 | "resolve": "^1.17.0", 1117 | "string.prototype.matchall": "^4.0.2" 1118 | }, 1119 | "dependencies": { 1120 | "doctrine": { 1121 | "version": "2.1.0", 1122 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 1123 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 1124 | "dev": true, 1125 | "requires": { 1126 | "esutils": "^2.0.2" 1127 | } 1128 | } 1129 | } 1130 | }, 1131 | "eslint-plugin-react-hooks": { 1132 | "version": "4.0.8", 1133 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.0.8.tgz", 1134 | "integrity": "sha512-6SSb5AiMCPd8FDJrzah+Z4F44P2CdOaK026cXFV+o/xSRzfOiV1FNFeLl2z6xm3yqWOQEZ5OfVgiec90qV2xrQ==", 1135 | "dev": true 1136 | }, 1137 | "eslint-plugin-react-native": { 1138 | "version": "3.8.1", 1139 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-native/-/eslint-plugin-react-native-3.8.1.tgz", 1140 | "integrity": "sha512-6Z4s4nvgFRdda/1s1+uu4a6EMZwEjjJ9Bk/1yBImv0fd9U2CsGu2cUakAtV83cZKhizbWhSouXoaK4JtlScdFg==", 1141 | "dev": true, 1142 | "requires": { 1143 | "eslint-plugin-react-native-globals": "^0.1.1" 1144 | } 1145 | }, 1146 | "eslint-plugin-react-native-globals": { 1147 | "version": "0.1.2", 1148 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-native-globals/-/eslint-plugin-react-native-globals-0.1.2.tgz", 1149 | "integrity": "sha512-9aEPf1JEpiTjcFAmmyw8eiIXmcNZOqaZyHO77wgm0/dWfT/oxC1SrIq8ET38pMxHYrcB6Uew+TzUVsBeczF88g==", 1150 | "dev": true 1151 | }, 1152 | "eslint-scope": { 1153 | "version": "5.1.0", 1154 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.0.tgz", 1155 | "integrity": "sha512-iiGRvtxWqgtx5m8EyQUJihBloE4EnYeGE/bz1wSPwJE6tZuJUtHlhqDM4Xj2ukE8Dyy1+HCZ4hE0fzIVMzb58w==", 1156 | "dev": true, 1157 | "requires": { 1158 | "esrecurse": "^4.1.0", 1159 | "estraverse": "^4.1.1" 1160 | } 1161 | }, 1162 | "eslint-utils": { 1163 | "version": "1.4.3", 1164 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", 1165 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", 1166 | "dev": true, 1167 | "requires": { 1168 | "eslint-visitor-keys": "^1.1.0" 1169 | } 1170 | }, 1171 | "eslint-visitor-keys": { 1172 | "version": "1.3.0", 1173 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 1174 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 1175 | "dev": true 1176 | }, 1177 | "espree": { 1178 | "version": "6.2.1", 1179 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.2.1.tgz", 1180 | "integrity": "sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==", 1181 | "dev": true, 1182 | "requires": { 1183 | "acorn": "^7.1.1", 1184 | "acorn-jsx": "^5.2.0", 1185 | "eslint-visitor-keys": "^1.1.0" 1186 | } 1187 | }, 1188 | "esprima": { 1189 | "version": "4.0.1", 1190 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1191 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1192 | "dev": true 1193 | }, 1194 | "esquery": { 1195 | "version": "1.3.1", 1196 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 1197 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 1198 | "dev": true, 1199 | "requires": { 1200 | "estraverse": "^5.1.0" 1201 | }, 1202 | "dependencies": { 1203 | "estraverse": { 1204 | "version": "5.1.0", 1205 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.1.0.tgz", 1206 | "integrity": "sha512-FyohXK+R0vE+y1nHLoBM7ZTyqRpqAlhdZHCWIWEviFLiGB8b04H6bQs8G+XTthacvT8VuwvteiP7RJSxMs8UEw==", 1207 | "dev": true 1208 | } 1209 | } 1210 | }, 1211 | "esrecurse": { 1212 | "version": "4.2.1", 1213 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 1214 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 1215 | "dev": true, 1216 | "requires": { 1217 | "estraverse": "^4.1.0" 1218 | } 1219 | }, 1220 | "estraverse": { 1221 | "version": "4.3.0", 1222 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 1223 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 1224 | "dev": true 1225 | }, 1226 | "esutils": { 1227 | "version": "2.0.3", 1228 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1229 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1230 | "dev": true 1231 | }, 1232 | "event-emitter": { 1233 | "version": "0.3.5", 1234 | "resolved": "https://registry.npmjs.org/event-emitter/-/event-emitter-0.3.5.tgz", 1235 | "integrity": "sha1-34xp7vFkeSPHFXuc6DhAYQsCzDk=", 1236 | "requires": { 1237 | "d": "1", 1238 | "es5-ext": "~0.10.14" 1239 | } 1240 | }, 1241 | "events": { 1242 | "version": "1.1.1", 1243 | "resolved": "https://registry.npmjs.org/events/-/events-1.1.1.tgz", 1244 | "integrity": "sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ=" 1245 | }, 1246 | "ext": { 1247 | "version": "1.4.0", 1248 | "resolved": "https://registry.npmjs.org/ext/-/ext-1.4.0.tgz", 1249 | "integrity": "sha512-Key5NIsUxdqKg3vIsdw9dSuXpPCQ297y6wBjL30edxwPgt2E44WcWBZey/ZvUc6sERLTxKdyCu4gZFmUbk1Q7A==", 1250 | "requires": { 1251 | "type": "^2.0.0" 1252 | }, 1253 | "dependencies": { 1254 | "type": { 1255 | "version": "2.0.0", 1256 | "resolved": "https://registry.npmjs.org/type/-/type-2.0.0.tgz", 1257 | "integrity": "sha512-KBt58xCHry4Cejnc2ISQAF7QY+ORngsWfxezO68+12hKV6lQY8P/psIkcbjeHWn7MqcgciWJyCCevFMJdIXpow==" 1258 | } 1259 | } 1260 | }, 1261 | "external-editor": { 1262 | "version": "3.1.0", 1263 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 1264 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 1265 | "dev": true, 1266 | "requires": { 1267 | "chardet": "^0.7.0", 1268 | "iconv-lite": "^0.4.24", 1269 | "tmp": "^0.0.33" 1270 | } 1271 | }, 1272 | "fast-deep-equal": { 1273 | "version": "3.1.3", 1274 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1275 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1276 | "dev": true 1277 | }, 1278 | "fast-diff": { 1279 | "version": "1.2.0", 1280 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 1281 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 1282 | "dev": true 1283 | }, 1284 | "fast-json-stable-stringify": { 1285 | "version": "2.1.0", 1286 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1287 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1288 | "dev": true 1289 | }, 1290 | "fast-levenshtein": { 1291 | "version": "2.0.6", 1292 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1293 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 1294 | "dev": true 1295 | }, 1296 | "figures": { 1297 | "version": "3.2.0", 1298 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", 1299 | "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", 1300 | "dev": true, 1301 | "requires": { 1302 | "escape-string-regexp": "^1.0.5" 1303 | } 1304 | }, 1305 | "file-entry-cache": { 1306 | "version": "5.0.1", 1307 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 1308 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 1309 | "dev": true, 1310 | "requires": { 1311 | "flat-cache": "^2.0.1" 1312 | } 1313 | }, 1314 | "find-up": { 1315 | "version": "2.1.0", 1316 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 1317 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 1318 | "dev": true, 1319 | "requires": { 1320 | "locate-path": "^2.0.0" 1321 | } 1322 | }, 1323 | "flat-cache": { 1324 | "version": "2.0.1", 1325 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 1326 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 1327 | "dev": true, 1328 | "requires": { 1329 | "flatted": "^2.0.0", 1330 | "rimraf": "2.6.3", 1331 | "write": "1.0.3" 1332 | } 1333 | }, 1334 | "flatted": { 1335 | "version": "2.0.2", 1336 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz", 1337 | "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==", 1338 | "dev": true 1339 | }, 1340 | "follow-redirects": { 1341 | "version": "1.5.10", 1342 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.5.10.tgz", 1343 | "integrity": "sha512-0V5l4Cizzvqt5D44aTXbFZz+FtyXV1vrDN6qrelxtfYQKW0KO0W2T/hkE8xvGa/540LkZlkaUjO4ailYTFtHVQ==", 1344 | "requires": { 1345 | "debug": "=3.1.0" 1346 | } 1347 | }, 1348 | "fs.realpath": { 1349 | "version": "1.0.0", 1350 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1351 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1352 | "dev": true 1353 | }, 1354 | "function-bind": { 1355 | "version": "1.1.1", 1356 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1357 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1358 | "dev": true 1359 | }, 1360 | "functional-red-black-tree": { 1361 | "version": "1.0.1", 1362 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1363 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1364 | "dev": true 1365 | }, 1366 | "get-stdin": { 1367 | "version": "6.0.0", 1368 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-6.0.0.tgz", 1369 | "integrity": "sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g==", 1370 | "dev": true 1371 | }, 1372 | "glob": { 1373 | "version": "7.1.6", 1374 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1375 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1376 | "dev": true, 1377 | "requires": { 1378 | "fs.realpath": "^1.0.0", 1379 | "inflight": "^1.0.4", 1380 | "inherits": "2", 1381 | "minimatch": "^3.0.4", 1382 | "once": "^1.3.0", 1383 | "path-is-absolute": "^1.0.0" 1384 | } 1385 | }, 1386 | "glob-parent": { 1387 | "version": "5.1.1", 1388 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 1389 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 1390 | "dev": true, 1391 | "requires": { 1392 | "is-glob": "^4.0.1" 1393 | } 1394 | }, 1395 | "globals": { 1396 | "version": "11.12.0", 1397 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 1398 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 1399 | "dev": true 1400 | }, 1401 | "graceful-fs": { 1402 | "version": "4.2.4", 1403 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 1404 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==", 1405 | "dev": true 1406 | }, 1407 | "has": { 1408 | "version": "1.0.3", 1409 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1410 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1411 | "dev": true, 1412 | "requires": { 1413 | "function-bind": "^1.1.1" 1414 | } 1415 | }, 1416 | "has-flag": { 1417 | "version": "3.0.0", 1418 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1419 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1420 | "dev": true 1421 | }, 1422 | "has-symbols": { 1423 | "version": "1.0.1", 1424 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 1425 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 1426 | "dev": true 1427 | }, 1428 | "hosted-git-info": { 1429 | "version": "2.8.8", 1430 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.8.tgz", 1431 | "integrity": "sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg==", 1432 | "dev": true 1433 | }, 1434 | "iconv-lite": { 1435 | "version": "0.4.24", 1436 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1437 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1438 | "dev": true, 1439 | "requires": { 1440 | "safer-buffer": ">= 2.1.2 < 3" 1441 | } 1442 | }, 1443 | "ieee754": { 1444 | "version": "1.1.13", 1445 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.13.tgz", 1446 | "integrity": "sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg==" 1447 | }, 1448 | "ignore": { 1449 | "version": "4.0.6", 1450 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1451 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1452 | "dev": true 1453 | }, 1454 | "import-fresh": { 1455 | "version": "3.2.1", 1456 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 1457 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 1458 | "dev": true, 1459 | "requires": { 1460 | "parent-module": "^1.0.0", 1461 | "resolve-from": "^4.0.0" 1462 | } 1463 | }, 1464 | "imurmurhash": { 1465 | "version": "0.1.4", 1466 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1467 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1468 | "dev": true 1469 | }, 1470 | "inflight": { 1471 | "version": "1.0.6", 1472 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1473 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1474 | "dev": true, 1475 | "requires": { 1476 | "once": "^1.3.0", 1477 | "wrappy": "1" 1478 | } 1479 | }, 1480 | "inherits": { 1481 | "version": "2.0.4", 1482 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1483 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1484 | "dev": true 1485 | }, 1486 | "inquirer": { 1487 | "version": "7.3.2", 1488 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.3.2.tgz", 1489 | "integrity": "sha512-DF4osh1FM6l0RJc5YWYhSDB6TawiBRlbV9Cox8MWlidU218Tb7fm3lQTULyUJDfJ0tjbzl0W4q651mrCCEM55w==", 1490 | "dev": true, 1491 | "requires": { 1492 | "ansi-escapes": "^4.2.1", 1493 | "chalk": "^4.1.0", 1494 | "cli-cursor": "^3.1.0", 1495 | "cli-width": "^3.0.0", 1496 | "external-editor": "^3.0.3", 1497 | "figures": "^3.0.0", 1498 | "lodash": "^4.17.16", 1499 | "mute-stream": "0.0.8", 1500 | "run-async": "^2.4.0", 1501 | "rxjs": "^6.6.0", 1502 | "string-width": "^4.1.0", 1503 | "strip-ansi": "^6.0.0", 1504 | "through": "^2.3.6" 1505 | }, 1506 | "dependencies": { 1507 | "ansi-regex": { 1508 | "version": "5.0.0", 1509 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 1510 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 1511 | "dev": true 1512 | }, 1513 | "ansi-styles": { 1514 | "version": "4.2.1", 1515 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 1516 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 1517 | "dev": true, 1518 | "requires": { 1519 | "@types/color-name": "^1.1.1", 1520 | "color-convert": "^2.0.1" 1521 | } 1522 | }, 1523 | "chalk": { 1524 | "version": "4.1.0", 1525 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 1526 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 1527 | "dev": true, 1528 | "requires": { 1529 | "ansi-styles": "^4.1.0", 1530 | "supports-color": "^7.1.0" 1531 | } 1532 | }, 1533 | "color-convert": { 1534 | "version": "2.0.1", 1535 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1536 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1537 | "dev": true, 1538 | "requires": { 1539 | "color-name": "~1.1.4" 1540 | } 1541 | }, 1542 | "color-name": { 1543 | "version": "1.1.4", 1544 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1545 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1546 | "dev": true 1547 | }, 1548 | "has-flag": { 1549 | "version": "4.0.0", 1550 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1551 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1552 | "dev": true 1553 | }, 1554 | "strip-ansi": { 1555 | "version": "6.0.0", 1556 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1557 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1558 | "dev": true, 1559 | "requires": { 1560 | "ansi-regex": "^5.0.0" 1561 | } 1562 | }, 1563 | "supports-color": { 1564 | "version": "7.1.0", 1565 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 1566 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 1567 | "dev": true, 1568 | "requires": { 1569 | "has-flag": "^4.0.0" 1570 | } 1571 | } 1572 | } 1573 | }, 1574 | "internal-slot": { 1575 | "version": "1.0.2", 1576 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.2.tgz", 1577 | "integrity": "sha512-2cQNfwhAfJIkU4KZPkDI+Gj5yNNnbqi40W9Gge6dfnk4TocEVm00B3bdiL+JINrbGJil2TeHvM4rETGzk/f/0g==", 1578 | "dev": true, 1579 | "requires": { 1580 | "es-abstract": "^1.17.0-next.1", 1581 | "has": "^1.0.3", 1582 | "side-channel": "^1.0.2" 1583 | } 1584 | }, 1585 | "is-arrayish": { 1586 | "version": "0.2.1", 1587 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1588 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 1589 | "dev": true 1590 | }, 1591 | "is-callable": { 1592 | "version": "1.2.0", 1593 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.0.tgz", 1594 | "integrity": "sha512-pyVD9AaGLxtg6srb2Ng6ynWJqkHU9bEM087AKck0w8QwDarTfNcpIYoU8x8Hv2Icm8u6kFJM18Dag8lyqGkviw==", 1595 | "dev": true 1596 | }, 1597 | "is-class": { 1598 | "version": "0.0.9", 1599 | "resolved": "https://registry.npmjs.org/is-class/-/is-class-0.0.9.tgz", 1600 | "integrity": "sha512-kUfRnejcRC9YLgblxoJ76dp9gZ3vMKTrDS5I6z2UVMOsHHSImNKCJocjQTkZr38PwiSZ9LVklaHEENaVYeFTXg==" 1601 | }, 1602 | "is-date-object": { 1603 | "version": "1.0.2", 1604 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 1605 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==", 1606 | "dev": true 1607 | }, 1608 | "is-extglob": { 1609 | "version": "2.1.1", 1610 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1611 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1612 | "dev": true 1613 | }, 1614 | "is-fullwidth-code-point": { 1615 | "version": "3.0.0", 1616 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1617 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1618 | "dev": true 1619 | }, 1620 | "is-glob": { 1621 | "version": "4.0.1", 1622 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1623 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1624 | "dev": true, 1625 | "requires": { 1626 | "is-extglob": "^2.1.1" 1627 | } 1628 | }, 1629 | "is-promise": { 1630 | "version": "2.2.2", 1631 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.2.2.tgz", 1632 | "integrity": "sha512-+lP4/6lKUBfQjZ2pdxThZvLUAafmZb8OAxFb8XXtiQmS35INgr85hdOGoEs124ez1FCnZJt6jau/T+alh58QFQ==" 1633 | }, 1634 | "is-regex": { 1635 | "version": "1.1.0", 1636 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.0.tgz", 1637 | "integrity": "sha512-iI97M8KTWID2la5uYXlkbSDQIg4F6o1sYboZKKTDpnDQMLtUL86zxhgDet3Q2SriaYsyGqZ6Mn2SjbRKeLHdqw==", 1638 | "dev": true, 1639 | "requires": { 1640 | "has-symbols": "^1.0.1" 1641 | } 1642 | }, 1643 | "is-string": { 1644 | "version": "1.0.5", 1645 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.5.tgz", 1646 | "integrity": "sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ==", 1647 | "dev": true 1648 | }, 1649 | "is-symbol": { 1650 | "version": "1.0.3", 1651 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 1652 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 1653 | "dev": true, 1654 | "requires": { 1655 | "has-symbols": "^1.0.1" 1656 | } 1657 | }, 1658 | "isarray": { 1659 | "version": "1.0.0", 1660 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1661 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 1662 | }, 1663 | "isexe": { 1664 | "version": "2.0.0", 1665 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1666 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1667 | "dev": true 1668 | }, 1669 | "jmespath": { 1670 | "version": "0.15.0", 1671 | "resolved": "https://registry.npmjs.org/jmespath/-/jmespath-0.15.0.tgz", 1672 | "integrity": "sha1-o/Iiqarp+Wb10nx5ZRDigJF2Qhc=" 1673 | }, 1674 | "js-tokens": { 1675 | "version": "4.0.0", 1676 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1677 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1678 | "dev": true 1679 | }, 1680 | "js-yaml": { 1681 | "version": "3.14.0", 1682 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.0.tgz", 1683 | "integrity": "sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==", 1684 | "dev": true, 1685 | "requires": { 1686 | "argparse": "^1.0.7", 1687 | "esprima": "^4.0.0" 1688 | } 1689 | }, 1690 | "jsesc": { 1691 | "version": "2.5.2", 1692 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 1693 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 1694 | "dev": true 1695 | }, 1696 | "json-schema-traverse": { 1697 | "version": "0.4.1", 1698 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1699 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1700 | "dev": true 1701 | }, 1702 | "json-stable-stringify-without-jsonify": { 1703 | "version": "1.0.1", 1704 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1705 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1706 | "dev": true 1707 | }, 1708 | "json5": { 1709 | "version": "1.0.1", 1710 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", 1711 | "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", 1712 | "dev": true, 1713 | "requires": { 1714 | "minimist": "^1.2.0" 1715 | } 1716 | }, 1717 | "jsx-ast-utils": { 1718 | "version": "2.4.1", 1719 | "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-2.4.1.tgz", 1720 | "integrity": "sha512-z1xSldJ6imESSzOjd3NNkieVJKRlKYSOtMG8SFyCj2FIrvSaSuli/WjpBkEzCBoR9bYYYFgqJw61Xhu7Lcgk+w==", 1721 | "dev": true, 1722 | "requires": { 1723 | "array-includes": "^3.1.1", 1724 | "object.assign": "^4.1.0" 1725 | } 1726 | }, 1727 | "levn": { 1728 | "version": "0.3.0", 1729 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1730 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1731 | "dev": true, 1732 | "requires": { 1733 | "prelude-ls": "~1.1.2", 1734 | "type-check": "~0.3.2" 1735 | } 1736 | }, 1737 | "load-json-file": { 1738 | "version": "2.0.0", 1739 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 1740 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 1741 | "dev": true, 1742 | "requires": { 1743 | "graceful-fs": "^4.1.2", 1744 | "parse-json": "^2.2.0", 1745 | "pify": "^2.0.0", 1746 | "strip-bom": "^3.0.0" 1747 | } 1748 | }, 1749 | "locate-path": { 1750 | "version": "2.0.0", 1751 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1752 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1753 | "dev": true, 1754 | "requires": { 1755 | "p-locate": "^2.0.0", 1756 | "path-exists": "^3.0.0" 1757 | } 1758 | }, 1759 | "lodash": { 1760 | "version": "4.17.19", 1761 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.19.tgz", 1762 | "integrity": "sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ==", 1763 | "dev": true 1764 | }, 1765 | "loose-envify": { 1766 | "version": "1.4.0", 1767 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 1768 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 1769 | "dev": true, 1770 | "requires": { 1771 | "js-tokens": "^3.0.0 || ^4.0.0" 1772 | } 1773 | }, 1774 | "lru-queue": { 1775 | "version": "0.1.0", 1776 | "resolved": "https://registry.npmjs.org/lru-queue/-/lru-queue-0.1.0.tgz", 1777 | "integrity": "sha1-Jzi9nw089PhEkMVzbEhpmsYyzaM=", 1778 | "requires": { 1779 | "es5-ext": "~0.10.2" 1780 | } 1781 | }, 1782 | "memoizee": { 1783 | "version": "0.4.14", 1784 | "resolved": "https://registry.npmjs.org/memoizee/-/memoizee-0.4.14.tgz", 1785 | "integrity": "sha512-/SWFvWegAIYAO4NQMpcX+gcra0yEZu4OntmUdrBaWrJncxOqAziGFlHxc7yjKVK2uu3lpPW27P27wkR82wA8mg==", 1786 | "requires": { 1787 | "d": "1", 1788 | "es5-ext": "^0.10.45", 1789 | "es6-weak-map": "^2.0.2", 1790 | "event-emitter": "^0.3.5", 1791 | "is-promise": "^2.1", 1792 | "lru-queue": "0.1", 1793 | "next-tick": "1", 1794 | "timers-ext": "^0.1.5" 1795 | } 1796 | }, 1797 | "mimic-fn": { 1798 | "version": "2.1.0", 1799 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1800 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1801 | "dev": true 1802 | }, 1803 | "minimatch": { 1804 | "version": "3.0.4", 1805 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1806 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1807 | "dev": true, 1808 | "requires": { 1809 | "brace-expansion": "^1.1.7" 1810 | } 1811 | }, 1812 | "minimist": { 1813 | "version": "1.2.5", 1814 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1815 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1816 | "dev": true 1817 | }, 1818 | "mkdirp": { 1819 | "version": "0.5.5", 1820 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1821 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1822 | "dev": true, 1823 | "requires": { 1824 | "minimist": "^1.2.5" 1825 | } 1826 | }, 1827 | "ms": { 1828 | "version": "2.0.0", 1829 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1830 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1831 | }, 1832 | "mute-stream": { 1833 | "version": "0.0.8", 1834 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 1835 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 1836 | "dev": true 1837 | }, 1838 | "natural-compare": { 1839 | "version": "1.4.0", 1840 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1841 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1842 | "dev": true 1843 | }, 1844 | "next-tick": { 1845 | "version": "1.0.0", 1846 | "resolved": "https://registry.npmjs.org/next-tick/-/next-tick-1.0.0.tgz", 1847 | "integrity": "sha1-yobR/ogoFpsBICCOPchCS524NCw=" 1848 | }, 1849 | "nice-try": { 1850 | "version": "1.0.5", 1851 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1852 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1853 | "dev": true 1854 | }, 1855 | "normalize-package-data": { 1856 | "version": "2.5.0", 1857 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1858 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1859 | "dev": true, 1860 | "requires": { 1861 | "hosted-git-info": "^2.1.4", 1862 | "resolve": "^1.10.0", 1863 | "semver": "2 || 3 || 4 || 5", 1864 | "validate-npm-package-license": "^3.0.1" 1865 | }, 1866 | "dependencies": { 1867 | "semver": { 1868 | "version": "5.7.1", 1869 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1870 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1871 | "dev": true 1872 | } 1873 | } 1874 | }, 1875 | "object-assign": { 1876 | "version": "4.1.1", 1877 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1878 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1879 | "dev": true 1880 | }, 1881 | "object-inspect": { 1882 | "version": "1.8.0", 1883 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.8.0.tgz", 1884 | "integrity": "sha512-jLdtEOB112fORuypAyl/50VRVIBIdVQOSUUGQHzJ4xBSbit81zRarz7GThkEFZy1RceYrWYcPcBFPQwHyAc1gA==", 1885 | "dev": true 1886 | }, 1887 | "object-keys": { 1888 | "version": "1.1.1", 1889 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1890 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1891 | "dev": true 1892 | }, 1893 | "object.assign": { 1894 | "version": "4.1.0", 1895 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1896 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1897 | "dev": true, 1898 | "requires": { 1899 | "define-properties": "^1.1.2", 1900 | "function-bind": "^1.1.1", 1901 | "has-symbols": "^1.0.0", 1902 | "object-keys": "^1.0.11" 1903 | } 1904 | }, 1905 | "object.entries": { 1906 | "version": "1.1.2", 1907 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.2.tgz", 1908 | "integrity": "sha512-BQdB9qKmb/HyNdMNWVr7O3+z5MUIx3aiegEIJqjMBbBf0YT9RRxTJSim4mzFqtyr7PDAHigq0N9dO0m0tRakQA==", 1909 | "dev": true, 1910 | "requires": { 1911 | "define-properties": "^1.1.3", 1912 | "es-abstract": "^1.17.5", 1913 | "has": "^1.0.3" 1914 | } 1915 | }, 1916 | "object.fromentries": { 1917 | "version": "2.0.2", 1918 | "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.2.tgz", 1919 | "integrity": "sha512-r3ZiBH7MQppDJVLx6fhD618GKNG40CZYH9wgwdhKxBDDbQgjeWGGd4AtkZad84d291YxvWe7bJGuE65Anh0dxQ==", 1920 | "dev": true, 1921 | "requires": { 1922 | "define-properties": "^1.1.3", 1923 | "es-abstract": "^1.17.0-next.1", 1924 | "function-bind": "^1.1.1", 1925 | "has": "^1.0.3" 1926 | } 1927 | }, 1928 | "object.values": { 1929 | "version": "1.1.1", 1930 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.1.tgz", 1931 | "integrity": "sha512-WTa54g2K8iu0kmS/us18jEmdv1a4Wi//BZ/DTVYEcH0XhLM5NYdpDHja3gt57VrZLcNAO2WGA+KpWsDBaHt6eA==", 1932 | "dev": true, 1933 | "requires": { 1934 | "define-properties": "^1.1.3", 1935 | "es-abstract": "^1.17.0-next.1", 1936 | "function-bind": "^1.1.1", 1937 | "has": "^1.0.3" 1938 | } 1939 | }, 1940 | "once": { 1941 | "version": "1.4.0", 1942 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1943 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1944 | "dev": true, 1945 | "requires": { 1946 | "wrappy": "1" 1947 | } 1948 | }, 1949 | "onetime": { 1950 | "version": "5.1.0", 1951 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 1952 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 1953 | "dev": true, 1954 | "requires": { 1955 | "mimic-fn": "^2.1.0" 1956 | } 1957 | }, 1958 | "optionator": { 1959 | "version": "0.8.3", 1960 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", 1961 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 1962 | "dev": true, 1963 | "requires": { 1964 | "deep-is": "~0.1.3", 1965 | "fast-levenshtein": "~2.0.6", 1966 | "levn": "~0.3.0", 1967 | "prelude-ls": "~1.1.2", 1968 | "type-check": "~0.3.2", 1969 | "word-wrap": "~1.2.3" 1970 | } 1971 | }, 1972 | "os-tmpdir": { 1973 | "version": "1.0.2", 1974 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1975 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1976 | "dev": true 1977 | }, 1978 | "p-limit": { 1979 | "version": "1.3.0", 1980 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1981 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1982 | "dev": true, 1983 | "requires": { 1984 | "p-try": "^1.0.0" 1985 | } 1986 | }, 1987 | "p-locate": { 1988 | "version": "2.0.0", 1989 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1990 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1991 | "dev": true, 1992 | "requires": { 1993 | "p-limit": "^1.1.0" 1994 | } 1995 | }, 1996 | "p-try": { 1997 | "version": "1.0.0", 1998 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1999 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 2000 | "dev": true 2001 | }, 2002 | "parent-module": { 2003 | "version": "1.0.1", 2004 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2005 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2006 | "dev": true, 2007 | "requires": { 2008 | "callsites": "^3.0.0" 2009 | } 2010 | }, 2011 | "parse-json": { 2012 | "version": "2.2.0", 2013 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 2014 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 2015 | "dev": true, 2016 | "requires": { 2017 | "error-ex": "^1.2.0" 2018 | } 2019 | }, 2020 | "path-exists": { 2021 | "version": "3.0.0", 2022 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2023 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2024 | "dev": true 2025 | }, 2026 | "path-is-absolute": { 2027 | "version": "1.0.1", 2028 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2029 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2030 | "dev": true 2031 | }, 2032 | "path-key": { 2033 | "version": "2.0.1", 2034 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 2035 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 2036 | "dev": true 2037 | }, 2038 | "path-parse": { 2039 | "version": "1.0.6", 2040 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 2041 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 2042 | "dev": true 2043 | }, 2044 | "path-type": { 2045 | "version": "2.0.0", 2046 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 2047 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 2048 | "dev": true, 2049 | "requires": { 2050 | "pify": "^2.0.0" 2051 | } 2052 | }, 2053 | "pify": { 2054 | "version": "2.3.0", 2055 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 2056 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 2057 | "dev": true 2058 | }, 2059 | "pkg-dir": { 2060 | "version": "2.0.0", 2061 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", 2062 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", 2063 | "dev": true, 2064 | "requires": { 2065 | "find-up": "^2.1.0" 2066 | } 2067 | }, 2068 | "prelude-ls": { 2069 | "version": "1.1.2", 2070 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 2071 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 2072 | "dev": true 2073 | }, 2074 | "prettier": { 2075 | "version": "2.0.5", 2076 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.0.5.tgz", 2077 | "integrity": "sha512-7PtVymN48hGcO4fGjybyBSIWDsLU4H4XlvOHfq91pz9kkGlonzwTfYkaIEwiRg/dAJF9YlbsduBAgtYLi+8cFg==", 2078 | "dev": true 2079 | }, 2080 | "prettier-linter-helpers": { 2081 | "version": "1.0.0", 2082 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 2083 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 2084 | "dev": true, 2085 | "requires": { 2086 | "fast-diff": "^1.1.2" 2087 | } 2088 | }, 2089 | "progress": { 2090 | "version": "2.0.3", 2091 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2092 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 2093 | "dev": true 2094 | }, 2095 | "prop-types": { 2096 | "version": "15.7.2", 2097 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.7.2.tgz", 2098 | "integrity": "sha512-8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ==", 2099 | "dev": true, 2100 | "requires": { 2101 | "loose-envify": "^1.4.0", 2102 | "object-assign": "^4.1.1", 2103 | "react-is": "^16.8.1" 2104 | } 2105 | }, 2106 | "punycode": { 2107 | "version": "1.3.2", 2108 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", 2109 | "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=" 2110 | }, 2111 | "querystring": { 2112 | "version": "0.2.0", 2113 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", 2114 | "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=" 2115 | }, 2116 | "react-is": { 2117 | "version": "16.13.1", 2118 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", 2119 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", 2120 | "dev": true 2121 | }, 2122 | "read-pkg": { 2123 | "version": "2.0.0", 2124 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 2125 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 2126 | "dev": true, 2127 | "requires": { 2128 | "load-json-file": "^2.0.0", 2129 | "normalize-package-data": "^2.3.2", 2130 | "path-type": "^2.0.0" 2131 | } 2132 | }, 2133 | "read-pkg-up": { 2134 | "version": "2.0.0", 2135 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 2136 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 2137 | "dev": true, 2138 | "requires": { 2139 | "find-up": "^2.0.0", 2140 | "read-pkg": "^2.0.0" 2141 | } 2142 | }, 2143 | "reflect-metadata": { 2144 | "version": "0.1.13", 2145 | "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz", 2146 | "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" 2147 | }, 2148 | "regexp.prototype.flags": { 2149 | "version": "1.3.0", 2150 | "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.3.0.tgz", 2151 | "integrity": "sha512-2+Q0C5g951OlYlJz6yu5/M33IcsESLlLfsyIaLJaG4FA2r4yP8MvVMJUUP/fVBkSpbbbZlS5gynbEWLipiiXiQ==", 2152 | "dev": true, 2153 | "requires": { 2154 | "define-properties": "^1.1.3", 2155 | "es-abstract": "^1.17.0-next.1" 2156 | } 2157 | }, 2158 | "regexpp": { 2159 | "version": "2.0.1", 2160 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 2161 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 2162 | "dev": true 2163 | }, 2164 | "resolve": { 2165 | "version": "1.17.0", 2166 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz", 2167 | "integrity": "sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==", 2168 | "dev": true, 2169 | "requires": { 2170 | "path-parse": "^1.0.6" 2171 | } 2172 | }, 2173 | "resolve-from": { 2174 | "version": "4.0.0", 2175 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2176 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2177 | "dev": true 2178 | }, 2179 | "restore-cursor": { 2180 | "version": "3.1.0", 2181 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 2182 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 2183 | "dev": true, 2184 | "requires": { 2185 | "onetime": "^5.1.0", 2186 | "signal-exit": "^3.0.2" 2187 | } 2188 | }, 2189 | "rimraf": { 2190 | "version": "2.6.3", 2191 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 2192 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 2193 | "dev": true, 2194 | "requires": { 2195 | "glob": "^7.1.3" 2196 | } 2197 | }, 2198 | "run-async": { 2199 | "version": "2.4.1", 2200 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.1.tgz", 2201 | "integrity": "sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==", 2202 | "dev": true 2203 | }, 2204 | "rxjs": { 2205 | "version": "6.6.0", 2206 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.6.0.tgz", 2207 | "integrity": "sha512-3HMA8z/Oz61DUHe+SdOiQyzIf4tOx5oQHmMir7IZEu6TMqCLHT4LRcmNaUS0NwOz8VLvmmBduMsoaUvMaIiqzg==", 2208 | "dev": true, 2209 | "requires": { 2210 | "tslib": "^1.9.0" 2211 | } 2212 | }, 2213 | "safer-buffer": { 2214 | "version": "2.1.2", 2215 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2216 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 2217 | "dev": true 2218 | }, 2219 | "sax": { 2220 | "version": "1.2.1", 2221 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.1.tgz", 2222 | "integrity": "sha1-e45lYZCyKOgaZq6nSEgNgozS03o=" 2223 | }, 2224 | "semver": { 2225 | "version": "6.3.0", 2226 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2227 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 2228 | "dev": true 2229 | }, 2230 | "shebang-command": { 2231 | "version": "1.2.0", 2232 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2233 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2234 | "dev": true, 2235 | "requires": { 2236 | "shebang-regex": "^1.0.0" 2237 | } 2238 | }, 2239 | "shebang-regex": { 2240 | "version": "1.0.0", 2241 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2242 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2243 | "dev": true 2244 | }, 2245 | "side-channel": { 2246 | "version": "1.0.2", 2247 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.2.tgz", 2248 | "integrity": "sha512-7rL9YlPHg7Ancea1S96Pa8/QWb4BtXL/TZvS6B8XFetGBeuhAsfmUspK6DokBeZ64+Kj9TCNRD/30pVz1BvQNA==", 2249 | "dev": true, 2250 | "requires": { 2251 | "es-abstract": "^1.17.0-next.1", 2252 | "object-inspect": "^1.7.0" 2253 | } 2254 | }, 2255 | "signal-exit": { 2256 | "version": "3.0.3", 2257 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 2258 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 2259 | "dev": true 2260 | }, 2261 | "slice-ansi": { 2262 | "version": "2.1.0", 2263 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 2264 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 2265 | "dev": true, 2266 | "requires": { 2267 | "ansi-styles": "^3.2.0", 2268 | "astral-regex": "^1.0.0", 2269 | "is-fullwidth-code-point": "^2.0.0" 2270 | }, 2271 | "dependencies": { 2272 | "is-fullwidth-code-point": { 2273 | "version": "2.0.0", 2274 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2275 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2276 | "dev": true 2277 | } 2278 | } 2279 | }, 2280 | "source-map": { 2281 | "version": "0.5.7", 2282 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2283 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 2284 | "dev": true 2285 | }, 2286 | "spdx-correct": { 2287 | "version": "3.1.1", 2288 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", 2289 | "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", 2290 | "dev": true, 2291 | "requires": { 2292 | "spdx-expression-parse": "^3.0.0", 2293 | "spdx-license-ids": "^3.0.0" 2294 | } 2295 | }, 2296 | "spdx-exceptions": { 2297 | "version": "2.3.0", 2298 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 2299 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", 2300 | "dev": true 2301 | }, 2302 | "spdx-expression-parse": { 2303 | "version": "3.0.1", 2304 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 2305 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 2306 | "dev": true, 2307 | "requires": { 2308 | "spdx-exceptions": "^2.1.0", 2309 | "spdx-license-ids": "^3.0.0" 2310 | } 2311 | }, 2312 | "spdx-license-ids": { 2313 | "version": "3.0.5", 2314 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz", 2315 | "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==", 2316 | "dev": true 2317 | }, 2318 | "sprintf-js": { 2319 | "version": "1.0.3", 2320 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2321 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2322 | "dev": true 2323 | }, 2324 | "string-width": { 2325 | "version": "4.2.0", 2326 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 2327 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 2328 | "dev": true, 2329 | "requires": { 2330 | "emoji-regex": "^8.0.0", 2331 | "is-fullwidth-code-point": "^3.0.0", 2332 | "strip-ansi": "^6.0.0" 2333 | }, 2334 | "dependencies": { 2335 | "ansi-regex": { 2336 | "version": "5.0.0", 2337 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 2338 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 2339 | "dev": true 2340 | }, 2341 | "strip-ansi": { 2342 | "version": "6.0.0", 2343 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 2344 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 2345 | "dev": true, 2346 | "requires": { 2347 | "ansi-regex": "^5.0.0" 2348 | } 2349 | } 2350 | } 2351 | }, 2352 | "string.prototype.matchall": { 2353 | "version": "4.0.2", 2354 | "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.2.tgz", 2355 | "integrity": "sha512-N/jp6O5fMf9os0JU3E72Qhf590RSRZU/ungsL/qJUYVTNv7hTG0P/dbPjxINVN9jpscu3nzYwKESU3P3RY5tOg==", 2356 | "dev": true, 2357 | "requires": { 2358 | "define-properties": "^1.1.3", 2359 | "es-abstract": "^1.17.0", 2360 | "has-symbols": "^1.0.1", 2361 | "internal-slot": "^1.0.2", 2362 | "regexp.prototype.flags": "^1.3.0", 2363 | "side-channel": "^1.0.2" 2364 | } 2365 | }, 2366 | "string.prototype.trimend": { 2367 | "version": "1.0.1", 2368 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz", 2369 | "integrity": "sha512-LRPxFUaTtpqYsTeNKaFOw3R4bxIzWOnbQ837QfBylo8jIxtcbK/A/sMV7Q+OAV/vWo+7s25pOE10KYSjaSO06g==", 2370 | "dev": true, 2371 | "requires": { 2372 | "define-properties": "^1.1.3", 2373 | "es-abstract": "^1.17.5" 2374 | } 2375 | }, 2376 | "string.prototype.trimstart": { 2377 | "version": "1.0.1", 2378 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz", 2379 | "integrity": "sha512-XxZn+QpvrBI1FOcg6dIpxUPgWCPuNXvMD72aaRaUQv1eD4e/Qy8i/hFTe0BUmD60p/QA6bh1avmuPTfNjqVWRw==", 2380 | "dev": true, 2381 | "requires": { 2382 | "define-properties": "^1.1.3", 2383 | "es-abstract": "^1.17.5" 2384 | } 2385 | }, 2386 | "strip-ansi": { 2387 | "version": "5.2.0", 2388 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2389 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2390 | "dev": true, 2391 | "requires": { 2392 | "ansi-regex": "^4.1.0" 2393 | }, 2394 | "dependencies": { 2395 | "ansi-regex": { 2396 | "version": "4.1.0", 2397 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2398 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2399 | "dev": true 2400 | } 2401 | } 2402 | }, 2403 | "strip-bom": { 2404 | "version": "3.0.0", 2405 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2406 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2407 | "dev": true 2408 | }, 2409 | "strip-json-comments": { 2410 | "version": "3.1.1", 2411 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2412 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2413 | "dev": true 2414 | }, 2415 | "supports-color": { 2416 | "version": "5.5.0", 2417 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2418 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2419 | "dev": true, 2420 | "requires": { 2421 | "has-flag": "^3.0.0" 2422 | } 2423 | }, 2424 | "table": { 2425 | "version": "5.4.6", 2426 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 2427 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 2428 | "dev": true, 2429 | "requires": { 2430 | "ajv": "^6.10.2", 2431 | "lodash": "^4.17.14", 2432 | "slice-ansi": "^2.1.0", 2433 | "string-width": "^3.0.0" 2434 | }, 2435 | "dependencies": { 2436 | "emoji-regex": { 2437 | "version": "7.0.3", 2438 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 2439 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 2440 | "dev": true 2441 | }, 2442 | "is-fullwidth-code-point": { 2443 | "version": "2.0.0", 2444 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2445 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2446 | "dev": true 2447 | }, 2448 | "string-width": { 2449 | "version": "3.1.0", 2450 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2451 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2452 | "dev": true, 2453 | "requires": { 2454 | "emoji-regex": "^7.0.1", 2455 | "is-fullwidth-code-point": "^2.0.0", 2456 | "strip-ansi": "^5.1.0" 2457 | } 2458 | } 2459 | } 2460 | }, 2461 | "text-table": { 2462 | "version": "0.2.0", 2463 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2464 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2465 | "dev": true 2466 | }, 2467 | "through": { 2468 | "version": "2.3.8", 2469 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2470 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2471 | "dev": true 2472 | }, 2473 | "timers-ext": { 2474 | "version": "0.1.7", 2475 | "resolved": "https://registry.npmjs.org/timers-ext/-/timers-ext-0.1.7.tgz", 2476 | "integrity": "sha512-b85NUNzTSdodShTIbky6ZF02e8STtVVfD+fu4aXXShEELpozH+bCpJLYMPZbsABN2wDH7fJpqIoXxJpzbf0NqQ==", 2477 | "requires": { 2478 | "es5-ext": "~0.10.46", 2479 | "next-tick": "1" 2480 | } 2481 | }, 2482 | "tmp": { 2483 | "version": "0.0.33", 2484 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 2485 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 2486 | "dev": true, 2487 | "requires": { 2488 | "os-tmpdir": "~1.0.2" 2489 | } 2490 | }, 2491 | "to-fast-properties": { 2492 | "version": "2.0.0", 2493 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 2494 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 2495 | "dev": true 2496 | }, 2497 | "tsconfig-paths": { 2498 | "version": "3.9.0", 2499 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.9.0.tgz", 2500 | "integrity": "sha512-dRcuzokWhajtZWkQsDVKbWyY+jgcLC5sqJhg2PSgf4ZkH2aHPvaOY8YWGhmjb68b5qqTfasSsDO9k7RUiEmZAw==", 2501 | "dev": true, 2502 | "requires": { 2503 | "@types/json5": "^0.0.29", 2504 | "json5": "^1.0.1", 2505 | "minimist": "^1.2.0", 2506 | "strip-bom": "^3.0.0" 2507 | } 2508 | }, 2509 | "tslib": { 2510 | "version": "1.13.0", 2511 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.13.0.tgz", 2512 | "integrity": "sha512-i/6DQjL8Xf3be4K/E6Wgpekn5Qasl1usyw++dAA35Ue5orEn65VIxOA+YvNNl9HV3qv70T7CNwjODHZrLwvd1Q==" 2513 | }, 2514 | "type": { 2515 | "version": "1.2.0", 2516 | "resolved": "https://registry.npmjs.org/type/-/type-1.2.0.tgz", 2517 | "integrity": "sha512-+5nt5AAniqsCnu2cEQQdpzCAh33kVx8n0VoFidKpB1dVVLAN/F+bgVOqOJqOnEnrhp222clB5p3vUlD+1QAnfg==" 2518 | }, 2519 | "type-check": { 2520 | "version": "0.3.2", 2521 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 2522 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 2523 | "dev": true, 2524 | "requires": { 2525 | "prelude-ls": "~1.1.2" 2526 | } 2527 | }, 2528 | "type-fest": { 2529 | "version": "0.8.1", 2530 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 2531 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 2532 | "dev": true 2533 | }, 2534 | "typescript": { 2535 | "version": "3.9.6", 2536 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.9.6.tgz", 2537 | "integrity": "sha512-Pspx3oKAPJtjNwE92YS05HQoY7z2SFyOpHo9MqJor3BXAGNaPUs83CuVp9VISFkSjyRfiTpmKuAYGJB7S7hOxw==", 2538 | "dev": true 2539 | }, 2540 | "uri-js": { 2541 | "version": "4.2.2", 2542 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2543 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2544 | "dev": true, 2545 | "requires": { 2546 | "punycode": "^2.1.0" 2547 | }, 2548 | "dependencies": { 2549 | "punycode": { 2550 | "version": "2.1.1", 2551 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2552 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2553 | "dev": true 2554 | } 2555 | } 2556 | }, 2557 | "url": { 2558 | "version": "0.10.3", 2559 | "resolved": "https://registry.npmjs.org/url/-/url-0.10.3.tgz", 2560 | "integrity": "sha1-Ah5NnHcF8hu/N9A861h2dAJ3TGQ=", 2561 | "requires": { 2562 | "punycode": "1.3.2", 2563 | "querystring": "0.2.0" 2564 | } 2565 | }, 2566 | "utf8-bytes": { 2567 | "version": "0.0.1", 2568 | "resolved": "https://registry.npmjs.org/utf8-bytes/-/utf8-bytes-0.0.1.tgz", 2569 | "integrity": "sha1-EWsCVEjJtQAIHN+/H01sbDfYg30=" 2570 | }, 2571 | "uuid": { 2572 | "version": "3.4.0", 2573 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 2574 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==" 2575 | }, 2576 | "v8-compile-cache": { 2577 | "version": "2.1.1", 2578 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.1.tgz", 2579 | "integrity": "sha512-8OQ9CL+VWyt3JStj7HX7/ciTL2V3Rl1Wf5OL+SNTm0yK1KvtReVulksyeRnCANHHuUxHlQig+JJDlUhBt1NQDQ==", 2580 | "dev": true 2581 | }, 2582 | "validate-npm-package-license": { 2583 | "version": "3.0.4", 2584 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 2585 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 2586 | "dev": true, 2587 | "requires": { 2588 | "spdx-correct": "^3.0.0", 2589 | "spdx-expression-parse": "^3.0.0" 2590 | } 2591 | }, 2592 | "which": { 2593 | "version": "1.3.1", 2594 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2595 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2596 | "dev": true, 2597 | "requires": { 2598 | "isexe": "^2.0.0" 2599 | } 2600 | }, 2601 | "word-wrap": { 2602 | "version": "1.2.3", 2603 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2604 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2605 | "dev": true 2606 | }, 2607 | "wrappy": { 2608 | "version": "1.0.2", 2609 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2610 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2611 | "dev": true 2612 | }, 2613 | "write": { 2614 | "version": "1.0.3", 2615 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 2616 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 2617 | "dev": true, 2618 | "requires": { 2619 | "mkdirp": "^0.5.1" 2620 | } 2621 | }, 2622 | "xml2js": { 2623 | "version": "0.4.19", 2624 | "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.19.tgz", 2625 | "integrity": "sha512-esZnJZJOiJR9wWKMyuvSE1y6Dq5LCuJanqhxslH2bxM6duahNZ+HMpCLhBQGZkbX6xRf8x1Y2eJlgt2q3qo49Q==", 2626 | "requires": { 2627 | "sax": ">=0.6.0", 2628 | "xmlbuilder": "~9.0.1" 2629 | } 2630 | }, 2631 | "xmlbuilder": { 2632 | "version": "9.0.7", 2633 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-9.0.7.tgz", 2634 | "integrity": "sha1-Ey7mPS7FVlxVfiD0wi35rKaGsQ0=" 2635 | } 2636 | } 2637 | } 2638 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@skypress/nestjs-dynamodb", 3 | "version": "0.1.1", 4 | "description": "NestJS DynamoDB Client ", 5 | "main": "dist/index.js", 6 | "scripts": { 7 | "build": "rm -rf dist && tsc -p tsconfig.json", 8 | "test": "echo \"Error: no test specified\" && exit 1", 9 | "prepublishOnly": "npm run build", 10 | "publish": "npm publish --access public" 11 | }, 12 | "author": "BMO ", 13 | "license": "MIT", 14 | "private": false, 15 | "devDependencies": { 16 | "babel-eslint": "^10.0.3", 17 | "eslint": "^6.8.0", 18 | "eslint-config-prettier": "^6.9.0", 19 | "eslint-config-rokket-labs": "^0.1.4", 20 | "eslint-plugin-import": "^2.20.0", 21 | "eslint-plugin-prettier": "^3.1.2", 22 | "typescript": "^3.8.2" 23 | }, 24 | "peerDependencies": { 25 | "@aws/dynamodb-data-mapper": "^0.7.3", 26 | "@aws/dynamodb-data-mapper-annotations": "^0.7.3", 27 | "@aws/dynamodb-data-marshaller": "^0.7.3", 28 | "@nestjs/common": "^7.6.13" 29 | }, 30 | "dependencies": { 31 | "@aws/dynamodb-data-mapper": "^0.7.3", 32 | "@aws/dynamodb-data-mapper-annotations": "^0.7.3", 33 | "@aws/dynamodb-data-marshaller": "^0.7.3", 34 | "@nestjs/common": "^7.6.13", 35 | "aws-sdk": "^2.624.0", 36 | "is-class": "^0.0.9", 37 | "reflect-metadata": "^0.1.13" 38 | }, 39 | "repository": { 40 | "type": "git", 41 | "url": "git+https://github.com/SkyPressATX/nestjs-dynamodb.git" 42 | }, 43 | "bugs": { 44 | "url": "https://github.com/SkyPressATX/nestjs-dynamodb/issues" 45 | }, 46 | "homepage": "https://github.com/SkyPressATX/nestjs-dynamodb#readme" 47 | } 48 | -------------------------------------------------------------------------------- /prettier.config.js: -------------------------------------------------------------------------------- 1 | module.exports = require('eslint-config-rokket-labs/prettier') 2 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | export { DynamoDBModule } from './module/dynamodb.module' 2 | export { InjectModel, ReturnModel } from './module/dynamodb.decorators' 3 | export { 4 | attribute as Attribute, 5 | hashKey as HashKey, 6 | rangeKey as RangeKey, 7 | table as Table, 8 | autoGeneratedHashKey as AutoGeneratedHashKey, 9 | versionAttribute as VersionAttribute, 10 | } from '@aws/dynamodb-data-mapper-annotations' 11 | -------------------------------------------------------------------------------- /src/module/dynamodb.config.ts: -------------------------------------------------------------------------------- 1 | import * as DynamoDB from 'aws-sdk/clients/dynamodb' 2 | import * as AWS from 'aws-sdk' 3 | import { DataMapper } from '@aws/dynamodb-data-mapper' 4 | import { DynamoDBModuleOptions } from './dynamodb.interfaces' 5 | 6 | export const createDynamodbClient = (options: DynamoDBModuleOptions): DynamoDB => { 7 | AWS.config.update(options.AWSConfig) 8 | return new DynamoDB(options.dynamoDBOptions) 9 | } 10 | 11 | export const createMapper = (dynamoDBClient: DynamoDB): DataMapper => 12 | new DataMapper({ 13 | client: dynamoDBClient // the SDK client used to execute operations 14 | }) 15 | -------------------------------------------------------------------------------- /src/module/dynamodb.constants.ts: -------------------------------------------------------------------------------- 1 | export const DYNAMO_DB_CLIENT = Symbol('DYNAMO_DB_CONNECTION') 2 | export const DYNAMO_DB_DATA_MAPPER = Symbol('DYNAMO_DB_DATA_MAPPER') 3 | export const DYNAMO_DB_MODULE_OPTIONS = Symbol('DYNAMO_DB_MODULE_OPTIONS') 4 | -------------------------------------------------------------------------------- /src/module/dynamodb.coremodule.ts: -------------------------------------------------------------------------------- 1 | import { Module, Global, Inject, DynamicModule, Provider } from '@nestjs/common' 2 | import { DynamoDBModuleAsyncOptions, DynamoDBModuleOptions } from './dynamodb.interfaces' 3 | import { DynamoDB } from 'aws-sdk' 4 | import { DataMapper } from '@aws/dynamodb-data-mapper' 5 | import { DYNAMO_DB_CLIENT, DYNAMO_DB_DATA_MAPPER, DYNAMO_DB_MODULE_OPTIONS } from './dynamodb.constants' 6 | import { createMapper, createDynamodbClient } from './dynamodb.config' 7 | 8 | @Global() 9 | @Module({}) 10 | export class DynamoDBCoreModule { 11 | constructor( 12 | @Inject(DYNAMO_DB_CLIENT) private readonly dynamoDBClient: DynamoDB, 13 | @Inject(DYNAMO_DB_DATA_MAPPER) 14 | private readonly dynamoDBDataMapper: DataMapper 15 | ) {} 16 | 17 | static forRoot(options: DynamoDBModuleOptions): DynamicModule { 18 | const dynamodbClient = createDynamodbClient(options) 19 | 20 | const mapper = createMapper(dynamodbClient) 21 | 22 | const clientProvider = { 23 | provide: DYNAMO_DB_CLIENT, 24 | useValue: dynamodbClient 25 | } 26 | 27 | const dataMapperProvider = { 28 | provide: DYNAMO_DB_DATA_MAPPER, 29 | useValue: mapper 30 | } 31 | 32 | return { 33 | module: DynamoDBCoreModule, 34 | providers: [dataMapperProvider, clientProvider], 35 | exports: [dataMapperProvider, clientProvider] 36 | } 37 | } 38 | 39 | static forRootAsync(options: DynamoDBModuleAsyncOptions): DynamicModule { 40 | const clientProvider = { 41 | provide: DYNAMO_DB_CLIENT, 42 | useFactory: (dynamoDBModuleOptions: DynamoDBModuleOptions): DynamoDB => createDynamodbClient(dynamoDBModuleOptions), 43 | inject: [DYNAMO_DB_MODULE_OPTIONS] // inject output of async config creator 44 | } 45 | const dataMapperProvider = { 46 | provide: DYNAMO_DB_DATA_MAPPER, 47 | useFactory: (dynamoDB: DynamoDB): DataMapper => createMapper(dynamoDB), 48 | inject: [DYNAMO_DB_CLIENT] // inject output of async config creator 49 | } 50 | 51 | const asyncProviders = this.createAsyncProviders(options) 52 | 53 | return { 54 | module: DynamoDBCoreModule, 55 | imports: options.imports, // imports from async for root 56 | providers: [...asyncProviders, dataMapperProvider, clientProvider], 57 | exports: [dataMapperProvider, clientProvider] 58 | } 59 | } 60 | 61 | private static createAsyncProviders(options: DynamoDBModuleAsyncOptions): Provider[] { 62 | if (options.useExisting || options.useFactory) return [this.createAsyncOptionsProvider(options)] 63 | 64 | return [ 65 | this.createAsyncOptionsProvider(options), 66 | { 67 | provide: options.useClass!, 68 | useClass: options.useClass! 69 | } 70 | ] 71 | } 72 | 73 | private static createAsyncOptionsProvider(options: DynamoDBModuleAsyncOptions): Provider { 74 | if (options.useFactory) 75 | return { 76 | provide: DYNAMO_DB_MODULE_OPTIONS, 77 | useFactory: options.useFactory, 78 | inject: options.inject || [] 79 | } 80 | return { provide: DYNAMO_DB_MODULE_OPTIONS, useFactory: () => {}, inject: [] } 81 | } 82 | } 83 | -------------------------------------------------------------------------------- /src/module/dynamodb.decorators.ts: -------------------------------------------------------------------------------- 1 | import { Inject } from '@nestjs/common' 2 | import { getModelToken, getModelForClass } from '../util' 3 | import { DynamoDBClass } from './dynamodb.interfaces' 4 | 5 | export const InjectModel = (model: DynamoDBClass) => 6 | Inject(getModelToken(model.name)) 7 | 8 | export const ReturnModel = (v?: any) => 9 | (false as true) && getModelForClass(v, v, v, v) 10 | -------------------------------------------------------------------------------- /src/module/dynamodb.interfaces.ts: -------------------------------------------------------------------------------- 1 | import { Type } from '@nestjs/common' 2 | import { ModuleMetadata } from '@nestjs/common/interfaces' 3 | import { ConfigurationOptions, DynamoDB } from 'aws-sdk' 4 | import { APIVersions } from 'aws-sdk/lib/config' 5 | import { ConfigurationServicePlaceholders } from 'aws-sdk/lib/config_service_placeholders' 6 | import { CreateTableOptions } from '@aws/dynamodb-data-mapper' 7 | 8 | export interface DynamoDBClass { 9 | new (...args: any[]) 10 | } 11 | 12 | export interface DynamoDBClassWithOptions { 13 | tableOptions: CreateTableOptions 14 | dynamoDBClass: DynamoDBClass 15 | } 16 | 17 | export type DynamoDBInput = DynamoDBClass | DynamoDBClassWithOptions 18 | 19 | export interface DynamoDBModuleOptions { 20 | dynamoDBOptions: DynamoDB.ClientConfiguration 21 | AWSConfig: Partial< 22 | ConfigurationOptions & ConfigurationServicePlaceholders & APIVersions 23 | > 24 | } 25 | 26 | export interface DynamoDBOptionsFactory { 27 | createTypegooseOptions(): 28 | | Promise 29 | | DynamoDBModuleOptions 30 | } 31 | 32 | export interface DynamoDBModuleAsyncOptions 33 | extends Pick { 34 | connectionName?: string 35 | useExisting?: Type 36 | useClass?: Type 37 | useFactory?: ( 38 | ...args: any[] 39 | ) => Promise | DynamoDBModuleOptions 40 | inject?: any[] 41 | } 42 | -------------------------------------------------------------------------------- /src/module/dynamodb.module.ts: -------------------------------------------------------------------------------- 1 | import { DynamicModule, Module } from '@nestjs/common' 2 | 3 | import { convertToClassWithOptions } from '../util/convertToClassWithOptions' 4 | import { DynamoDBCoreModule } from './dynamodb.coremodule' 5 | import { 6 | DynamoDBModuleAsyncOptions, 7 | DynamoDBModuleOptions, 8 | DynamoDBInput, 9 | } from './dynamodb.interfaces' 10 | import { createDynamoDBProvider } from './dynamodb.providers' 11 | 12 | @Module({}) 13 | export class DynamoDBModule { 14 | static forRoot(options: DynamoDBModuleOptions): DynamicModule { 15 | return { 16 | module: DynamoDBModule, 17 | imports: [DynamoDBCoreModule.forRoot(options)], 18 | } 19 | } 20 | 21 | static forRootAsync(options: DynamoDBModuleAsyncOptions): DynamicModule { 22 | return { 23 | module: DynamoDBModule, 24 | imports: [DynamoDBCoreModule.forRootAsync(options)], 25 | } 26 | } 27 | 28 | static forFeature(models: DynamoDBInput[]): DynamicModule { 29 | const convertedModels = models.map(model => 30 | convertToClassWithOptions(model), 31 | ) 32 | 33 | const providers = createDynamoDBProvider(convertedModels) 34 | 35 | return { 36 | module: DynamoDBModule, 37 | providers, 38 | exports: providers, 39 | } 40 | } 41 | } 42 | -------------------------------------------------------------------------------- /src/module/dynamodb.providers.ts: -------------------------------------------------------------------------------- 1 | import { DataMapper } from '@aws/dynamodb-data-mapper' 2 | import { FactoryProvider } from '@nestjs/common/interfaces' 3 | import { DynamoDB } from 'aws-sdk' 4 | 5 | import { getModelForClass, getModelToken } from '../util' 6 | import { DYNAMO_DB_CLIENT, DYNAMO_DB_DATA_MAPPER } from './dynamodb.constants' 7 | import { DynamoDBClass, DynamoDBClassWithOptions } from './dynamodb.interfaces' 8 | 9 | type ModelFactory = (dynamoDBClient: DynamoDB, mapper: DataMapper) => any 10 | 11 | export function createDynamoDBProvider( 12 | models: DynamoDBClassWithOptions[], 13 | ): FactoryProvider[] { 14 | const buildProvider = ( 15 | { name }: DynamoDBClass, 16 | modelFactory: ModelFactory, 17 | ) => ({ 18 | provide: getModelToken(name), 19 | useFactory: modelFactory, 20 | inject: [DYNAMO_DB_CLIENT, DYNAMO_DB_DATA_MAPPER], 21 | }) 22 | 23 | return models.reduce((providers, dynamoDBClassWithOptions) => { 24 | const modelFactory = (dynamoDBClient: DynamoDB, mapper: DataMapper) => 25 | getModelForClass>( 26 | dynamoDBClassWithOptions.dynamoDBClass, 27 | dynamoDBClassWithOptions.tableOptions, 28 | dynamoDBClient, 29 | mapper, 30 | ) 31 | 32 | const modelProvider = buildProvider( 33 | dynamoDBClassWithOptions.dynamoDBClass, 34 | modelFactory, 35 | ) 36 | 37 | return [...providers, modelProvider] 38 | }, []) 39 | } 40 | -------------------------------------------------------------------------------- /src/util/convertToClassWithOptions.ts: -------------------------------------------------------------------------------- 1 | import { isClass } from 'is-class' 2 | import { 3 | DynamoDBClass, 4 | DynamoDBClassWithOptions, 5 | DynamoDBInput, 6 | } from '../module/dynamodb.interfaces' 7 | 8 | const isDynamoDBClass = (item): item is DynamoDBClass => isClass(item) 9 | const isDynamoDBClassWithOptions = (item): item is DynamoDBClassWithOptions => 10 | isDynamoDBClass(item.dynamoDBClass) 11 | 12 | export const convertToClassWithOptions = ( 13 | item: DynamoDBInput, 14 | ): DynamoDBClassWithOptions => { 15 | if (isDynamoDBClass(item)) { 16 | return { 17 | dynamoDBClass: item, 18 | tableOptions: { 19 | readCapacityUnits: 5, 20 | writeCapacityUnits: 5, 21 | }, 22 | } 23 | } else if (isDynamoDBClassWithOptions(item)) { 24 | return item 25 | } 26 | return invalidObject('model') 27 | } 28 | 29 | function invalidObject(type: string): never { 30 | throw new Error(`Invalid ${type} object`) 31 | } 32 | -------------------------------------------------------------------------------- /src/util/getKeys.ts: -------------------------------------------------------------------------------- 1 | export const getKeys = (schema: any): Record => { 2 | let hash: string = '' 3 | let range: string = '' 4 | for (const prop in schema) { 5 | if (schema[prop].keyType === 'HASH') hash = prop 6 | if (schema[prop].keyType === 'RANGE') range = prop 7 | 8 | if (hash && range) return { range, hash } 9 | } 10 | 11 | return { range, hash } 12 | } 13 | -------------------------------------------------------------------------------- /src/util/getModelForClass.ts: -------------------------------------------------------------------------------- 1 | import { DynamoDB } from 'aws-sdk' 2 | import { 3 | DataMapper, 4 | CreateTableOptions, 5 | getSchema, 6 | } from '@aws/dynamodb-data-mapper' 7 | import { DynamoDBClass } from '../module/dynamodb.interfaces' 8 | import { getKeys } from './getKeys' 9 | import { unmarshallItem } from '@aws/dynamodb-data-marshaller' 10 | 11 | import { getTable } from './getTable' 12 | 13 | type instanceOfDynamoDBClass = InstanceType 14 | 15 | export class GetModelForClass { 16 | constructor( 17 | dynamoDBClass: DynamoDBClass, 18 | tableOptions: CreateTableOptions, 19 | dynamoDBClient: DynamoDB, 20 | mapper: DataMapper, 21 | ) { 22 | this.dynamoDBClass = dynamoDBClass 23 | this.table = getTable(dynamoDBClass) 24 | this.dynamoDBClient = dynamoDBClient 25 | this.mapper = mapper 26 | this.schema = getSchema(new dynamoDBClass()) 27 | const { hash, range } = getKeys(this.schema) 28 | this.hashKey = hash 29 | this.rangeKey = range 30 | mapper.ensureTableExists(dynamoDBClass, tableOptions) 31 | } 32 | private dynamoDBClass: DynamoDBClass 33 | private table: string 34 | private dynamoDBClient: DynamoDB 35 | private mapper: DataMapper 36 | private schema: any 37 | private hashKey: string 38 | private rangeKey: string 39 | 40 | getDynamoDBClient(): DynamoDB { 41 | return this.dynamoDBClient 42 | } 43 | 44 | getSchema(): any { 45 | return this.schema 46 | } 47 | 48 | getTable(): string { 49 | return this.table 50 | } 51 | 52 | async create(input: Partial): Promise { 53 | const toSave = Object.assign(new this.dynamoDBClass(), input) 54 | return this.mapper.put(toSave) 55 | } 56 | 57 | async find(input?: Partial): Promise { 58 | let results: T[] = [] 59 | const keys = Object.keys(input) 60 | if (!input || JSON.stringify(input) === JSON.stringify({})) { 61 | for await (const item of this.mapper.scan(this.dynamoDBClass)) { 62 | results.push(item) 63 | } 64 | } else if ( 65 | keys.includes(this.hashKey) || 66 | (keys.includes(this.hashKey) && keys.includes(this.rangeKey)) 67 | ) { 68 | for await (const item of this.mapper.query(this.dynamoDBClass, input)) { 69 | results.push(item) 70 | } 71 | } else { 72 | const key = Object.keys(input)[0] 73 | 74 | const items: DynamoDB.ItemList = await new Promise((resolve, reject) => 75 | this.dynamoDBClient.scan( 76 | this.getFindItemInput(key, input[key]), 77 | (err, data) => { 78 | if (err) reject(err) 79 | else resolve(data.Items) 80 | }, 81 | ), 82 | ) 83 | 84 | return items.map(item => unmarshallItem(this.schema, item)) 85 | } 86 | 87 | return results 88 | } 89 | 90 | async findById(id: string): Promise { 91 | return this.mapper.get(Object.assign(new this.dynamoDBClass(), { id })) 92 | } 93 | 94 | async findByIdAndDelete(id: string): Promise { 95 | return new Promise((resolve, reject) => 96 | this.dynamoDBClient.deleteItem( 97 | this.getDeleteItemInput(id), 98 | (err, data) => { 99 | if (err) reject(err) 100 | else resolve(data) 101 | }, 102 | ), 103 | ) 104 | } 105 | 106 | async findByIdAndUpdate( 107 | id: string, 108 | update: Partial, 109 | ): Promise { 110 | const item = await this.mapper.get( 111 | Object.assign(new this.dynamoDBClass(), { id }), 112 | ) 113 | 114 | return this.mapper.update(Object.assign(item, update)) 115 | } 116 | private getDeleteItemInput(id: string): DynamoDB.DeleteItemInput { 117 | return { 118 | Key: { 119 | id: { 120 | S: id, 121 | }, 122 | }, 123 | TableName: this.table, 124 | } 125 | } 126 | private getFindItemInput(key: string, value: string): DynamoDB.ScanInput { 127 | return { 128 | ExpressionAttributeValues: { 129 | ':catval': { 130 | S: value, 131 | }, 132 | }, 133 | FilterExpression: `${key} = :catval`, 134 | TableName: this.table, 135 | } 136 | } 137 | } 138 | 139 | export const getModelForClass = ( 140 | dynamoDBClass: DynamoDBClass, 141 | tableOptions: CreateTableOptions, 142 | dynamoDBClient: DynamoDB, 143 | mapper: DataMapper, 144 | ) => 145 | new GetModelForClass(dynamoDBClass, tableOptions, dynamoDBClient, mapper) 146 | -------------------------------------------------------------------------------- /src/util/getSchema.ts: -------------------------------------------------------------------------------- 1 | const DynamoDbSchema = Symbol.for('DynamoDbSchema') 2 | 3 | export function getSchema(item: any): any { 4 | if (item) { 5 | const schema = item[DynamoDbSchema] 6 | if (schema && typeof schema === 'object') { 7 | return schema 8 | } 9 | } 10 | 11 | throw new Error( 12 | 'The provided item did not adhere to the DynamoDbDocument protocol.' + 13 | ' No object property was found at the `DynamoDbSchema` symbol', 14 | ) 15 | } 16 | -------------------------------------------------------------------------------- /src/util/getTable.ts: -------------------------------------------------------------------------------- 1 | import { DynamoDbTable } from '@aws/dynamodb-data-mapper' 2 | import { DynamoDBClass } from '../module/dynamodb.interfaces' 3 | 4 | export const getTable = (dynamoDBClass: DynamoDBClass): string => 5 | dynamoDBClass.prototype[DynamoDbTable] 6 | -------------------------------------------------------------------------------- /src/util/getTokens.ts: -------------------------------------------------------------------------------- 1 | export const getModelToken = (name: string) => `__${name}DynamoDBModel__` 2 | export const getConnectionToken = (name: string) => `__${name}DynamoDBModel__` 3 | -------------------------------------------------------------------------------- /src/util/index.ts: -------------------------------------------------------------------------------- 1 | export * from './getModelForClass' 2 | export * from './getTokens' 3 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "declaration": true, 5 | "strict": false, 6 | "removeComments": true, 7 | "noLib": false, 8 | "emitDecoratorMetadata": true, 9 | "experimentalDecorators": true, 10 | "lib": ["es6", "dom", "es2017"], 11 | "target": "es6", 12 | "sourceMap": false, 13 | "outDir": "./dist", 14 | "rootDir": "./src", 15 | "skipLibCheck": true 16 | }, 17 | "include": ["src"], 18 | "exclude": ["node_modules", "dist"] 19 | } 20 | --------------------------------------------------------------------------------