├── LICENSE ├── README.md ├── examples ├── advanced_search.js ├── all-brands.js ├── all_categories.js ├── basic_search.js └── product_detail.js ├── package-lock.json ├── package.json ├── src ├── index.ts └── types.ts ├── test ├── advanced_search.js ├── all-brands.js ├── all_categories.js ├── basic_search.js └── product_detail.js ├── tsconfig-build.json └── tsconfig.json /LICENSE: -------------------------------------------------------------------------------- 1 | Copyright (c) 2018 The Python Packaging Authority 2 | 3 | Permission is hereby granted, free of charge, to any person obtaining a copy 4 | of this software and associated documentation files (the "Software"), to deal 5 | in the Software without restriction, including without limitation the rights 6 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 7 | copies of the Software, and to permit persons to whom the Software is 8 | furnished to do so, subject to the following conditions: 9 | 10 | The above copyright notice and this permission notice shall be included in all 11 | copies or substantial portions of the Software. 12 | 13 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 14 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 15 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 16 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 17 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 18 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 19 | SOFTWARE. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ![TechSpecs Logo](https://i.imgur.com/JwSpZO8.jpg) 2 | ![TechSpecs Logo](https://i.imgur.com/JZ3GqAU.jpg) 3 | 4 | # Introducing TechSpecs JavaScript/TypeScript 5 | 6 | This node library provides programatic access to the standardized specs of over 61,000 consumer electronics devices, including the latest smartphones, tablets, smartwatches, laptops, and more. 7 | 8 | ## Documentation 9 | 10 | - See the [TechSpecs API Docs](https://techspecs.readme.io) 11 | 12 | ## API Key 13 | 14 | - Get an API key [here](https://developer.dashboard.techspecs.io/) 15 | 16 | ## Requirements 17 | 18 | - NodeJS v12.x or ES6 19 | 20 | ## Installation 21 | 22 | ![How to install TechSpecs](https://i.imgur.com/tutKl0r.png) 23 | 24 | ```sh 25 | npm install techspecs 26 | ``` 27 | 28 | ## Usage 29 | 30 | The library needs to be configured with your account's api key and base which is 31 | available in your [TechSpecs Dashboard](https://developer.dashboard.techspecs.io/). 32 | 33 | Set `techspecs_key` to your key value and `techspecs_base` to your base value. 34 | 35 | ### Basic Search 36 | 37 | #### Search for a device by specifying it's model name, version number or features 38 | 39 | ```javascript 40 | // Search for a product by name, version or features 41 | import { techspecs } from "techspecs"; 42 | 43 | // self invoking async function 44 | async function search() { 45 | // TechSpecs API Key 46 | const techspecs_key = "techspecs_api_key"; 47 | 48 | // TechSpecs base https://apis.dashboard.techspecs.io/{techspecs_base} 49 | const techspecs_base = "a8TD3mkN49fhg2y"; 50 | 51 | const query = { 52 | keyword: "iPhone 13", // product name or version number to search 53 | category: "all", // product category to search 54 | }; 55 | 56 | // choose between "pretty" or "raw" mode for viewing response 57 | const response = await techspecs.search(base, query, key, (mode = "pretty")); 58 | 59 | // print the search results 60 | console.log(response); 61 | } 62 | ``` 63 | 64 | ### Advanced Search 65 | 66 | #### List all products by brand, category and release date 67 | 68 | ```javascript 69 | // List all products by brand, category and release date 70 | import { techspecs } from "techspecs"; 71 | 72 | // self invoking async function 73 | async function getProducts() => { 74 | // TechSpecs API Key 75 | const techspecs_key = "techspecs_api_key"; 76 | 77 | // TechSpecs base https://apis.dashboard.techspecs.io/{techspecs_base} 78 | const techspecs_base = "a8TD3mkN49fhg2y"; 79 | 80 | // enter the page number to fetch results from 81 | const page = 1; 82 | 83 | // type in the name of the brand you're looking for or leave this field empty to see results from all brands 84 | const brand = ["Apple"]; 85 | 86 | // type in the name of the category you're looking for or leave this field empty to see results from all categories 87 | const category = ["smartphone"]; 88 | 89 | // please provide a date range to narrow your search. Leave this field empty to fetch all results from all dates 90 | const date = { 91 | from: "2010-01-01", // YYYY-MM-DD 92 | to: "2022-03-15", // YYYY-MM-DD 93 | }; 94 | 95 | // choose between "pretty" or "raw" mode for viewing response 96 | const response = await techspecs.products( 97 | techspecs_base, 98 | brand, 99 | category, 100 | date, 101 | page, 102 | techspecs_key, 103 | "pretty" 104 | ); 105 | 106 | // print the search results 107 | console.log(response); 108 | } 109 | 110 | ``` 111 | 112 | ### Product Details 113 | 114 | ```javascript 115 | // Get the standardized specifications of a specified product 116 | 117 | import { techspecs } from "techspecs"; 118 | 119 | // self invoking async function 120 | async function getDetails() => { 121 | // TechSpecs API Key 122 | const techspecs_key = "techspecs_api_key"; 123 | 124 | // TechSpecs base https://apis.dashboard.techspecs.io/{techspecs_base} 125 | const techspecs_base = "a8TD3mkN49fhg2y"; 126 | 127 | // TechSpecs product id 128 | const techspecs_id = "6186b047987cda5f88311983"; 129 | 130 | // choose between "pretty" or "raw" mode for viewing response 131 | const response = await techspecs.detail( 132 | techspecs_base, 133 | techspecs_id, 134 | techspecs_key, 135 | (mode = "pretty") 136 | ); 137 | 138 | // print the specifications of the product 139 | console.log(response); 140 | } 141 | 142 | ``` 143 | 144 | ### List all brands 145 | 146 | ```javascript 147 | import { techspecs } from "techspecs"; 148 | 149 | // self invoking async function 150 | async function getBrands() => { 151 | // TechSpecs API Key 152 | const techspecs_key = "techspecs_api_key"; 153 | 154 | // TechSpecs base https://apis.dashboard.techspecs.io/{techspecs_base} 155 | const techspecs_base = "a8TD3mkN49fhg2y"; 156 | 157 | // choose between "pretty" or "raw" mode for viewing response 158 | const response = await techspecs.brands( 159 | techspecs_base, 160 | techspecs_key, 161 | (mode = "pretty") 162 | ); 163 | 164 | // print the list of all brands 165 | console.log(response); 166 | } 167 | 168 | 169 | 170 | ``` 171 | 172 | ### List all categories 173 | 174 | ```javascript 175 | import { techspecs } from "techspecs"; 176 | 177 | // self invoking async function 178 | async function getAllCategories() => { 179 | // TechSpecs API Key 180 | const techspecs_key = "techspecs_api_key"; 181 | 182 | // TechSpecs base https://apis.dashboard.techspecs.io/{techspecs_base} 183 | const techspecs_base = "a8TD3mkN49fhg2y"; 184 | 185 | // choose between "pretty" or "raw" mode for viewing response 186 | const response = await techspecs.categories( 187 | techspecs_base, 188 | techspecs_key, 189 | (mode = "pretty") 190 | ); 191 | 192 | // print the list of all categories 193 | console.log(response); 194 | } 195 | 196 | ``` 197 | -------------------------------------------------------------------------------- /examples/advanced_search.js: -------------------------------------------------------------------------------- 1 | // List all products by brand, category and release date 2 | import { techspecs } from "techspecs"; 3 | 4 | // self invoking async function 5 | (async () => { 6 | // TechSpecs API Key 7 | const techspecs_key = "techspecs_api_key"; 8 | 9 | // TechSpecs base https://apis.dashboard.techspecs.io/{techspecs_base} 10 | const techspecs_base = "a8TD3mkN49fhg2y"; 11 | 12 | // enter the page number to fetch results from 13 | const page = 1; 14 | 15 | // type in the name of the brand you're looking for or leave this field empty to see results from all brands 16 | const brand = ["Apple"]; 17 | 18 | // type in the name of the category you're looking for or leave this field empty to see results from all categories 19 | const category = ["smartphone"]; 20 | 21 | // please provide a date range to narrow your search. Leave this field empty to fetch all results from all dates 22 | const date = { 23 | from: "2010-01-01", // YYYY-MM-DD 24 | to: "2022-03-15", // YYYY-MM-DD 25 | }; 26 | 27 | // choose between "pretty" or "raw" mode for viewing response 28 | const response = await techspecs.products( 29 | techspecs_base, 30 | brand, 31 | category, 32 | date, 33 | page, 34 | techspecs_key, 35 | "pretty" 36 | ); 37 | 38 | // print the search results 39 | console.log(response); 40 | })(); 41 | -------------------------------------------------------------------------------- /examples/all-brands.js: -------------------------------------------------------------------------------- 1 | import { techspecs } from "techspecs"; 2 | 3 | // self invoking async function 4 | (async () => { 5 | // TechSpecs API Key 6 | const techspecs_key = "techspecs_api_key"; 7 | 8 | // TechSpecs base https://apis.dashboard.techspecs.io/{techspecs_base} 9 | const techspecs_base = "a8TD3mkN49fhg2y"; 10 | 11 | // choose between "pretty" or "raw" mode for viewing response 12 | const response = await techspecs.brands( 13 | techspecs_base, 14 | techspecs_key, 15 | (mode = "pretty") 16 | ); 17 | 18 | // print the list of all brands 19 | console.log(response); 20 | })(); 21 | -------------------------------------------------------------------------------- /examples/all_categories.js: -------------------------------------------------------------------------------- 1 | import { techspecs } from "techspecs"; 2 | 3 | // self invoking async function 4 | (async () => { 5 | // TechSpecs API Key 6 | const techspecs_key = "techspecs_api_key"; 7 | 8 | // TechSpecs base https://apis.dashboard.techspecs.io/{techspecs_base} 9 | const techspecs_base = "a8TD3mkN49fhg2y"; 10 | 11 | // choose between "pretty" or "raw" mode for viewing response 12 | const response = await techspecs.categories( 13 | techspecs_base, 14 | techspecs_key, 15 | (mode = "pretty") 16 | ); 17 | 18 | // print the list of all categories 19 | console.log(response); 20 | })(); 21 | -------------------------------------------------------------------------------- /examples/basic_search.js: -------------------------------------------------------------------------------- 1 | // Search for a product by name, version or features 2 | import { techspecs } from "techspecs"; 3 | 4 | // self invoking async function 5 | (async () => { 6 | // TechSpecs API Key 7 | const techspecs_key = "techspecs_api_key"; 8 | 9 | // TechSpecs base https://apis.dashboard.techspecs.io/{techspecs_base} 10 | const techspecs_base = "a8TD3mkN49fhg2y"; 11 | 12 | const query = { 13 | keyword: "iPhone 13", // product name or version number to search 14 | category: "all", // product category to search 15 | }; 16 | 17 | // choose between "pretty" or "raw" mode for viewing response 18 | const response = await techspecs.search(base, query, key, (mode = "pretty")); 19 | 20 | // print the search results 21 | console.log(response); 22 | })(); 23 | -------------------------------------------------------------------------------- /examples/product_detail.js: -------------------------------------------------------------------------------- 1 | // Get the standardized specifications of a specified product 2 | 3 | import { techspecs } from "techspecs"; 4 | 5 | // self invoking async function 6 | (async () => { 7 | // TechSpecs API Key 8 | const techspecs_key = "techspecs_api_key"; 9 | 10 | // TechSpecs base https://apis.dashboard.techspecs.io/{techspecs_base} 11 | const techspecs_base = "a8TD3mkN49fhg2y"; 12 | 13 | // TechSpecs product id 14 | const techspecs_id = "6186b047987cda5f88311983"; 15 | 16 | // choose between "pretty" or "raw" mode for viewing response 17 | const response = await techspecs.detail( 18 | techspecs_base, 19 | techspecs_id, 20 | techspecs_key, 21 | (mode = "pretty") 22 | ); 23 | 24 | // print the specifications of the product 25 | console.log(response); 26 | })(); 27 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "techspecs", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@sindresorhus/is": { 8 | "version": "0.14.0", 9 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz", 10 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==", 11 | "dev": true 12 | }, 13 | "@szmarczak/http-timer": { 14 | "version": "1.1.2", 15 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz", 16 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==", 17 | "dev": true, 18 | "requires": { 19 | "defer-to-connect": "^1.0.1" 20 | } 21 | }, 22 | "abbrev": { 23 | "version": "1.1.1", 24 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 25 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 26 | "dev": true 27 | }, 28 | "ansi-align": { 29 | "version": "3.0.1", 30 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.1.tgz", 31 | "integrity": "sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w==", 32 | "dev": true, 33 | "requires": { 34 | "string-width": "^4.1.0" 35 | } 36 | }, 37 | "ansi-regex": { 38 | "version": "5.0.1", 39 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 40 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 41 | "dev": true 42 | }, 43 | "ansi-styles": { 44 | "version": "4.3.0", 45 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 46 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 47 | "dev": true, 48 | "requires": { 49 | "color-convert": "^2.0.1" 50 | } 51 | }, 52 | "anymatch": { 53 | "version": "3.1.2", 54 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 55 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 56 | "dev": true, 57 | "requires": { 58 | "normalize-path": "^3.0.0", 59 | "picomatch": "^2.0.4" 60 | } 61 | }, 62 | "axios": { 63 | "version": "0.26.1", 64 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.26.1.tgz", 65 | "integrity": "sha512-fPwcX4EvnSHuInCMItEhAGnaSEXRBjtzh9fOtsE6E1G6p7vl7edEeZe11QHf18+6+9gR5PbKV/sGKNaD8YaMeA==", 66 | "requires": { 67 | "follow-redirects": "^1.14.8" 68 | } 69 | }, 70 | "balanced-match": { 71 | "version": "1.0.2", 72 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 73 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 74 | "dev": true 75 | }, 76 | "binary-extensions": { 77 | "version": "2.2.0", 78 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 79 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 80 | "dev": true 81 | }, 82 | "boxen": { 83 | "version": "5.1.2", 84 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-5.1.2.tgz", 85 | "integrity": "sha512-9gYgQKXx+1nP8mP7CzFyaUARhg7D3n1dF/FnErWmu9l6JvGpNUN278h0aSb+QjoiKSWG+iZ3uHrcqk0qrY9RQQ==", 86 | "dev": true, 87 | "requires": { 88 | "ansi-align": "^3.0.0", 89 | "camelcase": "^6.2.0", 90 | "chalk": "^4.1.0", 91 | "cli-boxes": "^2.2.1", 92 | "string-width": "^4.2.2", 93 | "type-fest": "^0.20.2", 94 | "widest-line": "^3.1.0", 95 | "wrap-ansi": "^7.0.0" 96 | } 97 | }, 98 | "brace-expansion": { 99 | "version": "1.1.11", 100 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 101 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 102 | "dev": true, 103 | "requires": { 104 | "balanced-match": "^1.0.0", 105 | "concat-map": "0.0.1" 106 | } 107 | }, 108 | "braces": { 109 | "version": "3.0.2", 110 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 111 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 112 | "dev": true, 113 | "requires": { 114 | "fill-range": "^7.0.1" 115 | } 116 | }, 117 | "cacheable-request": { 118 | "version": "6.1.0", 119 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz", 120 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==", 121 | "dev": true, 122 | "requires": { 123 | "clone-response": "^1.0.2", 124 | "get-stream": "^5.1.0", 125 | "http-cache-semantics": "^4.0.0", 126 | "keyv": "^3.0.0", 127 | "lowercase-keys": "^2.0.0", 128 | "normalize-url": "^4.1.0", 129 | "responselike": "^1.0.2" 130 | }, 131 | "dependencies": { 132 | "get-stream": { 133 | "version": "5.2.0", 134 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", 135 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", 136 | "dev": true, 137 | "requires": { 138 | "pump": "^3.0.0" 139 | } 140 | }, 141 | "lowercase-keys": { 142 | "version": "2.0.0", 143 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", 144 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==", 145 | "dev": true 146 | } 147 | } 148 | }, 149 | "call-bind": { 150 | "version": "1.0.2", 151 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 152 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 153 | "dev": true, 154 | "requires": { 155 | "function-bind": "^1.1.1", 156 | "get-intrinsic": "^1.0.2" 157 | } 158 | }, 159 | "camelcase": { 160 | "version": "6.3.0", 161 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 162 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 163 | "dev": true 164 | }, 165 | "chalk": { 166 | "version": "4.1.2", 167 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 168 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 169 | "dev": true, 170 | "requires": { 171 | "ansi-styles": "^4.1.0", 172 | "supports-color": "^7.1.0" 173 | }, 174 | "dependencies": { 175 | "has-flag": { 176 | "version": "4.0.0", 177 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 178 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 179 | "dev": true 180 | }, 181 | "supports-color": { 182 | "version": "7.2.0", 183 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 184 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 185 | "dev": true, 186 | "requires": { 187 | "has-flag": "^4.0.0" 188 | } 189 | } 190 | } 191 | }, 192 | "chokidar": { 193 | "version": "3.5.3", 194 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 195 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 196 | "dev": true, 197 | "requires": { 198 | "anymatch": "~3.1.2", 199 | "braces": "~3.0.2", 200 | "fsevents": "~2.3.2", 201 | "glob-parent": "~5.1.2", 202 | "is-binary-path": "~2.1.0", 203 | "is-glob": "~4.0.1", 204 | "normalize-path": "~3.0.0", 205 | "readdirp": "~3.6.0" 206 | } 207 | }, 208 | "ci-info": { 209 | "version": "2.0.0", 210 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 211 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", 212 | "dev": true 213 | }, 214 | "cli-boxes": { 215 | "version": "2.2.1", 216 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz", 217 | "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==", 218 | "dev": true 219 | }, 220 | "clone-response": { 221 | "version": "1.0.2", 222 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz", 223 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=", 224 | "dev": true, 225 | "requires": { 226 | "mimic-response": "^1.0.0" 227 | } 228 | }, 229 | "color-convert": { 230 | "version": "2.0.1", 231 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 232 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 233 | "dev": true, 234 | "requires": { 235 | "color-name": "~1.1.4" 236 | } 237 | }, 238 | "color-name": { 239 | "version": "1.1.4", 240 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 241 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 242 | "dev": true 243 | }, 244 | "concat-map": { 245 | "version": "0.0.1", 246 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 247 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 248 | "dev": true 249 | }, 250 | "configstore": { 251 | "version": "5.0.1", 252 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz", 253 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==", 254 | "dev": true, 255 | "requires": { 256 | "dot-prop": "^5.2.0", 257 | "graceful-fs": "^4.1.2", 258 | "make-dir": "^3.0.0", 259 | "unique-string": "^2.0.0", 260 | "write-file-atomic": "^3.0.0", 261 | "xdg-basedir": "^4.0.0" 262 | } 263 | }, 264 | "cross-spawn": { 265 | "version": "6.0.5", 266 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 267 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 268 | "dev": true, 269 | "requires": { 270 | "nice-try": "^1.0.4", 271 | "path-key": "^2.0.1", 272 | "semver": "^5.5.0", 273 | "shebang-command": "^1.2.0", 274 | "which": "^1.2.9" 275 | } 276 | }, 277 | "crypto-random-string": { 278 | "version": "2.0.0", 279 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", 280 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==", 281 | "dev": true 282 | }, 283 | "debug": { 284 | "version": "3.2.7", 285 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 286 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 287 | "dev": true, 288 | "requires": { 289 | "ms": "^2.1.1" 290 | } 291 | }, 292 | "decompress-response": { 293 | "version": "3.3.0", 294 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz", 295 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=", 296 | "dev": true, 297 | "requires": { 298 | "mimic-response": "^1.0.0" 299 | } 300 | }, 301 | "deep-extend": { 302 | "version": "0.6.0", 303 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 304 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 305 | "dev": true 306 | }, 307 | "defer-to-connect": { 308 | "version": "1.1.3", 309 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz", 310 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==", 311 | "dev": true 312 | }, 313 | "define-properties": { 314 | "version": "1.1.4", 315 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.4.tgz", 316 | "integrity": "sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA==", 317 | "dev": true, 318 | "requires": { 319 | "has-property-descriptors": "^1.0.0", 320 | "object-keys": "^1.1.1" 321 | } 322 | }, 323 | "dot-prop": { 324 | "version": "5.3.0", 325 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz", 326 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==", 327 | "dev": true, 328 | "requires": { 329 | "is-obj": "^2.0.0" 330 | } 331 | }, 332 | "duplexer3": { 333 | "version": "0.1.4", 334 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 335 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=", 336 | "dev": true 337 | }, 338 | "emoji-regex": { 339 | "version": "8.0.0", 340 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 341 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 342 | "dev": true 343 | }, 344 | "end-of-stream": { 345 | "version": "1.4.4", 346 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 347 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 348 | "dev": true, 349 | "requires": { 350 | "once": "^1.4.0" 351 | } 352 | }, 353 | "error-ex": { 354 | "version": "1.3.2", 355 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 356 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 357 | "dev": true, 358 | "requires": { 359 | "is-arrayish": "^0.2.1" 360 | } 361 | }, 362 | "es-abstract": { 363 | "version": "1.19.5", 364 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.19.5.tgz", 365 | "integrity": "sha512-Aa2G2+Rd3b6kxEUKTF4TaW67czBLyAv3z7VOhYRU50YBx+bbsYZ9xQP4lMNazePuFlybXI0V4MruPos7qUo5fA==", 366 | "dev": true, 367 | "requires": { 368 | "call-bind": "^1.0.2", 369 | "es-to-primitive": "^1.2.1", 370 | "function-bind": "^1.1.1", 371 | "get-intrinsic": "^1.1.1", 372 | "get-symbol-description": "^1.0.0", 373 | "has": "^1.0.3", 374 | "has-symbols": "^1.0.3", 375 | "internal-slot": "^1.0.3", 376 | "is-callable": "^1.2.4", 377 | "is-negative-zero": "^2.0.2", 378 | "is-regex": "^1.1.4", 379 | "is-shared-array-buffer": "^1.0.2", 380 | "is-string": "^1.0.7", 381 | "is-weakref": "^1.0.2", 382 | "object-inspect": "^1.12.0", 383 | "object-keys": "^1.1.1", 384 | "object.assign": "^4.1.2", 385 | "string.prototype.trimend": "^1.0.4", 386 | "string.prototype.trimstart": "^1.0.4", 387 | "unbox-primitive": "^1.0.1" 388 | } 389 | }, 390 | "es-to-primitive": { 391 | "version": "1.2.1", 392 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 393 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 394 | "dev": true, 395 | "requires": { 396 | "is-callable": "^1.1.4", 397 | "is-date-object": "^1.0.1", 398 | "is-symbol": "^1.0.2" 399 | } 400 | }, 401 | "escape-goat": { 402 | "version": "2.1.1", 403 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz", 404 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==", 405 | "dev": true 406 | }, 407 | "escape-string-regexp": { 408 | "version": "1.0.5", 409 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 410 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 411 | "dev": true 412 | }, 413 | "fill-range": { 414 | "version": "7.0.1", 415 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 416 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 417 | "dev": true, 418 | "requires": { 419 | "to-regex-range": "^5.0.1" 420 | } 421 | }, 422 | "follow-redirects": { 423 | "version": "1.14.9", 424 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.9.tgz", 425 | "integrity": "sha512-MQDfihBQYMcyy5dhRDJUHcw7lb2Pv/TuE6xP1vyraLukNDHKbDxDNaOE3NbCAdKQApno+GPRyo1YAp89yCjK4w==" 426 | }, 427 | "fsevents": { 428 | "version": "2.3.2", 429 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 430 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 431 | "dev": true, 432 | "optional": true 433 | }, 434 | "function-bind": { 435 | "version": "1.1.1", 436 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 437 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 438 | "dev": true 439 | }, 440 | "get-intrinsic": { 441 | "version": "1.1.1", 442 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 443 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 444 | "dev": true, 445 | "requires": { 446 | "function-bind": "^1.1.1", 447 | "has": "^1.0.3", 448 | "has-symbols": "^1.0.1" 449 | } 450 | }, 451 | "get-stream": { 452 | "version": "4.1.0", 453 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 454 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 455 | "dev": true, 456 | "requires": { 457 | "pump": "^3.0.0" 458 | } 459 | }, 460 | "get-symbol-description": { 461 | "version": "1.0.0", 462 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", 463 | "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", 464 | "dev": true, 465 | "requires": { 466 | "call-bind": "^1.0.2", 467 | "get-intrinsic": "^1.1.1" 468 | } 469 | }, 470 | "glob-parent": { 471 | "version": "5.1.2", 472 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 473 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 474 | "dev": true, 475 | "requires": { 476 | "is-glob": "^4.0.1" 477 | } 478 | }, 479 | "global-dirs": { 480 | "version": "3.0.0", 481 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-3.0.0.tgz", 482 | "integrity": "sha512-v8ho2DS5RiCjftj1nD9NmnfaOzTdud7RRnVd9kFNOjqZbISlx5DQ+OrTkywgd0dIt7oFCvKetZSHoHcP3sDdiA==", 483 | "dev": true, 484 | "requires": { 485 | "ini": "2.0.0" 486 | } 487 | }, 488 | "got": { 489 | "version": "9.6.0", 490 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz", 491 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==", 492 | "dev": true, 493 | "requires": { 494 | "@sindresorhus/is": "^0.14.0", 495 | "@szmarczak/http-timer": "^1.1.2", 496 | "cacheable-request": "^6.0.0", 497 | "decompress-response": "^3.3.0", 498 | "duplexer3": "^0.1.4", 499 | "get-stream": "^4.1.0", 500 | "lowercase-keys": "^1.0.1", 501 | "mimic-response": "^1.0.1", 502 | "p-cancelable": "^1.0.0", 503 | "to-readable-stream": "^1.0.0", 504 | "url-parse-lax": "^3.0.0" 505 | } 506 | }, 507 | "graceful-fs": { 508 | "version": "4.2.10", 509 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", 510 | "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", 511 | "dev": true 512 | }, 513 | "has": { 514 | "version": "1.0.3", 515 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 516 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 517 | "dev": true, 518 | "requires": { 519 | "function-bind": "^1.1.1" 520 | } 521 | }, 522 | "has-bigints": { 523 | "version": "1.0.1", 524 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.1.tgz", 525 | "integrity": "sha512-LSBS2LjbNBTf6287JEbEzvJgftkF5qFkmCo9hDRpAzKhUOlJ+hx8dd4USs00SgsUNwc4617J9ki5YtEClM2ffA==", 526 | "dev": true 527 | }, 528 | "has-flag": { 529 | "version": "3.0.0", 530 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 531 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 532 | "dev": true 533 | }, 534 | "has-property-descriptors": { 535 | "version": "1.0.0", 536 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz", 537 | "integrity": "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==", 538 | "dev": true, 539 | "requires": { 540 | "get-intrinsic": "^1.1.1" 541 | } 542 | }, 543 | "has-symbols": { 544 | "version": "1.0.3", 545 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 546 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 547 | "dev": true 548 | }, 549 | "has-tostringtag": { 550 | "version": "1.0.0", 551 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", 552 | "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", 553 | "dev": true, 554 | "requires": { 555 | "has-symbols": "^1.0.2" 556 | } 557 | }, 558 | "has-yarn": { 559 | "version": "2.1.0", 560 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz", 561 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==", 562 | "dev": true 563 | }, 564 | "hosted-git-info": { 565 | "version": "2.8.9", 566 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", 567 | "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==", 568 | "dev": true 569 | }, 570 | "http-cache-semantics": { 571 | "version": "4.1.0", 572 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 573 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==", 574 | "dev": true 575 | }, 576 | "ignore-by-default": { 577 | "version": "1.0.1", 578 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 579 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 580 | "dev": true 581 | }, 582 | "import-lazy": { 583 | "version": "2.1.0", 584 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 585 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=", 586 | "dev": true 587 | }, 588 | "imurmurhash": { 589 | "version": "0.1.4", 590 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 591 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 592 | "dev": true 593 | }, 594 | "ini": { 595 | "version": "2.0.0", 596 | "resolved": "https://registry.npmjs.org/ini/-/ini-2.0.0.tgz", 597 | "integrity": "sha512-7PnF4oN3CvZF23ADhA5wRaYEQpJ8qygSkbtTXWBeXWXmEVRXK+1ITciHWwHhsjv1TmW0MgacIv6hEi5pX5NQdA==", 598 | "dev": true 599 | }, 600 | "internal-slot": { 601 | "version": "1.0.3", 602 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.3.tgz", 603 | "integrity": "sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA==", 604 | "dev": true, 605 | "requires": { 606 | "get-intrinsic": "^1.1.0", 607 | "has": "^1.0.3", 608 | "side-channel": "^1.0.4" 609 | } 610 | }, 611 | "is-arrayish": { 612 | "version": "0.2.1", 613 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 614 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 615 | "dev": true 616 | }, 617 | "is-bigint": { 618 | "version": "1.0.4", 619 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 620 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 621 | "dev": true, 622 | "requires": { 623 | "has-bigints": "^1.0.1" 624 | } 625 | }, 626 | "is-binary-path": { 627 | "version": "2.1.0", 628 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 629 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 630 | "dev": true, 631 | "requires": { 632 | "binary-extensions": "^2.0.0" 633 | } 634 | }, 635 | "is-boolean-object": { 636 | "version": "1.1.2", 637 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 638 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 639 | "dev": true, 640 | "requires": { 641 | "call-bind": "^1.0.2", 642 | "has-tostringtag": "^1.0.0" 643 | } 644 | }, 645 | "is-callable": { 646 | "version": "1.2.4", 647 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.4.tgz", 648 | "integrity": "sha512-nsuwtxZfMX67Oryl9LCQ+upnC0Z0BgpwntpS89m1H/TLF0zNfzfLMV/9Wa/6MZsj0acpEjAO0KF1xT6ZdLl95w==", 649 | "dev": true 650 | }, 651 | "is-ci": { 652 | "version": "2.0.0", 653 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", 654 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", 655 | "dev": true, 656 | "requires": { 657 | "ci-info": "^2.0.0" 658 | } 659 | }, 660 | "is-core-module": { 661 | "version": "2.8.1", 662 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.1.tgz", 663 | "integrity": "sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==", 664 | "dev": true, 665 | "requires": { 666 | "has": "^1.0.3" 667 | } 668 | }, 669 | "is-date-object": { 670 | "version": "1.0.5", 671 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 672 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 673 | "dev": true, 674 | "requires": { 675 | "has-tostringtag": "^1.0.0" 676 | } 677 | }, 678 | "is-extglob": { 679 | "version": "2.1.1", 680 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 681 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 682 | "dev": true 683 | }, 684 | "is-fullwidth-code-point": { 685 | "version": "3.0.0", 686 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 687 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 688 | "dev": true 689 | }, 690 | "is-glob": { 691 | "version": "4.0.3", 692 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 693 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 694 | "dev": true, 695 | "requires": { 696 | "is-extglob": "^2.1.1" 697 | } 698 | }, 699 | "is-installed-globally": { 700 | "version": "0.4.0", 701 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.4.0.tgz", 702 | "integrity": "sha512-iwGqO3J21aaSkC7jWnHP/difazwS7SFeIqxv6wEtLU8Y5KlzFTjyqcSIT0d8s4+dDhKytsk9PJZ2BkS5eZwQRQ==", 703 | "dev": true, 704 | "requires": { 705 | "global-dirs": "^3.0.0", 706 | "is-path-inside": "^3.0.2" 707 | } 708 | }, 709 | "is-negative-zero": { 710 | "version": "2.0.2", 711 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", 712 | "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", 713 | "dev": true 714 | }, 715 | "is-npm": { 716 | "version": "5.0.0", 717 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-5.0.0.tgz", 718 | "integrity": "sha512-WW/rQLOazUq+ST/bCAVBp/2oMERWLsR7OrKyt052dNDk4DHcDE0/7QSXITlmi+VBcV13DfIbysG3tZJm5RfdBA==", 719 | "dev": true 720 | }, 721 | "is-number": { 722 | "version": "7.0.0", 723 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 724 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 725 | "dev": true 726 | }, 727 | "is-number-object": { 728 | "version": "1.0.7", 729 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", 730 | "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", 731 | "dev": true, 732 | "requires": { 733 | "has-tostringtag": "^1.0.0" 734 | } 735 | }, 736 | "is-obj": { 737 | "version": "2.0.0", 738 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 739 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==", 740 | "dev": true 741 | }, 742 | "is-path-inside": { 743 | "version": "3.0.3", 744 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 745 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 746 | "dev": true 747 | }, 748 | "is-regex": { 749 | "version": "1.1.4", 750 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 751 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 752 | "dev": true, 753 | "requires": { 754 | "call-bind": "^1.0.2", 755 | "has-tostringtag": "^1.0.0" 756 | } 757 | }, 758 | "is-shared-array-buffer": { 759 | "version": "1.0.2", 760 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz", 761 | "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==", 762 | "dev": true, 763 | "requires": { 764 | "call-bind": "^1.0.2" 765 | } 766 | }, 767 | "is-string": { 768 | "version": "1.0.7", 769 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 770 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 771 | "dev": true, 772 | "requires": { 773 | "has-tostringtag": "^1.0.0" 774 | } 775 | }, 776 | "is-symbol": { 777 | "version": "1.0.4", 778 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 779 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 780 | "dev": true, 781 | "requires": { 782 | "has-symbols": "^1.0.2" 783 | } 784 | }, 785 | "is-typedarray": { 786 | "version": "1.0.0", 787 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 788 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 789 | "dev": true 790 | }, 791 | "is-weakref": { 792 | "version": "1.0.2", 793 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", 794 | "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", 795 | "dev": true, 796 | "requires": { 797 | "call-bind": "^1.0.2" 798 | } 799 | }, 800 | "is-yarn-global": { 801 | "version": "0.3.0", 802 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz", 803 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==", 804 | "dev": true 805 | }, 806 | "isexe": { 807 | "version": "2.0.0", 808 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 809 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 810 | "dev": true 811 | }, 812 | "json-buffer": { 813 | "version": "3.0.0", 814 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz", 815 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=", 816 | "dev": true 817 | }, 818 | "json-parse-better-errors": { 819 | "version": "1.0.2", 820 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 821 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 822 | "dev": true 823 | }, 824 | "keyv": { 825 | "version": "3.1.0", 826 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz", 827 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==", 828 | "dev": true, 829 | "requires": { 830 | "json-buffer": "3.0.0" 831 | } 832 | }, 833 | "latest-version": { 834 | "version": "5.1.0", 835 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz", 836 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==", 837 | "dev": true, 838 | "requires": { 839 | "package-json": "^6.3.0" 840 | } 841 | }, 842 | "load-json-file": { 843 | "version": "4.0.0", 844 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 845 | "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", 846 | "dev": true, 847 | "requires": { 848 | "graceful-fs": "^4.1.2", 849 | "parse-json": "^4.0.0", 850 | "pify": "^3.0.0", 851 | "strip-bom": "^3.0.0" 852 | } 853 | }, 854 | "lowercase-keys": { 855 | "version": "1.0.1", 856 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 857 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==", 858 | "dev": true 859 | }, 860 | "lru-cache": { 861 | "version": "6.0.0", 862 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 863 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 864 | "dev": true, 865 | "requires": { 866 | "yallist": "^4.0.0" 867 | } 868 | }, 869 | "make-dir": { 870 | "version": "3.1.0", 871 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 872 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 873 | "dev": true, 874 | "requires": { 875 | "semver": "^6.0.0" 876 | }, 877 | "dependencies": { 878 | "semver": { 879 | "version": "6.3.0", 880 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 881 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 882 | "dev": true 883 | } 884 | } 885 | }, 886 | "memorystream": { 887 | "version": "0.3.1", 888 | "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", 889 | "integrity": "sha1-htcJCzDORV1j+64S3aUaR93K+bI=", 890 | "dev": true 891 | }, 892 | "mimic-response": { 893 | "version": "1.0.1", 894 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", 895 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==", 896 | "dev": true 897 | }, 898 | "minimatch": { 899 | "version": "3.1.2", 900 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 901 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 902 | "dev": true, 903 | "requires": { 904 | "brace-expansion": "^1.1.7" 905 | } 906 | }, 907 | "minimist": { 908 | "version": "1.2.6", 909 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 910 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 911 | "dev": true 912 | }, 913 | "ms": { 914 | "version": "2.1.3", 915 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 916 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 917 | "dev": true 918 | }, 919 | "nice-try": { 920 | "version": "1.0.5", 921 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 922 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 923 | "dev": true 924 | }, 925 | "nodemon": { 926 | "version": "2.0.15", 927 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.15.tgz", 928 | "integrity": "sha512-gdHMNx47Gw7b3kWxJV64NI+Q5nfl0y5DgDbiVtShiwa7Z0IZ07Ll4RLFo6AjrhzMtoEZn5PDE3/c2AbVsiCkpA==", 929 | "dev": true, 930 | "requires": { 931 | "chokidar": "^3.5.2", 932 | "debug": "^3.2.7", 933 | "ignore-by-default": "^1.0.1", 934 | "minimatch": "^3.0.4", 935 | "pstree.remy": "^1.1.8", 936 | "semver": "^5.7.1", 937 | "supports-color": "^5.5.0", 938 | "touch": "^3.1.0", 939 | "undefsafe": "^2.0.5", 940 | "update-notifier": "^5.1.0" 941 | } 942 | }, 943 | "nopt": { 944 | "version": "1.0.10", 945 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 946 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 947 | "dev": true, 948 | "requires": { 949 | "abbrev": "1" 950 | } 951 | }, 952 | "normalize-package-data": { 953 | "version": "2.5.0", 954 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 955 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 956 | "dev": true, 957 | "requires": { 958 | "hosted-git-info": "^2.1.4", 959 | "resolve": "^1.10.0", 960 | "semver": "2 || 3 || 4 || 5", 961 | "validate-npm-package-license": "^3.0.1" 962 | } 963 | }, 964 | "normalize-path": { 965 | "version": "3.0.0", 966 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 967 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 968 | "dev": true 969 | }, 970 | "normalize-url": { 971 | "version": "4.5.1", 972 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.1.tgz", 973 | "integrity": "sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA==", 974 | "dev": true 975 | }, 976 | "npm-run-all": { 977 | "version": "4.1.5", 978 | "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", 979 | "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", 980 | "dev": true, 981 | "requires": { 982 | "ansi-styles": "^3.2.1", 983 | "chalk": "^2.4.1", 984 | "cross-spawn": "^6.0.5", 985 | "memorystream": "^0.3.1", 986 | "minimatch": "^3.0.4", 987 | "pidtree": "^0.3.0", 988 | "read-pkg": "^3.0.0", 989 | "shell-quote": "^1.6.1", 990 | "string.prototype.padend": "^3.0.0" 991 | }, 992 | "dependencies": { 993 | "ansi-styles": { 994 | "version": "3.2.1", 995 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 996 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 997 | "dev": true, 998 | "requires": { 999 | "color-convert": "^1.9.0" 1000 | } 1001 | }, 1002 | "chalk": { 1003 | "version": "2.4.2", 1004 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1005 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1006 | "dev": true, 1007 | "requires": { 1008 | "ansi-styles": "^3.2.1", 1009 | "escape-string-regexp": "^1.0.5", 1010 | "supports-color": "^5.3.0" 1011 | } 1012 | }, 1013 | "color-convert": { 1014 | "version": "1.9.3", 1015 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1016 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1017 | "dev": true, 1018 | "requires": { 1019 | "color-name": "1.1.3" 1020 | } 1021 | }, 1022 | "color-name": { 1023 | "version": "1.1.3", 1024 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1025 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 1026 | "dev": true 1027 | } 1028 | } 1029 | }, 1030 | "object-inspect": { 1031 | "version": "1.12.0", 1032 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.0.tgz", 1033 | "integrity": "sha512-Ho2z80bVIvJloH+YzRmpZVQe87+qASmBUKZDWgx9cu+KDrX2ZDH/3tMy+gXbZETVGs2M8YdxObOh7XAtim9Y0g==", 1034 | "dev": true 1035 | }, 1036 | "object-keys": { 1037 | "version": "1.1.1", 1038 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1039 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1040 | "dev": true 1041 | }, 1042 | "object.assign": { 1043 | "version": "4.1.2", 1044 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz", 1045 | "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==", 1046 | "dev": true, 1047 | "requires": { 1048 | "call-bind": "^1.0.0", 1049 | "define-properties": "^1.1.3", 1050 | "has-symbols": "^1.0.1", 1051 | "object-keys": "^1.1.1" 1052 | } 1053 | }, 1054 | "once": { 1055 | "version": "1.4.0", 1056 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1057 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1058 | "dev": true, 1059 | "requires": { 1060 | "wrappy": "1" 1061 | } 1062 | }, 1063 | "p-cancelable": { 1064 | "version": "1.1.0", 1065 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz", 1066 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==", 1067 | "dev": true 1068 | }, 1069 | "package-json": { 1070 | "version": "6.5.0", 1071 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz", 1072 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==", 1073 | "dev": true, 1074 | "requires": { 1075 | "got": "^9.6.0", 1076 | "registry-auth-token": "^4.0.0", 1077 | "registry-url": "^5.0.0", 1078 | "semver": "^6.2.0" 1079 | }, 1080 | "dependencies": { 1081 | "semver": { 1082 | "version": "6.3.0", 1083 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1084 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1085 | "dev": true 1086 | } 1087 | } 1088 | }, 1089 | "parse-json": { 1090 | "version": "4.0.0", 1091 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 1092 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 1093 | "dev": true, 1094 | "requires": { 1095 | "error-ex": "^1.3.1", 1096 | "json-parse-better-errors": "^1.0.1" 1097 | } 1098 | }, 1099 | "path-key": { 1100 | "version": "2.0.1", 1101 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1102 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1103 | "dev": true 1104 | }, 1105 | "path-parse": { 1106 | "version": "1.0.7", 1107 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1108 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1109 | "dev": true 1110 | }, 1111 | "path-type": { 1112 | "version": "3.0.0", 1113 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", 1114 | "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", 1115 | "dev": true, 1116 | "requires": { 1117 | "pify": "^3.0.0" 1118 | } 1119 | }, 1120 | "picomatch": { 1121 | "version": "2.3.1", 1122 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1123 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1124 | "dev": true 1125 | }, 1126 | "pidtree": { 1127 | "version": "0.3.1", 1128 | "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.1.tgz", 1129 | "integrity": "sha512-qQbW94hLHEqCg7nhby4yRC7G2+jYHY4Rguc2bjw7Uug4GIJuu1tvf2uHaZv5Q8zdt+WKJ6qK1FOI6amaWUo5FA==", 1130 | "dev": true 1131 | }, 1132 | "pify": { 1133 | "version": "3.0.0", 1134 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 1135 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 1136 | "dev": true 1137 | }, 1138 | "prepend-http": { 1139 | "version": "2.0.0", 1140 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz", 1141 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=", 1142 | "dev": true 1143 | }, 1144 | "pstree.remy": { 1145 | "version": "1.1.8", 1146 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1147 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 1148 | "dev": true 1149 | }, 1150 | "pump": { 1151 | "version": "3.0.0", 1152 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1153 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1154 | "dev": true, 1155 | "requires": { 1156 | "end-of-stream": "^1.1.0", 1157 | "once": "^1.3.1" 1158 | } 1159 | }, 1160 | "pupa": { 1161 | "version": "2.1.1", 1162 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz", 1163 | "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==", 1164 | "dev": true, 1165 | "requires": { 1166 | "escape-goat": "^2.0.0" 1167 | } 1168 | }, 1169 | "rc": { 1170 | "version": "1.2.8", 1171 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1172 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1173 | "dev": true, 1174 | "requires": { 1175 | "deep-extend": "^0.6.0", 1176 | "ini": "~1.3.0", 1177 | "minimist": "^1.2.0", 1178 | "strip-json-comments": "~2.0.1" 1179 | }, 1180 | "dependencies": { 1181 | "ini": { 1182 | "version": "1.3.8", 1183 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 1184 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==", 1185 | "dev": true 1186 | } 1187 | } 1188 | }, 1189 | "read-pkg": { 1190 | "version": "3.0.0", 1191 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", 1192 | "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", 1193 | "dev": true, 1194 | "requires": { 1195 | "load-json-file": "^4.0.0", 1196 | "normalize-package-data": "^2.3.2", 1197 | "path-type": "^3.0.0" 1198 | } 1199 | }, 1200 | "readdirp": { 1201 | "version": "3.6.0", 1202 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1203 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1204 | "dev": true, 1205 | "requires": { 1206 | "picomatch": "^2.2.1" 1207 | } 1208 | }, 1209 | "registry-auth-token": { 1210 | "version": "4.2.1", 1211 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.1.tgz", 1212 | "integrity": "sha512-6gkSb4U6aWJB4SF2ZvLb76yCBjcvufXBqvvEx1HbmKPkutswjW1xNVRY0+daljIYRbogN7O0etYSlbiaEQyMyw==", 1213 | "dev": true, 1214 | "requires": { 1215 | "rc": "^1.2.8" 1216 | } 1217 | }, 1218 | "registry-url": { 1219 | "version": "5.1.0", 1220 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz", 1221 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==", 1222 | "dev": true, 1223 | "requires": { 1224 | "rc": "^1.2.8" 1225 | } 1226 | }, 1227 | "resolve": { 1228 | "version": "1.22.0", 1229 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz", 1230 | "integrity": "sha512-Hhtrw0nLeSrFQ7phPp4OOcVjLPIeMnRlr5mcnVuMe7M/7eBn98A3hmFRLoFo3DLZkivSYwhRUJTyPyWAk56WLw==", 1231 | "dev": true, 1232 | "requires": { 1233 | "is-core-module": "^2.8.1", 1234 | "path-parse": "^1.0.7", 1235 | "supports-preserve-symlinks-flag": "^1.0.0" 1236 | } 1237 | }, 1238 | "responselike": { 1239 | "version": "1.0.2", 1240 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz", 1241 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=", 1242 | "dev": true, 1243 | "requires": { 1244 | "lowercase-keys": "^1.0.0" 1245 | } 1246 | }, 1247 | "semver": { 1248 | "version": "5.7.1", 1249 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1250 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1251 | "dev": true 1252 | }, 1253 | "semver-diff": { 1254 | "version": "3.1.1", 1255 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz", 1256 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==", 1257 | "dev": true, 1258 | "requires": { 1259 | "semver": "^6.3.0" 1260 | }, 1261 | "dependencies": { 1262 | "semver": { 1263 | "version": "6.3.0", 1264 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1265 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1266 | "dev": true 1267 | } 1268 | } 1269 | }, 1270 | "shebang-command": { 1271 | "version": "1.2.0", 1272 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1273 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1274 | "dev": true, 1275 | "requires": { 1276 | "shebang-regex": "^1.0.0" 1277 | } 1278 | }, 1279 | "shebang-regex": { 1280 | "version": "1.0.0", 1281 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1282 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1283 | "dev": true 1284 | }, 1285 | "shell-quote": { 1286 | "version": "1.7.3", 1287 | "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.7.3.tgz", 1288 | "integrity": "sha512-Vpfqwm4EnqGdlsBFNmHhxhElJYrdfcxPThu+ryKS5J8L/fhAwLazFZtq+S+TWZ9ANj2piSQLGj6NQg+lKPmxrw==", 1289 | "dev": true 1290 | }, 1291 | "side-channel": { 1292 | "version": "1.0.4", 1293 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1294 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1295 | "dev": true, 1296 | "requires": { 1297 | "call-bind": "^1.0.0", 1298 | "get-intrinsic": "^1.0.2", 1299 | "object-inspect": "^1.9.0" 1300 | } 1301 | }, 1302 | "signal-exit": { 1303 | "version": "3.0.7", 1304 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 1305 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 1306 | "dev": true 1307 | }, 1308 | "spdx-correct": { 1309 | "version": "3.1.1", 1310 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", 1311 | "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", 1312 | "dev": true, 1313 | "requires": { 1314 | "spdx-expression-parse": "^3.0.0", 1315 | "spdx-license-ids": "^3.0.0" 1316 | } 1317 | }, 1318 | "spdx-exceptions": { 1319 | "version": "2.3.0", 1320 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 1321 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", 1322 | "dev": true 1323 | }, 1324 | "spdx-expression-parse": { 1325 | "version": "3.0.1", 1326 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 1327 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 1328 | "dev": true, 1329 | "requires": { 1330 | "spdx-exceptions": "^2.1.0", 1331 | "spdx-license-ids": "^3.0.0" 1332 | } 1333 | }, 1334 | "spdx-license-ids": { 1335 | "version": "3.0.11", 1336 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.11.tgz", 1337 | "integrity": "sha512-Ctl2BrFiM0X3MANYgj3CkygxhRmr9mi6xhejbdO960nF6EDJApTYpn0BQnDKlnNBULKiCN1n3w9EBkHK8ZWg+g==", 1338 | "dev": true 1339 | }, 1340 | "string-width": { 1341 | "version": "4.2.3", 1342 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1343 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1344 | "dev": true, 1345 | "requires": { 1346 | "emoji-regex": "^8.0.0", 1347 | "is-fullwidth-code-point": "^3.0.0", 1348 | "strip-ansi": "^6.0.1" 1349 | } 1350 | }, 1351 | "string.prototype.padend": { 1352 | "version": "3.1.3", 1353 | "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.3.tgz", 1354 | "integrity": "sha512-jNIIeokznm8SD/TZISQsZKYu7RJyheFNt84DUPrh482GC8RVp2MKqm2O5oBRdGxbDQoXrhhWtPIWQOiy20svUg==", 1355 | "dev": true, 1356 | "requires": { 1357 | "call-bind": "^1.0.2", 1358 | "define-properties": "^1.1.3", 1359 | "es-abstract": "^1.19.1" 1360 | } 1361 | }, 1362 | "string.prototype.trimend": { 1363 | "version": "1.0.4", 1364 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.4.tgz", 1365 | "integrity": "sha512-y9xCjw1P23Awk8EvTpcyL2NIr1j7wJ39f+k6lvRnSMz+mz9CGz9NYPelDk42kOz6+ql8xjfK8oYzy3jAP5QU5A==", 1366 | "dev": true, 1367 | "requires": { 1368 | "call-bind": "^1.0.2", 1369 | "define-properties": "^1.1.3" 1370 | } 1371 | }, 1372 | "string.prototype.trimstart": { 1373 | "version": "1.0.4", 1374 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.4.tgz", 1375 | "integrity": "sha512-jh6e984OBfvxS50tdY2nRZnoC5/mLFKOREQfw8t5yytkoUsJRNxvI/E39qu1sD0OtWI3OC0XgKSmcWwziwYuZw==", 1376 | "dev": true, 1377 | "requires": { 1378 | "call-bind": "^1.0.2", 1379 | "define-properties": "^1.1.3" 1380 | } 1381 | }, 1382 | "strip-ansi": { 1383 | "version": "6.0.1", 1384 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1385 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1386 | "dev": true, 1387 | "requires": { 1388 | "ansi-regex": "^5.0.1" 1389 | } 1390 | }, 1391 | "strip-bom": { 1392 | "version": "3.0.0", 1393 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1394 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1395 | "dev": true 1396 | }, 1397 | "strip-json-comments": { 1398 | "version": "2.0.1", 1399 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1400 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1401 | "dev": true 1402 | }, 1403 | "supports-color": { 1404 | "version": "5.5.0", 1405 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1406 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1407 | "dev": true, 1408 | "requires": { 1409 | "has-flag": "^3.0.0" 1410 | } 1411 | }, 1412 | "supports-preserve-symlinks-flag": { 1413 | "version": "1.0.0", 1414 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1415 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1416 | "dev": true 1417 | }, 1418 | "to-readable-stream": { 1419 | "version": "1.0.0", 1420 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz", 1421 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==", 1422 | "dev": true 1423 | }, 1424 | "to-regex-range": { 1425 | "version": "5.0.1", 1426 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1427 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1428 | "dev": true, 1429 | "requires": { 1430 | "is-number": "^7.0.0" 1431 | } 1432 | }, 1433 | "touch": { 1434 | "version": "3.1.0", 1435 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1436 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1437 | "dev": true, 1438 | "requires": { 1439 | "nopt": "~1.0.10" 1440 | } 1441 | }, 1442 | "type-fest": { 1443 | "version": "0.20.2", 1444 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1445 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1446 | "dev": true 1447 | }, 1448 | "typedarray-to-buffer": { 1449 | "version": "3.1.5", 1450 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 1451 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 1452 | "dev": true, 1453 | "requires": { 1454 | "is-typedarray": "^1.0.0" 1455 | } 1456 | }, 1457 | "typescript": { 1458 | "version": "4.6.3", 1459 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.6.3.tgz", 1460 | "integrity": "sha512-yNIatDa5iaofVozS/uQJEl3JRWLKKGJKh6Yaiv0GLGSuhpFJe7P3SbHZ8/yjAHRQwKRoA6YZqlfjXWmVzoVSMw==" 1461 | }, 1462 | "unbox-primitive": { 1463 | "version": "1.0.1", 1464 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.1.tgz", 1465 | "integrity": "sha512-tZU/3NqK3dA5gpE1KtyiJUrEB0lxnGkMFHptJ7q6ewdZ8s12QrODwNbhIJStmJkd1QDXa1NRA8aF2A1zk/Ypyw==", 1466 | "dev": true, 1467 | "requires": { 1468 | "function-bind": "^1.1.1", 1469 | "has-bigints": "^1.0.1", 1470 | "has-symbols": "^1.0.2", 1471 | "which-boxed-primitive": "^1.0.2" 1472 | } 1473 | }, 1474 | "undefsafe": { 1475 | "version": "2.0.5", 1476 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 1477 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 1478 | "dev": true 1479 | }, 1480 | "unique-string": { 1481 | "version": "2.0.0", 1482 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", 1483 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", 1484 | "dev": true, 1485 | "requires": { 1486 | "crypto-random-string": "^2.0.0" 1487 | } 1488 | }, 1489 | "update-notifier": { 1490 | "version": "5.1.0", 1491 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-5.1.0.tgz", 1492 | "integrity": "sha512-ItnICHbeMh9GqUy31hFPrD1kcuZ3rpxDZbf4KUDavXwS0bW5m7SLbDQpGX3UYr072cbrF5hFUs3r5tUsPwjfHw==", 1493 | "dev": true, 1494 | "requires": { 1495 | "boxen": "^5.0.0", 1496 | "chalk": "^4.1.0", 1497 | "configstore": "^5.0.1", 1498 | "has-yarn": "^2.1.0", 1499 | "import-lazy": "^2.1.0", 1500 | "is-ci": "^2.0.0", 1501 | "is-installed-globally": "^0.4.0", 1502 | "is-npm": "^5.0.0", 1503 | "is-yarn-global": "^0.3.0", 1504 | "latest-version": "^5.1.0", 1505 | "pupa": "^2.1.1", 1506 | "semver": "^7.3.4", 1507 | "semver-diff": "^3.1.1", 1508 | "xdg-basedir": "^4.0.0" 1509 | }, 1510 | "dependencies": { 1511 | "semver": { 1512 | "version": "7.3.7", 1513 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz", 1514 | "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==", 1515 | "dev": true, 1516 | "requires": { 1517 | "lru-cache": "^6.0.0" 1518 | } 1519 | } 1520 | } 1521 | }, 1522 | "url-parse-lax": { 1523 | "version": "3.0.0", 1524 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz", 1525 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=", 1526 | "dev": true, 1527 | "requires": { 1528 | "prepend-http": "^2.0.0" 1529 | } 1530 | }, 1531 | "validate-npm-package-license": { 1532 | "version": "3.0.4", 1533 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 1534 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 1535 | "dev": true, 1536 | "requires": { 1537 | "spdx-correct": "^3.0.0", 1538 | "spdx-expression-parse": "^3.0.0" 1539 | } 1540 | }, 1541 | "which": { 1542 | "version": "1.3.1", 1543 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1544 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1545 | "dev": true, 1546 | "requires": { 1547 | "isexe": "^2.0.0" 1548 | } 1549 | }, 1550 | "which-boxed-primitive": { 1551 | "version": "1.0.2", 1552 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 1553 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 1554 | "dev": true, 1555 | "requires": { 1556 | "is-bigint": "^1.0.1", 1557 | "is-boolean-object": "^1.1.0", 1558 | "is-number-object": "^1.0.4", 1559 | "is-string": "^1.0.5", 1560 | "is-symbol": "^1.0.3" 1561 | } 1562 | }, 1563 | "widest-line": { 1564 | "version": "3.1.0", 1565 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz", 1566 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==", 1567 | "dev": true, 1568 | "requires": { 1569 | "string-width": "^4.0.0" 1570 | } 1571 | }, 1572 | "wrap-ansi": { 1573 | "version": "7.0.0", 1574 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1575 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1576 | "dev": true, 1577 | "requires": { 1578 | "ansi-styles": "^4.0.0", 1579 | "string-width": "^4.1.0", 1580 | "strip-ansi": "^6.0.0" 1581 | } 1582 | }, 1583 | "wrappy": { 1584 | "version": "1.0.2", 1585 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1586 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1587 | "dev": true 1588 | }, 1589 | "write-file-atomic": { 1590 | "version": "3.0.3", 1591 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 1592 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 1593 | "dev": true, 1594 | "requires": { 1595 | "imurmurhash": "^0.1.4", 1596 | "is-typedarray": "^1.0.0", 1597 | "signal-exit": "^3.0.2", 1598 | "typedarray-to-buffer": "^3.1.5" 1599 | } 1600 | }, 1601 | "xdg-basedir": { 1602 | "version": "4.0.0", 1603 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", 1604 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==", 1605 | "dev": true 1606 | }, 1607 | "yallist": { 1608 | "version": "4.0.0", 1609 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1610 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1611 | "dev": true 1612 | } 1613 | } 1614 | } 1615 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "techspecs", 3 | "version": "1.0.0", 4 | "description": "Progamtically get the standardized specs of over 61,000 consumer electronics devices, including the latest smartphones, tablets, smartwatches, laptops, and more.", 5 | "main": "dist/index.js", 6 | "types": "dist/index.d.ts", 7 | "keywords": [ 8 | "techspecs, laptop specs, laptop database, smartphones specs, smartphone database, tablet specs, tablet database, smartwatch specs, smartwatch database" 9 | ], 10 | "homepage": "https://github.com/techspecs/techspecs-node", 11 | "bugs": { 12 | "url": "https://github.com/techspecs/techspecs-node" 13 | }, 14 | "repository": { 15 | "type": "git", 16 | "url": "https://github.com/techspecs/techspecs-node" 17 | }, 18 | "author": { 19 | "name": "TechSpecs" 20 | }, 21 | "scripts": { 22 | "test": "npm run build && jest", 23 | "serve": "npm-run-all --parallel build-watch dev", 24 | "build-watch": "tsc -w", 25 | "dev": "nodemon --watch lib --exec \"node lib/index.js\"", 26 | "build": "tsc -p tsconfig-build.json", 27 | "prepublish": "npm run build" 28 | }, 29 | "license": "MIT", 30 | "dependencies": { 31 | "axios": "^0.26.1", 32 | "typescript": "^4.6.3" 33 | }, 34 | "devDependencies": { 35 | "nodemon": "^2.0.15", 36 | "npm-run-all": "^4.1.5" 37 | } 38 | } 39 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | import axios from "axios"; 2 | import { query, mode, dateObj } from "./types"; 3 | 4 | async function search( 5 | techspecs_base: string, 6 | query: query, 7 | key: string, 8 | mode: mode = "raw" 9 | ) { 10 | const url = `https://apis.dashboard.techspecs.io/${techspecs_base}/api/product/search?query=${query.keyword.replace( 11 | " ", 12 | "%20" 13 | )}`; 14 | const headers = { 15 | Accept: "application/json", 16 | "x-blobr-key": key, 17 | "Content-Type": "application/json", 18 | }; 19 | const payload = { category: query.category }; 20 | const req = await axios.post(url, payload, { 21 | headers: headers, 22 | }); 23 | 24 | if (mode === "raw") { 25 | return req.data.data; 26 | } else if (mode === "pretty") { 27 | try { 28 | return req.data.data.results; 29 | } catch (err) { 30 | return req.data.data; 31 | } 32 | } else { 33 | return "Invalid Mode"; 34 | } 35 | } 36 | 37 | async function detail( 38 | techspecs_base: string, 39 | techspecs_id: string, 40 | key: string, 41 | mode = "raw" 42 | ) { 43 | const url = `https://apis.dashboard.techspecs.io/${techspecs_base}/api/product/get/${techspecs_id}`; 44 | const header = { 45 | Accept: "application/json", 46 | "Accept-Encoding": "gzip, deflate", 47 | "x-blobr-key": key, 48 | }; 49 | const req = await axios.get(url, { 50 | headers: header, 51 | }); 52 | if (mode === "raw") { 53 | return req.data.data; 54 | } else if (mode === "pretty") { 55 | try { 56 | const mod_list = req.data.data.product; 57 | const modified_data = []; 58 | for (const m of mod_list) { 59 | // destruct object upto 2 levels 60 | const mod_object: Object = {}; 61 | 62 | for (const [key, value] of Object.entries(m)) { 63 | if (typeof value === "object") { 64 | for (const [key2, value2] of Object.entries(value as object)) { 65 | // @ts-ignore 66 | mod_object[key2] = value2; 67 | } 68 | } else { 69 | // @ts-ignore 70 | mod_object[key] = value; 71 | } 72 | } 73 | modified_data.push(mod_object); 74 | } 75 | return modified_data; 76 | } catch (err) { 77 | return req.data.data; 78 | } 79 | } else { 80 | return "Invalid Mode"; 81 | } 82 | } 83 | 84 | async function brands(techspecs_base: string, key: string, mode = "raw") { 85 | const url = `https://apis.dashboard.techspecs.io/${techspecs_base}/api/product/brands`; 86 | const header = { 87 | Accept: "application/json", 88 | "x-blobr-key": key, 89 | }; 90 | const req = await axios.get(url, { 91 | headers: header, 92 | }); 93 | if (mode === "raw") { 94 | return req.data.data; 95 | } else if (mode === "pretty") { 96 | try { 97 | return req.data.data.brands; 98 | } catch (err) { 99 | return req.data.data; 100 | } 101 | } else { 102 | return "Invalid Mode"; 103 | } 104 | } 105 | 106 | async function categories(techspecs_base: string, key: string, mode = "raw") { 107 | const url = `https://apis.dashboard.techspecs.io/${techspecs_base}/api/category/getAll`; 108 | const header = { 109 | Accept: "application/json", 110 | "x-blobr-key": key, 111 | }; 112 | const req = await axios.get(url, { 113 | headers: header, 114 | }); 115 | if (mode === "raw") { 116 | return req.data.data; 117 | } else if (mode === "pretty") { 118 | try { 119 | return req.data.data.Category[1]; 120 | } catch (err) { 121 | return req.data.data; 122 | } 123 | } else { 124 | return "Invalid Mode"; 125 | } 126 | } 127 | 128 | async function products( 129 | techspecs_base: string, 130 | brand: string[], 131 | category: string[], 132 | date: dateObj, 133 | page: number, 134 | key: string, 135 | mode = "raw" 136 | ) { 137 | const url = `https://apis.dashboard.techspecs.io/${techspecs_base}/api/product/getAll?page=${page}`; 138 | const header = { 139 | Accept: "application/json", 140 | "x-blobr-key": key, 141 | "Content-Type": "application/json", 142 | }; 143 | const payload = { 144 | brand: brand, 145 | category: category, 146 | date: date.from, 147 | to: date.to, 148 | }; 149 | 150 | const req = await axios.post(url, payload, { 151 | headers: header, 152 | }); 153 | if (mode === "raw") { 154 | return req.data.data; 155 | } else if (mode === "pretty") { 156 | try { 157 | return req.data.data.product; 158 | } catch (err) { 159 | return req.data.data; 160 | } 161 | } else { 162 | return "Invalid Mode"; 163 | } 164 | } 165 | 166 | export const techspecs = { 167 | search, 168 | detail, 169 | brands, 170 | categories, 171 | products, 172 | }; 173 | -------------------------------------------------------------------------------- /src/types.ts: -------------------------------------------------------------------------------- 1 | export type query = { 2 | category: string; 3 | keyword: string; 4 | }; 5 | 6 | export type mode = "raw" | "pretty"; 7 | 8 | export type dateObj = { 9 | from: string; 10 | to: string; 11 | }; 12 | -------------------------------------------------------------------------------- /test/advanced_search.js: -------------------------------------------------------------------------------- 1 | import { techspecs } from "techspecs"; 2 | 3 | (async () => { 4 | const techspecs_key = "techspecs_api_key"; 5 | const techspecs_base = "a8TD3mkN49fhg2y"; 6 | const page = 1; 7 | const brand = ["Apple"]; 8 | const category = ["smartphone"]; 9 | const date = { 10 | from: "2010-01-01", 11 | to: "2022-03-15", 12 | }; 13 | 14 | const response = await techspecs.products( 15 | techspecs_base, 16 | brand, 17 | category, 18 | date, 19 | page, 20 | techspecs_key, 21 | "pretty" 22 | ); 23 | 24 | console.log(response); 25 | })(); 26 | -------------------------------------------------------------------------------- /test/all-brands.js: -------------------------------------------------------------------------------- 1 | import { techspecs } from "techspecs"; 2 | 3 | (async () => { 4 | const techspecs_key = "techspecs_api_key"; 5 | const techspecs_base = "a8TD3mkN49fhg2y"; 6 | const response = await techspecs.brands( 7 | techspecs_base, 8 | techspecs_key, 9 | (mode = "pretty") 10 | ); 11 | 12 | console.log(response); 13 | })(); 14 | -------------------------------------------------------------------------------- /test/all_categories.js: -------------------------------------------------------------------------------- 1 | import { techspecs } from "techspecs"; 2 | 3 | (async () => { 4 | const techspecs_key = "techspecs_api_key"; 5 | const techspecs_base = "a8TD3mkN49fhg2y"; 6 | const response = await techspecs.categories( 7 | techspecs_base, 8 | techspecs_key, 9 | (mode = "pretty") 10 | ); 11 | 12 | console.log(response); 13 | })(); 14 | -------------------------------------------------------------------------------- /test/basic_search.js: -------------------------------------------------------------------------------- 1 | import { techspecs } from "techspecs"; 2 | 3 | (async () => { 4 | const techspecs_key = "techspecs_api_key"; 5 | const techspecs_base = "a8TD3mkN49fhg2y"; 6 | const query = { 7 | keyword: "iPhone 13", 8 | category: "all", 9 | }; 10 | const response = await techspecs.search(base, query, key, (mode = "pretty")); 11 | 12 | console.log(response); 13 | })(); 14 | -------------------------------------------------------------------------------- /test/product_detail.js: -------------------------------------------------------------------------------- 1 | import { techspecs } from "techspecs"; 2 | 3 | (async () => { 4 | const techspecs_key = "techspecs_api_key"; 5 | const techspecs_base = "a8TD3mkN49fhg2y"; 6 | const techspecs_id = "6186b047987cda5f88311983"; 7 | const response = await techspecs.detail( 8 | techspecs_base, 9 | techspecs_id, 10 | techspecs_key, 11 | (mode = "pretty") 12 | ); 13 | 14 | console.log(response); 15 | })(); 16 | -------------------------------------------------------------------------------- /tsconfig-build.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es2020", 4 | "module": "commonjs", 5 | "strict": true, 6 | "outDir": "dist", 7 | "removeComments": true, 8 | "resolveJsonModule": true, 9 | "declaration": true 10 | }, 11 | "include": ["src/*"], 12 | "exclude": ["node_modules", "dist", "lib"] 13 | } 14 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es2020", 4 | "module": "commonjs", 5 | "strict": true, 6 | "outDir": "lib", 7 | "removeComments": false, 8 | "sourceMap": true, 9 | "resolveJsonModule": true, 10 | "declaration": true 11 | }, 12 | "include": ["src/*"], 13 | "exclude": ["node_modules", "dist", "lib"] 14 | } 15 | --------------------------------------------------------------------------------