├── .gitignore ├── .prettierrc ├── README.md ├── config.js ├── index.d.ts ├── index.js ├── package-lock.json ├── package.json └── test └── basic.test.js /.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 | .DS_Store 106 | -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | {} -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # openai-api 2 | 3 | ## Overview 4 | This package is a tiny node wrapper for the openAI API, if you find any issue please feel free to message me or open a PR :). 5 | 6 | ### A few words from GPT-3 ### 7 | If you have any ideas on how to improve the library feel free to let me know as well! 8 | 9 | You can also visit the Issue tracker for more information or open a new issue. 10 | 11 | This project is not affiliated with OpenAI and was written purely out of interest. 12 | 13 | ## Installation 14 | 15 | `npm i openai-api` 16 | 17 | ## Usage 18 | 19 | ### Initializing 20 | ```js 21 | const OpenAI = require('openai-api'); 22 | 23 | // Load your key from an environment variable or secret management service 24 | // (do not include your key directly in your code) 25 | const OPENAI_API_KEY = process.env.OPENAI_API_KEY; 26 | 27 | const openai = new OpenAI(OPENAI_API_KEY); 28 | ``` 29 | 30 | ### Completion API call 31 | ```js 32 | (async () => { 33 | const gptResponse = await openai.complete({ 34 | engine: 'davinci', 35 | prompt: 'this is a test', 36 | maxTokens: 5, 37 | temperature: 0.9, 38 | topP: 1, 39 | presencePenalty: 0, 40 | frequencyPenalty: 0, 41 | bestOf: 1, 42 | n: 1, 43 | stream: false, 44 | stop: ['\n', "testing"] 45 | }); 46 | 47 | console.log(gptResponse.data); 48 | })(); 49 | ``` 50 | 51 | #### Example of a successful completion response: 52 | ```js 53 | { 54 | id: 'some-long-id', 55 | object: 'text_completion', 56 | created: 1616791508, 57 | model: 'davinci:2020-05-03', 58 | choices: [ 59 | { 60 | text: " predicted text...", 61 | index: 0, 62 | logprobs: null, 63 | finish_reason: 'length' 64 | } 65 | ] 66 | } 67 | ``` 68 | 69 | ### Search API call 70 | 71 | ```js 72 | (async () => { 73 | const gptResponse = await openai.search({ 74 | engine: 'davinci', 75 | documents: ["White House", "hospital", "school"], 76 | query: "the president" 77 | }); 78 | 79 | console.log(gptResponse.data); 80 | })(); 81 | ``` 82 | 83 | 84 | ### Answers API call 85 | 86 | ```js 87 | (async () => { 88 | const gptResponse = await openai.answers({ 89 | "documents": ["Puppy A is happy.", "Puppy B is sad."], 90 | "question": "which puppy is happy?", 91 | "search_model": "ada", 92 | "model": "curie", 93 | "examples_context": "In 2017, U.S. life expectancy was 78.6 years.", 94 | "examples": [["What is human life expectancy in the United States?", "78 years."]], 95 | "max_tokens": 5, 96 | "stop": ["\n", "<|endoftext|>"], 97 | }); 98 | 99 | console.log(gptResponse.data); 100 | })(); 101 | ``` 102 | 103 | ### Classification API call 104 | 105 | ```js 106 | (async () => { 107 | const gptResponse = await openai.classification({ 108 | "examples": [ 109 | ["A happy moment", "Positive"], 110 | ["I am sad.", "Negative"], 111 | ["I am feeling awesome", "Positive"] 112 | ], 113 | "labels": ["Positive", "Negative", "Neutral"], 114 | "query": "It is a raining day :(", 115 | "search_model": "ada", 116 | "model": "curie" 117 | }); 118 | 119 | console.log(gptResponse.data); 120 | })(); 121 | ``` 122 | 123 | ### Engines API call 124 | 125 | ```js 126 | (async () => { 127 | const gptResponse = await openai.engines(); 128 | 129 | console.log(gptResponse.data); 130 | })(); 131 | ``` 132 | 133 | ### Embeddings API call 134 | Documentation: [https://beta.openai.com/docs/api-reference/embeddings](https://beta.openai.com/docs/api-reference/embeddings) 135 | 136 | ```js 137 | (async () => { 138 | const gptResponse = await openai.embeddings({ 139 | "engine": "text-similarity-babbage-001", 140 | "input": [ 141 | "A happy moment", 142 | "I am sad.", 143 | "I am feeling awesome" 144 | ], 145 | }); 146 | 147 | console.log(gptResponse.data); // see index.d.ts interface Embedding 148 | })(); 149 | ``` 150 | 151 | 152 | ### Get number of tokens for string 153 | #### Not supported as of 4/21. See issue #20 154 | The token limit is 2048 for completions using the OpenAI API. This method allows you to get the number of tokens in your prompt. This is done offline (no API call is made). 155 | 156 | ```js 157 | openai.encode('This is an encoding test. Number of tokens is not necessarily the same as word count.').then((result) => { 158 | console.log("Number of tokens for string:" + result.length); 159 | }); 160 | ``` 161 | 162 | ------- 163 | Powered by [Obelisk.ooo](https://obelisk.ooo) 164 | -------------------------------------------------------------------------------- /config.js: -------------------------------------------------------------------------------- 1 | const DEFAULT_ENGINE = 'davinci'; 2 | const ORIGIN = 'https://api.openai.com'; 3 | const API_VERSION = 'v1'; 4 | const OPEN_AI_URL = `${ORIGIN}/${API_VERSION}`; 5 | 6 | module.exports = { 7 | completionURL(engine) { 8 | return `${OPEN_AI_URL}/engines/${engine}/completions`; 9 | }, 10 | searchURL(engine) { 11 | return `${OPEN_AI_URL}/engines/${engine}/search`; 12 | }, 13 | enginesUrl() { 14 | return `${OPEN_AI_URL}/engines`; 15 | }, 16 | engineUrl(engine) { 17 | return `${OPEN_AI_URL}/engines/${engine}`; 18 | }, 19 | classificationsUrl() { 20 | return `${OPEN_AI_URL}/classifications`; 21 | }, 22 | filesUrl() { 23 | return `${OPEN_AI_URL}/files`; 24 | }, 25 | answersUrl() { 26 | return `${OPEN_AI_URL}/answers`; 27 | }, 28 | embeddingsUrl(engine) { 29 | return `${OPEN_AI_URL}/engines/${engine}/embeddings`; 30 | }, 31 | chatURL() { 32 | return `${OPEN_AI_URL}/chat/completions`; 33 | } 34 | }; 35 | -------------------------------------------------------------------------------- /index.d.ts: -------------------------------------------------------------------------------- 1 | declare module 'openai-api' { 2 | export interface CompletionOpts { 3 | engine: string; 4 | prompt?: string; 5 | maxTokens?: number; 6 | temperature?: number; 7 | topP?: number; 8 | n?: number; 9 | stream?: boolean; 10 | logprobs?: number; 11 | echo?: boolean; 12 | stop?: string | string[]; 13 | presencePenalty?: number; 14 | frequencyPenalty?: number; 15 | bestOf?: number; 16 | user?: string; 17 | logitBias?: { [token: string]: number; }; 18 | } 19 | 20 | export interface Completion { 21 | data: { 22 | id: string; 23 | object: string; 24 | created: number; 25 | model: string; 26 | choices: Choice[]; 27 | }; 28 | } 29 | 30 | export interface Choice { 31 | text: string; 32 | index: number; 33 | logprobs: any; 34 | finish_reason: string; 35 | } 36 | 37 | export interface SearchOpts { 38 | engine: string; 39 | documents?: string[]; 40 | file?: string; 41 | query: string; 42 | maxRerank?: number; 43 | returnMetadata?: boolean; 44 | } 45 | 46 | export interface Search { 47 | data: Document[]; 48 | object: string; 49 | } 50 | 51 | export interface Document { 52 | document: number; 53 | object: string; 54 | score: number; 55 | metadata?: any; 56 | } 57 | 58 | export interface Embedding { 59 | object: string; 60 | data: EmbeddingData[]; 61 | model: string; 62 | } 63 | 64 | export interface EmbeddingData { 65 | object: string; 66 | index: number; 67 | embedding: number[]; 68 | } 69 | 70 | export interface ChatOpts { 71 | model: string; 72 | message: ChatMessage[]; 73 | max_tokens?: number; 74 | temperature?: number; 75 | top_p?: number; 76 | n?: number; 77 | stream?: boolean; 78 | logprobs?: number; 79 | echo?: boolean; 80 | stop?: string | string[]; 81 | presence_penalty?: number; 82 | frequency_penalty?: number; 83 | user?: string; 84 | logit_bias?: { [token: string]: number; }; 85 | } 86 | 87 | export interface ChatResponse { 88 | data: { 89 | id: string; 90 | object: string; 91 | created: number; 92 | model: string; 93 | usage: { prompt_tokens: number, completion_tokens: number, total_tokens: number }; 94 | choices: ChatChoice[]; 95 | }; 96 | } 97 | 98 | export interface ChatChoice { 99 | message: ChatMessage[]; 100 | index: number; 101 | logprobs: any; 102 | finish_reason: string; 103 | } 104 | 105 | export interface ChatMessage { 106 | role: string; 107 | content: string; 108 | } 109 | 110 | class OpenAI { 111 | constructor(api: string); 112 | complete(opts: CompletionOpts): Promise; 113 | encode(str: string): number[]; 114 | search(opts: SearchOpts): Promise; 115 | chat(opts: ChatOpts): Promise; 116 | } 117 | 118 | export default OpenAI; 119 | } 120 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const config = require('./config'); 4 | const axios = require('axios'); 5 | 6 | const DEFAULT_ENGINE = "davinci"; 7 | 8 | class OpenAI { 9 | constructor(api_key) { 10 | this._api_key = api_key; 11 | } 12 | 13 | _send_request(url, method, opts = {}) { 14 | let camelToUnderscore = (key) => { 15 | let result = key.replace(/([A-Z])/g, " $1"); 16 | return result.split(' ').join('_').toLowerCase(); 17 | }; 18 | 19 | const data = {}; 20 | for (const key in opts) { 21 | data[camelToUnderscore(key)] = opts[key]; 22 | } 23 | 24 | return axios({ 25 | url, 26 | headers: { 27 | 'Authorization': `Bearer ${this._api_key}`, 28 | 'Content-Type': 'application/json' 29 | }, 30 | data: Object.keys(data).length ? data : '', 31 | method, 32 | }); 33 | } 34 | 35 | _check_embeddings_engine_name(engine) { 36 | const availableEngineNames = [ 37 | 'text-similarity-ada-001', 38 | 'text-similarity-babbage-001', 39 | 'text-similarity-curie-001', 40 | 'text-similarity-davinci-001', 41 | 'text-search-ada-doc-001', 42 | 'text-search-ada-query-001', 43 | 'text-search-babbage-doc-001', 44 | 'text-search-babbage-query-001', 45 | 'text-search-curie-doc-001', 46 | 'text-search-curie-query-001', 47 | 'text-search-davinci-doc-001', 48 | 'text-search-davinci-query-001', 49 | 'code-search-ada-code-001', 50 | 'code-search-ada-text-001', 51 | 'code-search-babbage-code-001', 52 | 'code-search-babbage-text-001', 53 | ]; 54 | 55 | if (!availableEngineNames.includes(engine)) { 56 | throw new Error(`Unknown engine name for embeddings. Available engine names are ${availableEngineNames}`); 57 | } 58 | } 59 | 60 | complete(opts) { 61 | const url = config.completionURL(opts.engine || DEFAULT_ENGINE); 62 | delete opts.engine; 63 | 64 | return this._send_request(url, 'post', opts); 65 | } 66 | 67 | encode() { 68 | // This method is no longer supported in Node>=v14. See 69 | return Promise.resolve(new Array(2047).fill("")); 70 | } 71 | 72 | search(opts) { 73 | const url = config.searchURL(opts.engine || DEFAULT_ENGINE); 74 | delete opts.engine; 75 | return this._send_request(url, 'post', opts); 76 | } 77 | 78 | answers(opts) { 79 | const url = config.answersUrl(); 80 | return this._send_request(url, 'post', opts); 81 | } 82 | 83 | classification(opts) { 84 | const url = config.classificationsUrl(); 85 | return this._send_request(url, "post", opts); 86 | } 87 | 88 | engines() { 89 | const url = config.enginesUrl(); 90 | return this._send_request(url, 'get'); 91 | } 92 | 93 | engine(engine) { 94 | const url = config.engineUrl(engine); 95 | return this._send_request(url, 'get'); 96 | } 97 | 98 | embeddings(opts) { 99 | this._check_embeddings_engine_name(opts.engine); 100 | 101 | const url = config.embeddingsUrl(opts.engine); 102 | return this._send_request(url, 'post', opts); 103 | } 104 | 105 | chat(opts) { 106 | const url = config.chatURL(); 107 | return this._send_request(url, 'post', opts); 108 | } 109 | } 110 | 111 | module.exports = OpenAI; 112 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "openai-api", 3 | "version": "1.3.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "openai-api", 9 | "version": "1.3.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "axios": "^0.21.1", 13 | "dotenv": "^8.2.0" 14 | }, 15 | "devDependencies": { 16 | "chai": "^4.3.4", 17 | "mocha": "^8.3.2" 18 | } 19 | }, 20 | "node_modules/@ungap/promise-all-settled": { 21 | "version": "1.1.2", 22 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 23 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 24 | "dev": true 25 | }, 26 | "node_modules/ansi-colors": { 27 | "version": "4.1.1", 28 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 29 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 30 | "dev": true, 31 | "engines": { 32 | "node": ">=6" 33 | } 34 | }, 35 | "node_modules/ansi-regex": { 36 | "version": "3.0.1", 37 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.1.tgz", 38 | "integrity": "sha512-+O9Jct8wf++lXxxFc4hc8LsjaSq0HFzzL7cVsw8pRDIPdjKD2mT4ytDZlLuSBZ4cLKZFXIrMGO7DbQCtMJJMKw==", 39 | "dev": true, 40 | "engines": { 41 | "node": ">=4" 42 | } 43 | }, 44 | "node_modules/ansi-styles": { 45 | "version": "4.3.0", 46 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 47 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 48 | "dev": true, 49 | "dependencies": { 50 | "color-convert": "^2.0.1" 51 | }, 52 | "engines": { 53 | "node": ">=8" 54 | } 55 | }, 56 | "node_modules/anymatch": { 57 | "version": "3.1.2", 58 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 59 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 60 | "dev": true, 61 | "dependencies": { 62 | "normalize-path": "^3.0.0", 63 | "picomatch": "^2.0.4" 64 | }, 65 | "engines": { 66 | "node": ">= 8" 67 | } 68 | }, 69 | "node_modules/argparse": { 70 | "version": "2.0.1", 71 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 72 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 73 | "dev": true 74 | }, 75 | "node_modules/assertion-error": { 76 | "version": "1.1.0", 77 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 78 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 79 | "dev": true, 80 | "engines": { 81 | "node": "*" 82 | } 83 | }, 84 | "node_modules/axios": { 85 | "version": "0.21.2", 86 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.21.2.tgz", 87 | "integrity": "sha512-87otirqUw3e8CzHTMO+/9kh/FSgXt/eVDvipijwDtEuwbkySWZ9SBm6VEubmJ/kLKEoLQV/POhxXFb66bfekfg==", 88 | "dependencies": { 89 | "follow-redirects": "^1.14.0" 90 | } 91 | }, 92 | "node_modules/balanced-match": { 93 | "version": "1.0.2", 94 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 95 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 96 | "dev": true 97 | }, 98 | "node_modules/binary-extensions": { 99 | "version": "2.2.0", 100 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 101 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 102 | "dev": true, 103 | "engines": { 104 | "node": ">=8" 105 | } 106 | }, 107 | "node_modules/brace-expansion": { 108 | "version": "1.1.11", 109 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 110 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 111 | "dev": true, 112 | "dependencies": { 113 | "balanced-match": "^1.0.0", 114 | "concat-map": "0.0.1" 115 | } 116 | }, 117 | "node_modules/braces": { 118 | "version": "3.0.2", 119 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 120 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 121 | "dev": true, 122 | "dependencies": { 123 | "fill-range": "^7.0.1" 124 | }, 125 | "engines": { 126 | "node": ">=8" 127 | } 128 | }, 129 | "node_modules/browser-stdout": { 130 | "version": "1.3.1", 131 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 132 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 133 | "dev": true 134 | }, 135 | "node_modules/camelcase": { 136 | "version": "6.2.0", 137 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.0.tgz", 138 | "integrity": "sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==", 139 | "dev": true, 140 | "engines": { 141 | "node": ">=10" 142 | } 143 | }, 144 | "node_modules/chai": { 145 | "version": "4.3.4", 146 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.4.tgz", 147 | "integrity": "sha512-yS5H68VYOCtN1cjfwumDSuzn/9c+yza4f3reKXlE5rUg7SFcCEy90gJvydNgOYtblyf4Zi6jIWRnXOgErta0KA==", 148 | "dev": true, 149 | "dependencies": { 150 | "assertion-error": "^1.1.0", 151 | "check-error": "^1.0.2", 152 | "deep-eql": "^3.0.1", 153 | "get-func-name": "^2.0.0", 154 | "pathval": "^1.1.1", 155 | "type-detect": "^4.0.5" 156 | }, 157 | "engines": { 158 | "node": ">=4" 159 | } 160 | }, 161 | "node_modules/chalk": { 162 | "version": "4.1.1", 163 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz", 164 | "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==", 165 | "dev": true, 166 | "dependencies": { 167 | "ansi-styles": "^4.1.0", 168 | "supports-color": "^7.1.0" 169 | }, 170 | "engines": { 171 | "node": ">=10" 172 | } 173 | }, 174 | "node_modules/chalk/node_modules/supports-color": { 175 | "version": "7.2.0", 176 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 177 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 178 | "dev": true, 179 | "dependencies": { 180 | "has-flag": "^4.0.0" 181 | }, 182 | "engines": { 183 | "node": ">=8" 184 | } 185 | }, 186 | "node_modules/check-error": { 187 | "version": "1.0.2", 188 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 189 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 190 | "dev": true, 191 | "engines": { 192 | "node": "*" 193 | } 194 | }, 195 | "node_modules/chokidar": { 196 | "version": "3.5.1", 197 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.1.tgz", 198 | "integrity": "sha512-9+s+Od+W0VJJzawDma/gvBNQqkTiqYTWLuZoyAsivsI4AaWTCzHG06/TMjsf1cYe9Cb97UCEhjz7HvnPk2p/tw==", 199 | "dev": true, 200 | "dependencies": { 201 | "anymatch": "~3.1.1", 202 | "braces": "~3.0.2", 203 | "glob-parent": "~5.1.0", 204 | "is-binary-path": "~2.1.0", 205 | "is-glob": "~4.0.1", 206 | "normalize-path": "~3.0.0", 207 | "readdirp": "~3.5.0" 208 | }, 209 | "engines": { 210 | "node": ">= 8.10.0" 211 | }, 212 | "optionalDependencies": { 213 | "fsevents": "~2.3.1" 214 | } 215 | }, 216 | "node_modules/cliui": { 217 | "version": "7.0.4", 218 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 219 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 220 | "dev": true, 221 | "dependencies": { 222 | "string-width": "^4.2.0", 223 | "strip-ansi": "^6.0.0", 224 | "wrap-ansi": "^7.0.0" 225 | } 226 | }, 227 | "node_modules/cliui/node_modules/ansi-regex": { 228 | "version": "5.0.1", 229 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 230 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 231 | "dev": true, 232 | "engines": { 233 | "node": ">=8" 234 | } 235 | }, 236 | "node_modules/cliui/node_modules/is-fullwidth-code-point": { 237 | "version": "3.0.0", 238 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 239 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 240 | "dev": true, 241 | "engines": { 242 | "node": ">=8" 243 | } 244 | }, 245 | "node_modules/cliui/node_modules/string-width": { 246 | "version": "4.2.2", 247 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 248 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 249 | "dev": true, 250 | "dependencies": { 251 | "emoji-regex": "^8.0.0", 252 | "is-fullwidth-code-point": "^3.0.0", 253 | "strip-ansi": "^6.0.0" 254 | }, 255 | "engines": { 256 | "node": ">=8" 257 | } 258 | }, 259 | "node_modules/cliui/node_modules/strip-ansi": { 260 | "version": "6.0.0", 261 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 262 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 263 | "dev": true, 264 | "dependencies": { 265 | "ansi-regex": "^5.0.0" 266 | }, 267 | "engines": { 268 | "node": ">=8" 269 | } 270 | }, 271 | "node_modules/color-convert": { 272 | "version": "2.0.1", 273 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 274 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 275 | "dev": true, 276 | "dependencies": { 277 | "color-name": "~1.1.4" 278 | }, 279 | "engines": { 280 | "node": ">=7.0.0" 281 | } 282 | }, 283 | "node_modules/color-name": { 284 | "version": "1.1.4", 285 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 286 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 287 | "dev": true 288 | }, 289 | "node_modules/concat-map": { 290 | "version": "0.0.1", 291 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 292 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 293 | "dev": true 294 | }, 295 | "node_modules/debug": { 296 | "version": "4.3.1", 297 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 298 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 299 | "dev": true, 300 | "dependencies": { 301 | "ms": "2.1.2" 302 | }, 303 | "engines": { 304 | "node": ">=6.0" 305 | } 306 | }, 307 | "node_modules/debug/node_modules/ms": { 308 | "version": "2.1.2", 309 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 310 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 311 | "dev": true 312 | }, 313 | "node_modules/decamelize": { 314 | "version": "4.0.0", 315 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 316 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 317 | "dev": true, 318 | "engines": { 319 | "node": ">=10" 320 | } 321 | }, 322 | "node_modules/deep-eql": { 323 | "version": "3.0.1", 324 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 325 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 326 | "dev": true, 327 | "dependencies": { 328 | "type-detect": "^4.0.0" 329 | }, 330 | "engines": { 331 | "node": ">=0.12" 332 | } 333 | }, 334 | "node_modules/diff": { 335 | "version": "5.0.0", 336 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 337 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 338 | "dev": true, 339 | "engines": { 340 | "node": ">=0.3.1" 341 | } 342 | }, 343 | "node_modules/dotenv": { 344 | "version": "8.2.0", 345 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz", 346 | "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==", 347 | "engines": { 348 | "node": ">=8" 349 | } 350 | }, 351 | "node_modules/emoji-regex": { 352 | "version": "8.0.0", 353 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 354 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 355 | "dev": true 356 | }, 357 | "node_modules/escalade": { 358 | "version": "3.1.1", 359 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 360 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 361 | "dev": true, 362 | "engines": { 363 | "node": ">=6" 364 | } 365 | }, 366 | "node_modules/escape-string-regexp": { 367 | "version": "4.0.0", 368 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 369 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 370 | "dev": true, 371 | "engines": { 372 | "node": ">=10" 373 | } 374 | }, 375 | "node_modules/fill-range": { 376 | "version": "7.0.1", 377 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 378 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 379 | "dev": true, 380 | "dependencies": { 381 | "to-regex-range": "^5.0.1" 382 | }, 383 | "engines": { 384 | "node": ">=8" 385 | } 386 | }, 387 | "node_modules/find-up": { 388 | "version": "5.0.0", 389 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 390 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 391 | "dev": true, 392 | "dependencies": { 393 | "locate-path": "^6.0.0", 394 | "path-exists": "^4.0.0" 395 | }, 396 | "engines": { 397 | "node": ">=10" 398 | } 399 | }, 400 | "node_modules/flat": { 401 | "version": "5.0.2", 402 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 403 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 404 | "dev": true, 405 | "bin": { 406 | "flat": "cli.js" 407 | } 408 | }, 409 | "node_modules/follow-redirects": { 410 | "version": "1.14.9", 411 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.9.tgz", 412 | "integrity": "sha512-MQDfihBQYMcyy5dhRDJUHcw7lb2Pv/TuE6xP1vyraLukNDHKbDxDNaOE3NbCAdKQApno+GPRyo1YAp89yCjK4w==", 413 | "funding": [ 414 | { 415 | "type": "individual", 416 | "url": "https://github.com/sponsors/RubenVerborgh" 417 | } 418 | ], 419 | "engines": { 420 | "node": ">=4.0" 421 | }, 422 | "peerDependenciesMeta": { 423 | "debug": { 424 | "optional": true 425 | } 426 | } 427 | }, 428 | "node_modules/fs.realpath": { 429 | "version": "1.0.0", 430 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 431 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 432 | "dev": true 433 | }, 434 | "node_modules/fsevents": { 435 | "version": "2.3.2", 436 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 437 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 438 | "dev": true, 439 | "optional": true, 440 | "os": [ 441 | "darwin" 442 | ], 443 | "engines": { 444 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 445 | } 446 | }, 447 | "node_modules/get-caller-file": { 448 | "version": "2.0.5", 449 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 450 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 451 | "dev": true, 452 | "engines": { 453 | "node": "6.* || 8.* || >= 10.*" 454 | } 455 | }, 456 | "node_modules/get-func-name": { 457 | "version": "2.0.0", 458 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 459 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 460 | "dev": true, 461 | "engines": { 462 | "node": "*" 463 | } 464 | }, 465 | "node_modules/glob": { 466 | "version": "7.1.6", 467 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 468 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 469 | "dev": true, 470 | "dependencies": { 471 | "fs.realpath": "^1.0.0", 472 | "inflight": "^1.0.4", 473 | "inherits": "2", 474 | "minimatch": "^3.0.4", 475 | "once": "^1.3.0", 476 | "path-is-absolute": "^1.0.0" 477 | }, 478 | "engines": { 479 | "node": "*" 480 | } 481 | }, 482 | "node_modules/glob-parent": { 483 | "version": "5.1.2", 484 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 485 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 486 | "dev": true, 487 | "dependencies": { 488 | "is-glob": "^4.0.1" 489 | }, 490 | "engines": { 491 | "node": ">= 6" 492 | } 493 | }, 494 | "node_modules/growl": { 495 | "version": "1.10.5", 496 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 497 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 498 | "dev": true, 499 | "engines": { 500 | "node": ">=4.x" 501 | } 502 | }, 503 | "node_modules/has-flag": { 504 | "version": "4.0.0", 505 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 506 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 507 | "dev": true, 508 | "engines": { 509 | "node": ">=8" 510 | } 511 | }, 512 | "node_modules/he": { 513 | "version": "1.2.0", 514 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 515 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 516 | "dev": true, 517 | "bin": { 518 | "he": "bin/he" 519 | } 520 | }, 521 | "node_modules/inflight": { 522 | "version": "1.0.6", 523 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 524 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 525 | "dev": true, 526 | "dependencies": { 527 | "once": "^1.3.0", 528 | "wrappy": "1" 529 | } 530 | }, 531 | "node_modules/inherits": { 532 | "version": "2.0.4", 533 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 534 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 535 | "dev": true 536 | }, 537 | "node_modules/is-binary-path": { 538 | "version": "2.1.0", 539 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 540 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 541 | "dev": true, 542 | "dependencies": { 543 | "binary-extensions": "^2.0.0" 544 | }, 545 | "engines": { 546 | "node": ">=8" 547 | } 548 | }, 549 | "node_modules/is-extglob": { 550 | "version": "2.1.1", 551 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 552 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 553 | "dev": true, 554 | "engines": { 555 | "node": ">=0.10.0" 556 | } 557 | }, 558 | "node_modules/is-fullwidth-code-point": { 559 | "version": "2.0.0", 560 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 561 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 562 | "dev": true, 563 | "engines": { 564 | "node": ">=4" 565 | } 566 | }, 567 | "node_modules/is-glob": { 568 | "version": "4.0.1", 569 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 570 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 571 | "dev": true, 572 | "dependencies": { 573 | "is-extglob": "^2.1.1" 574 | }, 575 | "engines": { 576 | "node": ">=0.10.0" 577 | } 578 | }, 579 | "node_modules/is-number": { 580 | "version": "7.0.0", 581 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 582 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 583 | "dev": true, 584 | "engines": { 585 | "node": ">=0.12.0" 586 | } 587 | }, 588 | "node_modules/is-plain-obj": { 589 | "version": "2.1.0", 590 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 591 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 592 | "dev": true, 593 | "engines": { 594 | "node": ">=8" 595 | } 596 | }, 597 | "node_modules/isexe": { 598 | "version": "2.0.0", 599 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 600 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 601 | "dev": true 602 | }, 603 | "node_modules/js-yaml": { 604 | "version": "4.0.0", 605 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.0.0.tgz", 606 | "integrity": "sha512-pqon0s+4ScYUvX30wxQi3PogGFAlUyH0awepWvwkj4jD4v+ova3RiYw8bmA6x2rDrEaj8i/oWKoRxpVNW+Re8Q==", 607 | "dev": true, 608 | "dependencies": { 609 | "argparse": "^2.0.1" 610 | }, 611 | "bin": { 612 | "js-yaml": "bin/js-yaml.js" 613 | } 614 | }, 615 | "node_modules/locate-path": { 616 | "version": "6.0.0", 617 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 618 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 619 | "dev": true, 620 | "dependencies": { 621 | "p-locate": "^5.0.0" 622 | }, 623 | "engines": { 624 | "node": ">=10" 625 | } 626 | }, 627 | "node_modules/log-symbols": { 628 | "version": "4.0.0", 629 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.0.0.tgz", 630 | "integrity": "sha512-FN8JBzLx6CzeMrB0tg6pqlGU1wCrXW+ZXGH481kfsBqer0hToTIiHdjH4Mq8xJUbvATujKCvaREGWpGUionraA==", 631 | "dev": true, 632 | "dependencies": { 633 | "chalk": "^4.0.0" 634 | }, 635 | "engines": { 636 | "node": ">=10" 637 | } 638 | }, 639 | "node_modules/minimatch": { 640 | "version": "3.0.4", 641 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 642 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 643 | "dev": true, 644 | "dependencies": { 645 | "brace-expansion": "^1.1.7" 646 | }, 647 | "engines": { 648 | "node": "*" 649 | } 650 | }, 651 | "node_modules/mocha": { 652 | "version": "8.3.2", 653 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-8.3.2.tgz", 654 | "integrity": "sha512-UdmISwr/5w+uXLPKspgoV7/RXZwKRTiTjJ2/AC5ZiEztIoOYdfKb19+9jNmEInzx5pBsCyJQzarAxqIGBNYJhg==", 655 | "dev": true, 656 | "dependencies": { 657 | "@ungap/promise-all-settled": "1.1.2", 658 | "ansi-colors": "4.1.1", 659 | "browser-stdout": "1.3.1", 660 | "chokidar": "3.5.1", 661 | "debug": "4.3.1", 662 | "diff": "5.0.0", 663 | "escape-string-regexp": "4.0.0", 664 | "find-up": "5.0.0", 665 | "glob": "7.1.6", 666 | "growl": "1.10.5", 667 | "he": "1.2.0", 668 | "js-yaml": "4.0.0", 669 | "log-symbols": "4.0.0", 670 | "minimatch": "3.0.4", 671 | "ms": "2.1.3", 672 | "nanoid": "3.1.20", 673 | "serialize-javascript": "5.0.1", 674 | "strip-json-comments": "3.1.1", 675 | "supports-color": "8.1.1", 676 | "which": "2.0.2", 677 | "wide-align": "1.1.3", 678 | "workerpool": "6.1.0", 679 | "yargs": "16.2.0", 680 | "yargs-parser": "20.2.4", 681 | "yargs-unparser": "2.0.0" 682 | }, 683 | "bin": { 684 | "_mocha": "bin/_mocha", 685 | "mocha": "bin/mocha" 686 | }, 687 | "engines": { 688 | "node": ">= 10.12.0" 689 | } 690 | }, 691 | "node_modules/ms": { 692 | "version": "2.1.3", 693 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 694 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 695 | "dev": true 696 | }, 697 | "node_modules/nanoid": { 698 | "version": "3.1.20", 699 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.20.tgz", 700 | "integrity": "sha512-a1cQNyczgKbLX9jwbS/+d7W8fX/RfgYR7lVWwWOGIPNgK2m0MWvrGF6/m4kk6U3QcFMnZf3RIhL0v2Jgh/0Uxw==", 701 | "dev": true, 702 | "bin": { 703 | "nanoid": "bin/nanoid.cjs" 704 | }, 705 | "engines": { 706 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 707 | } 708 | }, 709 | "node_modules/normalize-path": { 710 | "version": "3.0.0", 711 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 712 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 713 | "dev": true, 714 | "engines": { 715 | "node": ">=0.10.0" 716 | } 717 | }, 718 | "node_modules/once": { 719 | "version": "1.4.0", 720 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 721 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 722 | "dev": true, 723 | "dependencies": { 724 | "wrappy": "1" 725 | } 726 | }, 727 | "node_modules/p-limit": { 728 | "version": "3.1.0", 729 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 730 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 731 | "dev": true, 732 | "dependencies": { 733 | "yocto-queue": "^0.1.0" 734 | }, 735 | "engines": { 736 | "node": ">=10" 737 | } 738 | }, 739 | "node_modules/p-locate": { 740 | "version": "5.0.0", 741 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 742 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 743 | "dev": true, 744 | "dependencies": { 745 | "p-limit": "^3.0.2" 746 | }, 747 | "engines": { 748 | "node": ">=10" 749 | } 750 | }, 751 | "node_modules/path-exists": { 752 | "version": "4.0.0", 753 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 754 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 755 | "dev": true, 756 | "engines": { 757 | "node": ">=8" 758 | } 759 | }, 760 | "node_modules/path-is-absolute": { 761 | "version": "1.0.1", 762 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 763 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 764 | "dev": true, 765 | "engines": { 766 | "node": ">=0.10.0" 767 | } 768 | }, 769 | "node_modules/pathval": { 770 | "version": "1.1.1", 771 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 772 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 773 | "dev": true, 774 | "engines": { 775 | "node": "*" 776 | } 777 | }, 778 | "node_modules/picomatch": { 779 | "version": "2.2.3", 780 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.3.tgz", 781 | "integrity": "sha512-KpELjfwcCDUb9PeigTs2mBJzXUPzAuP2oPcA989He8Rte0+YUAjw1JVedDhuTKPkHjSYzMN3npC9luThGYEKdg==", 782 | "dev": true, 783 | "engines": { 784 | "node": ">=8.6" 785 | } 786 | }, 787 | "node_modules/randombytes": { 788 | "version": "2.1.0", 789 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 790 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 791 | "dev": true, 792 | "dependencies": { 793 | "safe-buffer": "^5.1.0" 794 | } 795 | }, 796 | "node_modules/readdirp": { 797 | "version": "3.5.0", 798 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.5.0.tgz", 799 | "integrity": "sha512-cMhu7c/8rdhkHXWsY+osBhfSy0JikwpHK/5+imo+LpeasTF8ouErHrlYkwT0++njiyuDvc7OFY5T3ukvZ8qmFQ==", 800 | "dev": true, 801 | "dependencies": { 802 | "picomatch": "^2.2.1" 803 | }, 804 | "engines": { 805 | "node": ">=8.10.0" 806 | } 807 | }, 808 | "node_modules/require-directory": { 809 | "version": "2.1.1", 810 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 811 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 812 | "dev": true, 813 | "engines": { 814 | "node": ">=0.10.0" 815 | } 816 | }, 817 | "node_modules/safe-buffer": { 818 | "version": "5.2.1", 819 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 820 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 821 | "dev": true 822 | }, 823 | "node_modules/serialize-javascript": { 824 | "version": "5.0.1", 825 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-5.0.1.tgz", 826 | "integrity": "sha512-SaaNal9imEO737H2c05Og0/8LUXG7EnsZyMa8MzkmuHoELfT6txuj0cMqRj6zfPKnmQ1yasR4PCJc8x+M4JSPA==", 827 | "dev": true, 828 | "dependencies": { 829 | "randombytes": "^2.1.0" 830 | } 831 | }, 832 | "node_modules/string-width": { 833 | "version": "2.1.1", 834 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 835 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 836 | "dev": true, 837 | "dependencies": { 838 | "is-fullwidth-code-point": "^2.0.0", 839 | "strip-ansi": "^4.0.0" 840 | }, 841 | "engines": { 842 | "node": ">=4" 843 | } 844 | }, 845 | "node_modules/strip-ansi": { 846 | "version": "4.0.0", 847 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 848 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 849 | "dev": true, 850 | "dependencies": { 851 | "ansi-regex": "^3.0.0" 852 | }, 853 | "engines": { 854 | "node": ">=4" 855 | } 856 | }, 857 | "node_modules/strip-json-comments": { 858 | "version": "3.1.1", 859 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 860 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 861 | "dev": true, 862 | "engines": { 863 | "node": ">=8" 864 | } 865 | }, 866 | "node_modules/supports-color": { 867 | "version": "8.1.1", 868 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 869 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 870 | "dev": true, 871 | "dependencies": { 872 | "has-flag": "^4.0.0" 873 | }, 874 | "engines": { 875 | "node": ">=10" 876 | } 877 | }, 878 | "node_modules/to-regex-range": { 879 | "version": "5.0.1", 880 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 881 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 882 | "dev": true, 883 | "dependencies": { 884 | "is-number": "^7.0.0" 885 | }, 886 | "engines": { 887 | "node": ">=8.0" 888 | } 889 | }, 890 | "node_modules/type-detect": { 891 | "version": "4.0.8", 892 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 893 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 894 | "dev": true, 895 | "engines": { 896 | "node": ">=4" 897 | } 898 | }, 899 | "node_modules/which": { 900 | "version": "2.0.2", 901 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 902 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 903 | "dev": true, 904 | "dependencies": { 905 | "isexe": "^2.0.0" 906 | }, 907 | "bin": { 908 | "node-which": "bin/node-which" 909 | }, 910 | "engines": { 911 | "node": ">= 8" 912 | } 913 | }, 914 | "node_modules/wide-align": { 915 | "version": "1.1.3", 916 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 917 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 918 | "dev": true, 919 | "dependencies": { 920 | "string-width": "^1.0.2 || 2" 921 | } 922 | }, 923 | "node_modules/workerpool": { 924 | "version": "6.1.0", 925 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.1.0.tgz", 926 | "integrity": "sha512-toV7q9rWNYha963Pl/qyeZ6wG+3nnsyvolaNUS8+R5Wtw6qJPTxIlOP1ZSvcGhEJw+l3HMMmtiNo9Gl61G4GVg==", 927 | "dev": true 928 | }, 929 | "node_modules/wrap-ansi": { 930 | "version": "7.0.0", 931 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 932 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 933 | "dev": true, 934 | "dependencies": { 935 | "ansi-styles": "^4.0.0", 936 | "string-width": "^4.1.0", 937 | "strip-ansi": "^6.0.0" 938 | }, 939 | "engines": { 940 | "node": ">=10" 941 | } 942 | }, 943 | "node_modules/wrap-ansi/node_modules/ansi-regex": { 944 | "version": "5.0.1", 945 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 946 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 947 | "dev": true, 948 | "engines": { 949 | "node": ">=8" 950 | } 951 | }, 952 | "node_modules/wrap-ansi/node_modules/is-fullwidth-code-point": { 953 | "version": "3.0.0", 954 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 955 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 956 | "dev": true, 957 | "engines": { 958 | "node": ">=8" 959 | } 960 | }, 961 | "node_modules/wrap-ansi/node_modules/string-width": { 962 | "version": "4.2.2", 963 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 964 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 965 | "dev": true, 966 | "dependencies": { 967 | "emoji-regex": "^8.0.0", 968 | "is-fullwidth-code-point": "^3.0.0", 969 | "strip-ansi": "^6.0.0" 970 | }, 971 | "engines": { 972 | "node": ">=8" 973 | } 974 | }, 975 | "node_modules/wrap-ansi/node_modules/strip-ansi": { 976 | "version": "6.0.0", 977 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 978 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 979 | "dev": true, 980 | "dependencies": { 981 | "ansi-regex": "^5.0.0" 982 | }, 983 | "engines": { 984 | "node": ">=8" 985 | } 986 | }, 987 | "node_modules/wrappy": { 988 | "version": "1.0.2", 989 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 990 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 991 | "dev": true 992 | }, 993 | "node_modules/y18n": { 994 | "version": "5.0.8", 995 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 996 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 997 | "dev": true, 998 | "engines": { 999 | "node": ">=10" 1000 | } 1001 | }, 1002 | "node_modules/yargs": { 1003 | "version": "16.2.0", 1004 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 1005 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 1006 | "dev": true, 1007 | "dependencies": { 1008 | "cliui": "^7.0.2", 1009 | "escalade": "^3.1.1", 1010 | "get-caller-file": "^2.0.5", 1011 | "require-directory": "^2.1.1", 1012 | "string-width": "^4.2.0", 1013 | "y18n": "^5.0.5", 1014 | "yargs-parser": "^20.2.2" 1015 | }, 1016 | "engines": { 1017 | "node": ">=10" 1018 | } 1019 | }, 1020 | "node_modules/yargs-parser": { 1021 | "version": "20.2.4", 1022 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 1023 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 1024 | "dev": true, 1025 | "engines": { 1026 | "node": ">=10" 1027 | } 1028 | }, 1029 | "node_modules/yargs-unparser": { 1030 | "version": "2.0.0", 1031 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 1032 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 1033 | "dev": true, 1034 | "dependencies": { 1035 | "camelcase": "^6.0.0", 1036 | "decamelize": "^4.0.0", 1037 | "flat": "^5.0.2", 1038 | "is-plain-obj": "^2.1.0" 1039 | }, 1040 | "engines": { 1041 | "node": ">=10" 1042 | } 1043 | }, 1044 | "node_modules/yargs/node_modules/ansi-regex": { 1045 | "version": "5.0.1", 1046 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1047 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1048 | "dev": true, 1049 | "engines": { 1050 | "node": ">=8" 1051 | } 1052 | }, 1053 | "node_modules/yargs/node_modules/is-fullwidth-code-point": { 1054 | "version": "3.0.0", 1055 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1056 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1057 | "dev": true, 1058 | "engines": { 1059 | "node": ">=8" 1060 | } 1061 | }, 1062 | "node_modules/yargs/node_modules/string-width": { 1063 | "version": "4.2.2", 1064 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 1065 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 1066 | "dev": true, 1067 | "dependencies": { 1068 | "emoji-regex": "^8.0.0", 1069 | "is-fullwidth-code-point": "^3.0.0", 1070 | "strip-ansi": "^6.0.0" 1071 | }, 1072 | "engines": { 1073 | "node": ">=8" 1074 | } 1075 | }, 1076 | "node_modules/yargs/node_modules/strip-ansi": { 1077 | "version": "6.0.0", 1078 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1079 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1080 | "dev": true, 1081 | "dependencies": { 1082 | "ansi-regex": "^5.0.0" 1083 | }, 1084 | "engines": { 1085 | "node": ">=8" 1086 | } 1087 | }, 1088 | "node_modules/yocto-queue": { 1089 | "version": "0.1.0", 1090 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1091 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1092 | "dev": true, 1093 | "engines": { 1094 | "node": ">=10" 1095 | } 1096 | } 1097 | }, 1098 | "dependencies": { 1099 | "@ungap/promise-all-settled": { 1100 | "version": "1.1.2", 1101 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 1102 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 1103 | "dev": true 1104 | }, 1105 | "ansi-colors": { 1106 | "version": "4.1.1", 1107 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 1108 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 1109 | "dev": true 1110 | }, 1111 | "ansi-regex": { 1112 | "version": "3.0.1", 1113 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.1.tgz", 1114 | "integrity": "sha512-+O9Jct8wf++lXxxFc4hc8LsjaSq0HFzzL7cVsw8pRDIPdjKD2mT4ytDZlLuSBZ4cLKZFXIrMGO7DbQCtMJJMKw==", 1115 | "dev": true 1116 | }, 1117 | "ansi-styles": { 1118 | "version": "4.3.0", 1119 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1120 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1121 | "dev": true, 1122 | "requires": { 1123 | "color-convert": "^2.0.1" 1124 | } 1125 | }, 1126 | "anymatch": { 1127 | "version": "3.1.2", 1128 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 1129 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 1130 | "dev": true, 1131 | "requires": { 1132 | "normalize-path": "^3.0.0", 1133 | "picomatch": "^2.0.4" 1134 | } 1135 | }, 1136 | "argparse": { 1137 | "version": "2.0.1", 1138 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1139 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1140 | "dev": true 1141 | }, 1142 | "assertion-error": { 1143 | "version": "1.1.0", 1144 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 1145 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 1146 | "dev": true 1147 | }, 1148 | "axios": { 1149 | "version": "0.21.2", 1150 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.21.2.tgz", 1151 | "integrity": "sha512-87otirqUw3e8CzHTMO+/9kh/FSgXt/eVDvipijwDtEuwbkySWZ9SBm6VEubmJ/kLKEoLQV/POhxXFb66bfekfg==", 1152 | "requires": { 1153 | "follow-redirects": "^1.14.0" 1154 | } 1155 | }, 1156 | "balanced-match": { 1157 | "version": "1.0.2", 1158 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1159 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1160 | "dev": true 1161 | }, 1162 | "binary-extensions": { 1163 | "version": "2.2.0", 1164 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 1165 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 1166 | "dev": true 1167 | }, 1168 | "brace-expansion": { 1169 | "version": "1.1.11", 1170 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1171 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1172 | "dev": true, 1173 | "requires": { 1174 | "balanced-match": "^1.0.0", 1175 | "concat-map": "0.0.1" 1176 | } 1177 | }, 1178 | "braces": { 1179 | "version": "3.0.2", 1180 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1181 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1182 | "dev": true, 1183 | "requires": { 1184 | "fill-range": "^7.0.1" 1185 | } 1186 | }, 1187 | "browser-stdout": { 1188 | "version": "1.3.1", 1189 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 1190 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 1191 | "dev": true 1192 | }, 1193 | "camelcase": { 1194 | "version": "6.2.0", 1195 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.0.tgz", 1196 | "integrity": "sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==", 1197 | "dev": true 1198 | }, 1199 | "chai": { 1200 | "version": "4.3.4", 1201 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.4.tgz", 1202 | "integrity": "sha512-yS5H68VYOCtN1cjfwumDSuzn/9c+yza4f3reKXlE5rUg7SFcCEy90gJvydNgOYtblyf4Zi6jIWRnXOgErta0KA==", 1203 | "dev": true, 1204 | "requires": { 1205 | "assertion-error": "^1.1.0", 1206 | "check-error": "^1.0.2", 1207 | "deep-eql": "^3.0.1", 1208 | "get-func-name": "^2.0.0", 1209 | "pathval": "^1.1.1", 1210 | "type-detect": "^4.0.5" 1211 | } 1212 | }, 1213 | "chalk": { 1214 | "version": "4.1.1", 1215 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz", 1216 | "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==", 1217 | "dev": true, 1218 | "requires": { 1219 | "ansi-styles": "^4.1.0", 1220 | "supports-color": "^7.1.0" 1221 | }, 1222 | "dependencies": { 1223 | "supports-color": { 1224 | "version": "7.2.0", 1225 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1226 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1227 | "dev": true, 1228 | "requires": { 1229 | "has-flag": "^4.0.0" 1230 | } 1231 | } 1232 | } 1233 | }, 1234 | "check-error": { 1235 | "version": "1.0.2", 1236 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 1237 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 1238 | "dev": true 1239 | }, 1240 | "chokidar": { 1241 | "version": "3.5.1", 1242 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.1.tgz", 1243 | "integrity": "sha512-9+s+Od+W0VJJzawDma/gvBNQqkTiqYTWLuZoyAsivsI4AaWTCzHG06/TMjsf1cYe9Cb97UCEhjz7HvnPk2p/tw==", 1244 | "dev": true, 1245 | "requires": { 1246 | "anymatch": "~3.1.1", 1247 | "braces": "~3.0.2", 1248 | "fsevents": "~2.3.1", 1249 | "glob-parent": "~5.1.0", 1250 | "is-binary-path": "~2.1.0", 1251 | "is-glob": "~4.0.1", 1252 | "normalize-path": "~3.0.0", 1253 | "readdirp": "~3.5.0" 1254 | } 1255 | }, 1256 | "cliui": { 1257 | "version": "7.0.4", 1258 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 1259 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 1260 | "dev": true, 1261 | "requires": { 1262 | "string-width": "^4.2.0", 1263 | "strip-ansi": "^6.0.0", 1264 | "wrap-ansi": "^7.0.0" 1265 | }, 1266 | "dependencies": { 1267 | "ansi-regex": { 1268 | "version": "5.0.1", 1269 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1270 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1271 | "dev": true 1272 | }, 1273 | "is-fullwidth-code-point": { 1274 | "version": "3.0.0", 1275 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1276 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1277 | "dev": true 1278 | }, 1279 | "string-width": { 1280 | "version": "4.2.2", 1281 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 1282 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 1283 | "dev": true, 1284 | "requires": { 1285 | "emoji-regex": "^8.0.0", 1286 | "is-fullwidth-code-point": "^3.0.0", 1287 | "strip-ansi": "^6.0.0" 1288 | } 1289 | }, 1290 | "strip-ansi": { 1291 | "version": "6.0.0", 1292 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1293 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1294 | "dev": true, 1295 | "requires": { 1296 | "ansi-regex": "^5.0.0" 1297 | } 1298 | } 1299 | } 1300 | }, 1301 | "color-convert": { 1302 | "version": "2.0.1", 1303 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1304 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1305 | "dev": true, 1306 | "requires": { 1307 | "color-name": "~1.1.4" 1308 | } 1309 | }, 1310 | "color-name": { 1311 | "version": "1.1.4", 1312 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1313 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1314 | "dev": true 1315 | }, 1316 | "concat-map": { 1317 | "version": "0.0.1", 1318 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1319 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 1320 | "dev": true 1321 | }, 1322 | "debug": { 1323 | "version": "4.3.1", 1324 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 1325 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 1326 | "dev": true, 1327 | "requires": { 1328 | "ms": "2.1.2" 1329 | }, 1330 | "dependencies": { 1331 | "ms": { 1332 | "version": "2.1.2", 1333 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1334 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1335 | "dev": true 1336 | } 1337 | } 1338 | }, 1339 | "decamelize": { 1340 | "version": "4.0.0", 1341 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 1342 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 1343 | "dev": true 1344 | }, 1345 | "deep-eql": { 1346 | "version": "3.0.1", 1347 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 1348 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 1349 | "dev": true, 1350 | "requires": { 1351 | "type-detect": "^4.0.0" 1352 | } 1353 | }, 1354 | "diff": { 1355 | "version": "5.0.0", 1356 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 1357 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 1358 | "dev": true 1359 | }, 1360 | "dotenv": { 1361 | "version": "8.2.0", 1362 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz", 1363 | "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==" 1364 | }, 1365 | "emoji-regex": { 1366 | "version": "8.0.0", 1367 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1368 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1369 | "dev": true 1370 | }, 1371 | "escalade": { 1372 | "version": "3.1.1", 1373 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 1374 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 1375 | "dev": true 1376 | }, 1377 | "escape-string-regexp": { 1378 | "version": "4.0.0", 1379 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1380 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1381 | "dev": true 1382 | }, 1383 | "fill-range": { 1384 | "version": "7.0.1", 1385 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1386 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1387 | "dev": true, 1388 | "requires": { 1389 | "to-regex-range": "^5.0.1" 1390 | } 1391 | }, 1392 | "find-up": { 1393 | "version": "5.0.0", 1394 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1395 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1396 | "dev": true, 1397 | "requires": { 1398 | "locate-path": "^6.0.0", 1399 | "path-exists": "^4.0.0" 1400 | } 1401 | }, 1402 | "flat": { 1403 | "version": "5.0.2", 1404 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 1405 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 1406 | "dev": true 1407 | }, 1408 | "follow-redirects": { 1409 | "version": "1.14.9", 1410 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.9.tgz", 1411 | "integrity": "sha512-MQDfihBQYMcyy5dhRDJUHcw7lb2Pv/TuE6xP1vyraLukNDHKbDxDNaOE3NbCAdKQApno+GPRyo1YAp89yCjK4w==" 1412 | }, 1413 | "fs.realpath": { 1414 | "version": "1.0.0", 1415 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1416 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1417 | "dev": true 1418 | }, 1419 | "fsevents": { 1420 | "version": "2.3.2", 1421 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1422 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1423 | "dev": true, 1424 | "optional": true 1425 | }, 1426 | "get-caller-file": { 1427 | "version": "2.0.5", 1428 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1429 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1430 | "dev": true 1431 | }, 1432 | "get-func-name": { 1433 | "version": "2.0.0", 1434 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 1435 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 1436 | "dev": true 1437 | }, 1438 | "glob": { 1439 | "version": "7.1.6", 1440 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1441 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1442 | "dev": true, 1443 | "requires": { 1444 | "fs.realpath": "^1.0.0", 1445 | "inflight": "^1.0.4", 1446 | "inherits": "2", 1447 | "minimatch": "^3.0.4", 1448 | "once": "^1.3.0", 1449 | "path-is-absolute": "^1.0.0" 1450 | } 1451 | }, 1452 | "glob-parent": { 1453 | "version": "5.1.2", 1454 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1455 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1456 | "dev": true, 1457 | "requires": { 1458 | "is-glob": "^4.0.1" 1459 | } 1460 | }, 1461 | "growl": { 1462 | "version": "1.10.5", 1463 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 1464 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 1465 | "dev": true 1466 | }, 1467 | "has-flag": { 1468 | "version": "4.0.0", 1469 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1470 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1471 | "dev": true 1472 | }, 1473 | "he": { 1474 | "version": "1.2.0", 1475 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1476 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1477 | "dev": true 1478 | }, 1479 | "inflight": { 1480 | "version": "1.0.6", 1481 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1482 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1483 | "dev": true, 1484 | "requires": { 1485 | "once": "^1.3.0", 1486 | "wrappy": "1" 1487 | } 1488 | }, 1489 | "inherits": { 1490 | "version": "2.0.4", 1491 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1492 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1493 | "dev": true 1494 | }, 1495 | "is-binary-path": { 1496 | "version": "2.1.0", 1497 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1498 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1499 | "dev": true, 1500 | "requires": { 1501 | "binary-extensions": "^2.0.0" 1502 | } 1503 | }, 1504 | "is-extglob": { 1505 | "version": "2.1.1", 1506 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1507 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1508 | "dev": true 1509 | }, 1510 | "is-fullwidth-code-point": { 1511 | "version": "2.0.0", 1512 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1513 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1514 | "dev": true 1515 | }, 1516 | "is-glob": { 1517 | "version": "4.0.1", 1518 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1519 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1520 | "dev": true, 1521 | "requires": { 1522 | "is-extglob": "^2.1.1" 1523 | } 1524 | }, 1525 | "is-number": { 1526 | "version": "7.0.0", 1527 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1528 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1529 | "dev": true 1530 | }, 1531 | "is-plain-obj": { 1532 | "version": "2.1.0", 1533 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 1534 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 1535 | "dev": true 1536 | }, 1537 | "isexe": { 1538 | "version": "2.0.0", 1539 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1540 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1541 | "dev": true 1542 | }, 1543 | "js-yaml": { 1544 | "version": "4.0.0", 1545 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.0.0.tgz", 1546 | "integrity": "sha512-pqon0s+4ScYUvX30wxQi3PogGFAlUyH0awepWvwkj4jD4v+ova3RiYw8bmA6x2rDrEaj8i/oWKoRxpVNW+Re8Q==", 1547 | "dev": true, 1548 | "requires": { 1549 | "argparse": "^2.0.1" 1550 | } 1551 | }, 1552 | "locate-path": { 1553 | "version": "6.0.0", 1554 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1555 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1556 | "dev": true, 1557 | "requires": { 1558 | "p-locate": "^5.0.0" 1559 | } 1560 | }, 1561 | "log-symbols": { 1562 | "version": "4.0.0", 1563 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.0.0.tgz", 1564 | "integrity": "sha512-FN8JBzLx6CzeMrB0tg6pqlGU1wCrXW+ZXGH481kfsBqer0hToTIiHdjH4Mq8xJUbvATujKCvaREGWpGUionraA==", 1565 | "dev": true, 1566 | "requires": { 1567 | "chalk": "^4.0.0" 1568 | } 1569 | }, 1570 | "minimatch": { 1571 | "version": "3.0.4", 1572 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1573 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1574 | "dev": true, 1575 | "requires": { 1576 | "brace-expansion": "^1.1.7" 1577 | } 1578 | }, 1579 | "mocha": { 1580 | "version": "8.3.2", 1581 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-8.3.2.tgz", 1582 | "integrity": "sha512-UdmISwr/5w+uXLPKspgoV7/RXZwKRTiTjJ2/AC5ZiEztIoOYdfKb19+9jNmEInzx5pBsCyJQzarAxqIGBNYJhg==", 1583 | "dev": true, 1584 | "requires": { 1585 | "@ungap/promise-all-settled": "1.1.2", 1586 | "ansi-colors": "4.1.1", 1587 | "browser-stdout": "1.3.1", 1588 | "chokidar": "3.5.1", 1589 | "debug": "4.3.1", 1590 | "diff": "5.0.0", 1591 | "escape-string-regexp": "4.0.0", 1592 | "find-up": "5.0.0", 1593 | "glob": "7.1.6", 1594 | "growl": "1.10.5", 1595 | "he": "1.2.0", 1596 | "js-yaml": "4.0.0", 1597 | "log-symbols": "4.0.0", 1598 | "minimatch": "3.0.4", 1599 | "ms": "2.1.3", 1600 | "nanoid": "3.1.20", 1601 | "serialize-javascript": "5.0.1", 1602 | "strip-json-comments": "3.1.1", 1603 | "supports-color": "8.1.1", 1604 | "which": "2.0.2", 1605 | "wide-align": "1.1.3", 1606 | "workerpool": "6.1.0", 1607 | "yargs": "16.2.0", 1608 | "yargs-parser": "20.2.4", 1609 | "yargs-unparser": "2.0.0" 1610 | } 1611 | }, 1612 | "ms": { 1613 | "version": "2.1.3", 1614 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1615 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1616 | "dev": true 1617 | }, 1618 | "nanoid": { 1619 | "version": "3.1.20", 1620 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.20.tgz", 1621 | "integrity": "sha512-a1cQNyczgKbLX9jwbS/+d7W8fX/RfgYR7lVWwWOGIPNgK2m0MWvrGF6/m4kk6U3QcFMnZf3RIhL0v2Jgh/0Uxw==", 1622 | "dev": true 1623 | }, 1624 | "normalize-path": { 1625 | "version": "3.0.0", 1626 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1627 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1628 | "dev": true 1629 | }, 1630 | "once": { 1631 | "version": "1.4.0", 1632 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1633 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1634 | "dev": true, 1635 | "requires": { 1636 | "wrappy": "1" 1637 | } 1638 | }, 1639 | "p-limit": { 1640 | "version": "3.1.0", 1641 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1642 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1643 | "dev": true, 1644 | "requires": { 1645 | "yocto-queue": "^0.1.0" 1646 | } 1647 | }, 1648 | "p-locate": { 1649 | "version": "5.0.0", 1650 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1651 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1652 | "dev": true, 1653 | "requires": { 1654 | "p-limit": "^3.0.2" 1655 | } 1656 | }, 1657 | "path-exists": { 1658 | "version": "4.0.0", 1659 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1660 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1661 | "dev": true 1662 | }, 1663 | "path-is-absolute": { 1664 | "version": "1.0.1", 1665 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1666 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1667 | "dev": true 1668 | }, 1669 | "pathval": { 1670 | "version": "1.1.1", 1671 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 1672 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 1673 | "dev": true 1674 | }, 1675 | "picomatch": { 1676 | "version": "2.2.3", 1677 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.3.tgz", 1678 | "integrity": "sha512-KpELjfwcCDUb9PeigTs2mBJzXUPzAuP2oPcA989He8Rte0+YUAjw1JVedDhuTKPkHjSYzMN3npC9luThGYEKdg==", 1679 | "dev": true 1680 | }, 1681 | "randombytes": { 1682 | "version": "2.1.0", 1683 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1684 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1685 | "dev": true, 1686 | "requires": { 1687 | "safe-buffer": "^5.1.0" 1688 | } 1689 | }, 1690 | "readdirp": { 1691 | "version": "3.5.0", 1692 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.5.0.tgz", 1693 | "integrity": "sha512-cMhu7c/8rdhkHXWsY+osBhfSy0JikwpHK/5+imo+LpeasTF8ouErHrlYkwT0++njiyuDvc7OFY5T3ukvZ8qmFQ==", 1694 | "dev": true, 1695 | "requires": { 1696 | "picomatch": "^2.2.1" 1697 | } 1698 | }, 1699 | "require-directory": { 1700 | "version": "2.1.1", 1701 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1702 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1703 | "dev": true 1704 | }, 1705 | "safe-buffer": { 1706 | "version": "5.2.1", 1707 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1708 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1709 | "dev": true 1710 | }, 1711 | "serialize-javascript": { 1712 | "version": "5.0.1", 1713 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-5.0.1.tgz", 1714 | "integrity": "sha512-SaaNal9imEO737H2c05Og0/8LUXG7EnsZyMa8MzkmuHoELfT6txuj0cMqRj6zfPKnmQ1yasR4PCJc8x+M4JSPA==", 1715 | "dev": true, 1716 | "requires": { 1717 | "randombytes": "^2.1.0" 1718 | } 1719 | }, 1720 | "string-width": { 1721 | "version": "2.1.1", 1722 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1723 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1724 | "dev": true, 1725 | "requires": { 1726 | "is-fullwidth-code-point": "^2.0.0", 1727 | "strip-ansi": "^4.0.0" 1728 | } 1729 | }, 1730 | "strip-ansi": { 1731 | "version": "4.0.0", 1732 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1733 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1734 | "dev": true, 1735 | "requires": { 1736 | "ansi-regex": "^3.0.0" 1737 | } 1738 | }, 1739 | "strip-json-comments": { 1740 | "version": "3.1.1", 1741 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1742 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1743 | "dev": true 1744 | }, 1745 | "supports-color": { 1746 | "version": "8.1.1", 1747 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1748 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1749 | "dev": true, 1750 | "requires": { 1751 | "has-flag": "^4.0.0" 1752 | } 1753 | }, 1754 | "to-regex-range": { 1755 | "version": "5.0.1", 1756 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1757 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1758 | "dev": true, 1759 | "requires": { 1760 | "is-number": "^7.0.0" 1761 | } 1762 | }, 1763 | "type-detect": { 1764 | "version": "4.0.8", 1765 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 1766 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 1767 | "dev": true 1768 | }, 1769 | "which": { 1770 | "version": "2.0.2", 1771 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1772 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1773 | "dev": true, 1774 | "requires": { 1775 | "isexe": "^2.0.0" 1776 | } 1777 | }, 1778 | "wide-align": { 1779 | "version": "1.1.3", 1780 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1781 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1782 | "dev": true, 1783 | "requires": { 1784 | "string-width": "^1.0.2 || 2" 1785 | } 1786 | }, 1787 | "workerpool": { 1788 | "version": "6.1.0", 1789 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.1.0.tgz", 1790 | "integrity": "sha512-toV7q9rWNYha963Pl/qyeZ6wG+3nnsyvolaNUS8+R5Wtw6qJPTxIlOP1ZSvcGhEJw+l3HMMmtiNo9Gl61G4GVg==", 1791 | "dev": true 1792 | }, 1793 | "wrap-ansi": { 1794 | "version": "7.0.0", 1795 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1796 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1797 | "dev": true, 1798 | "requires": { 1799 | "ansi-styles": "^4.0.0", 1800 | "string-width": "^4.1.0", 1801 | "strip-ansi": "^6.0.0" 1802 | }, 1803 | "dependencies": { 1804 | "ansi-regex": { 1805 | "version": "5.0.1", 1806 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1807 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1808 | "dev": true 1809 | }, 1810 | "is-fullwidth-code-point": { 1811 | "version": "3.0.0", 1812 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1813 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1814 | "dev": true 1815 | }, 1816 | "string-width": { 1817 | "version": "4.2.2", 1818 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 1819 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 1820 | "dev": true, 1821 | "requires": { 1822 | "emoji-regex": "^8.0.0", 1823 | "is-fullwidth-code-point": "^3.0.0", 1824 | "strip-ansi": "^6.0.0" 1825 | } 1826 | }, 1827 | "strip-ansi": { 1828 | "version": "6.0.0", 1829 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1830 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1831 | "dev": true, 1832 | "requires": { 1833 | "ansi-regex": "^5.0.0" 1834 | } 1835 | } 1836 | } 1837 | }, 1838 | "wrappy": { 1839 | "version": "1.0.2", 1840 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1841 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1842 | "dev": true 1843 | }, 1844 | "y18n": { 1845 | "version": "5.0.8", 1846 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1847 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1848 | "dev": true 1849 | }, 1850 | "yargs": { 1851 | "version": "16.2.0", 1852 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 1853 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 1854 | "dev": true, 1855 | "requires": { 1856 | "cliui": "^7.0.2", 1857 | "escalade": "^3.1.1", 1858 | "get-caller-file": "^2.0.5", 1859 | "require-directory": "^2.1.1", 1860 | "string-width": "^4.2.0", 1861 | "y18n": "^5.0.5", 1862 | "yargs-parser": "^20.2.2" 1863 | }, 1864 | "dependencies": { 1865 | "ansi-regex": { 1866 | "version": "5.0.1", 1867 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1868 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1869 | "dev": true 1870 | }, 1871 | "is-fullwidth-code-point": { 1872 | "version": "3.0.0", 1873 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1874 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1875 | "dev": true 1876 | }, 1877 | "string-width": { 1878 | "version": "4.2.2", 1879 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 1880 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 1881 | "dev": true, 1882 | "requires": { 1883 | "emoji-regex": "^8.0.0", 1884 | "is-fullwidth-code-point": "^3.0.0", 1885 | "strip-ansi": "^6.0.0" 1886 | } 1887 | }, 1888 | "strip-ansi": { 1889 | "version": "6.0.0", 1890 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1891 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1892 | "dev": true, 1893 | "requires": { 1894 | "ansi-regex": "^5.0.0" 1895 | } 1896 | } 1897 | } 1898 | }, 1899 | "yargs-parser": { 1900 | "version": "20.2.4", 1901 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 1902 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 1903 | "dev": true 1904 | }, 1905 | "yargs-unparser": { 1906 | "version": "2.0.0", 1907 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 1908 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 1909 | "dev": true, 1910 | "requires": { 1911 | "camelcase": "^6.0.0", 1912 | "decamelize": "^4.0.0", 1913 | "flat": "^5.0.2", 1914 | "is-plain-obj": "^2.1.0" 1915 | } 1916 | }, 1917 | "yocto-queue": { 1918 | "version": "0.1.0", 1919 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1920 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1921 | "dev": true 1922 | } 1923 | } 1924 | } 1925 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "openai-api", 3 | "version": "1.3.0", 4 | "description": "A tiny client module for the openAI API", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "mocha --use_strict" 8 | }, 9 | "keywords": [ 10 | "openai", 11 | "gpt-3", 12 | "gpt3", 13 | "openaiapi", 14 | "open", 15 | "ai", 16 | "node" 17 | ], 18 | "author": "Nikita Jerschow", 19 | "contributors": [ 20 | { 21 | "url": "https://github.com/Njerschow" 22 | }, 23 | { 24 | "url": "https://github.com/uvafan" 25 | }, 26 | { 27 | "url": "https://github.com/AlbertGozzi" 28 | }, 29 | { 30 | "url": "https://github.com/LauraWartschinski" 31 | }, 32 | { 33 | "url": "https://github.com/kian-g" 34 | }, 35 | { 36 | "url": "https://github.com/timconnorz" 37 | }, 38 | { 39 | "url": "https://github.com/schnerd" 40 | }, 41 | { 42 | "url": "https://github.com/anonrose" 43 | }, 44 | { 45 | "url": "https://github.com/Cormanz" 46 | } 47 | ], 48 | "license": "ISC", 49 | "repository": { 50 | "type": "git", 51 | "url": "https://github.com/Njerschow/openai-api" 52 | }, 53 | "dependencies": { 54 | "axios": "^0.21.1", 55 | "dotenv": "^8.2.0" 56 | }, 57 | "devDependencies": { 58 | "chai": "^4.3.4", 59 | "mocha": "^8.3.2" 60 | } 61 | } 62 | -------------------------------------------------------------------------------- /test/basic.test.js: -------------------------------------------------------------------------------- 1 | require('dotenv').config(); 2 | const api_key = process.env.OPENAI_TEST_API_KEY; 3 | const expect = require('chai').expect; 4 | const OpenAI = require('../index'); 5 | 6 | if (!api_key) { 7 | throw new Error('api key is needed to run testsuite: set environment variable: OPENAI_TEST_API_KEY'); 8 | } 9 | 10 | describe('basic openai api methods', function () { 11 | this.timeout(8000); 12 | 13 | const openai = new OpenAI(api_key); 14 | 15 | it('should handle simple completion', async function () { 16 | const result = await openai.complete({ 17 | engine: 'ada', 18 | prompt: "this is a test", 19 | maxTokens: 5, 20 | temperature: 0.9, 21 | frequencyPenalty: 0, 22 | bestOf: 1, 23 | stop: ["\n", "lol"] 24 | }); 25 | expect(result).to.be.ok; 26 | }); 27 | 28 | it('should handle search', async function () { 29 | const result = await openai.search({ 30 | engine: 'ada', 31 | documents: ["White House", "hospital", "school"], 32 | query: "the president" 33 | }); 34 | expect(result).to.be.ok; 35 | }); 36 | 37 | it('should handle answers', async function () { 38 | const result = await openai.answers({ 39 | "documents": ["Puppy A is happy.", "Puppy B is sad."], 40 | "question": "which puppy is happy?", 41 | "search_model": "ada", 42 | "model": "curie", 43 | "examples_context": "In 2017, U.S. life expectancy was 78.6 years.", 44 | "examples": [["What is human life expectancy in the United States?", "78 years."]], 45 | "max_tokens": 5, 46 | "stop": ["\n", "<|endoftext|>"], 47 | }); 48 | expect(result).to.be.ok; 49 | }); 50 | 51 | it("should handle classification", async function () { 52 | const result = await openai.classification({ 53 | examples: [ 54 | ["A happy moment", "Positive"], 55 | ["I am sad.", "Negative"], 56 | ["I am feeling awesome", "Positive"], 57 | ], 58 | labels: ["Positive", "Negative", "Neutral"], 59 | query: "It is a raining day :(", 60 | search_model: "ada", 61 | model: "curie", 62 | }); 63 | expect(result).to.be.ok; 64 | }); 65 | 66 | it('should handle engines', async function () { 67 | const result = await openai.engines(); 68 | expect(result).to.be.ok; 69 | }); 70 | 71 | it('should handle engine', async function () { 72 | const result = await openai.engine('ada'); 73 | expect(result).to.be.ok; 74 | }); 75 | 76 | it('should use the davinci engine by default', async function () { 77 | const result = await openai.complete({ 78 | prompt: "this is a test", 79 | maxTokens: 5, 80 | temperature: 0.9, 81 | frequencyPenalty: 0, 82 | bestOf: 1, 83 | stop: ["\n", "engine test"] 84 | }); 85 | expect(result).to.be.ok; 86 | }); 87 | 88 | it('should return a default value from the encode function', async function () { 89 | const result = await openai.encode('this is a string'); 90 | expect(result).to.be.ok; 91 | expect(result.length).to.be.eql(2047); 92 | }); 93 | 94 | it('should handle embeddings', async function () { 95 | const result = await openai.embeddings({ 96 | engine: 'text-similarity-ada-001', 97 | input: [ 98 | "A happy moment", 99 | "I am sad.", 100 | "I am feeling awesome" 101 | ] 102 | }); 103 | expect(result).to.be.ok; 104 | }); 105 | }); --------------------------------------------------------------------------------