├── .gitignore ├── LICENSE ├── README.md ├── example.gif ├── src ├── .env ├── app.js ├── package.json ├── public │ ├── css │ │ └── main.css │ └── js │ │ ├── client.js │ │ ├── recorderWorkletProcessor.js │ │ ├── socket.io.js │ │ └── socket.io.js.map └── views │ └── index.ejs └── srcLogOnly ├── app.js ├── package-lock.json ├── package.json ├── public ├── css │ ├── main-min.css │ └── main.css └── js │ ├── client.js │ ├── socket.io.js │ └── socket.io.js.map └── views └── index.ejs /.gitignore: -------------------------------------------------------------------------------- 1 | src/node_modules 2 | src/pathToYourJson.json 3 | src/package-lock.json 4 | .env 5 | src/.DS_Store 6 | src/.env 7 | srcLogOnly/config.codekit3 8 | .DS_Store 9 | *.json 10 | srcLogOnly/node_modules 11 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2018 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Google Cloud Speech Node with Socket Playground 2 | 3 | [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) 4 | 5 | An easy-to-set-up playground for cross device real-time Google Speech Recognition with a Node server and socket.io. *Phew.* 6 | 7 | ![Yo this is a test](example.gif "example gif") 8 | 9 | ## Run Local 10 | 1. get a free test key from [Google](https://cloud.google.com/speech/docs/quickstart ) 11 | 2. place it into the src folder and update the path in the `.env` file 12 | 3. open the terminal and go to the `src` folder 13 | 4. run `npm install` 14 | 5. run `node app.js` or with nodemon: `nodemon app` 15 | 6. go to `http://127.0.0.1:1337/` 16 | 17 | ## Run on Server 18 | Same as **run local** `1-4`. 19 | 20 | 5. config the `.env` Port for a port that you've opened on the server. I'm using 1337 here, too. 21 | 6. go to `your server adress` 22 | 23 | I recommend using [pm2](http://pm2.keymetrics.io/) or something similar, to keep the process running even when closing the terminal connection. 24 | 25 | ## Examples 26 | - Speech Recognition controlled Face Filter: [Christmas Card](https://xmas.humanfoundry.com/) 27 | - Face Filter / Analyzer with Speech Recognition: [I Love You Trainer](http://iloveyoutrainer.com) 28 | 29 | ## Config 30 | 31 | It's possible to set a recognition context / add misunderstood words for better recognition results in the app.js `request` params. For more details on the configuration, go [here](https://cloud.google.com/speech-to-text/docs/reference/rest/v1/RecognitionConfig#SpeechContext). 32 | 33 | For other languages than english, look up your [language code](https://cloud.google.com/speech-to-text/docs/languages). 34 | 35 | ## How Does the Client Process the Stream? 36 | 37 | Google Cloud sends intermittent responses to the uploaded audio stream. Each response 38 | from Google Cloud contains the current estimation of the full sentence for the streamed audio. 39 | 40 | When Google Cloud senses that the audio has reached an end of sentence, it will issue a response with an `isFinal` flag set to true. Once this flag is issued, the client will finalize the sentence and write it to the document. 41 | 42 | This process is repeated until the user ends the recording. 43 | 44 | ## Interim Natural Language Processing 45 | 46 | The client application highlights different parts of speech, such as nouns and verbs, by using 47 | [this natural language processing library](https://github.com/spencermountain/compromise). 48 | 49 | ## Socket Connection 50 | 51 | The client communicates with the server using [Socket.io](https://socket.io). 52 | 53 | ## Troubleshooting 54 | - If you have delays in calls, check if `IPV6` is disabled on your server 55 | 56 | # Super Reduced Version for Devs 57 | 58 | There is now a super reduced log only verison. It show's only two buttons, logs the results to the console and has no nlp. Use this if you want to implement it somewhere else. 59 | 60 | Made by [Vinzenz Aubry](https://twitter.com/vinberto) 61 | -------------------------------------------------------------------------------- /example.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/vin-ni/Google-Cloud-Speech-Node-Socket-Playground/10af4e92e37b7dd5ba2545ea35651494d1c81838/example.gif -------------------------------------------------------------------------------- /src/.env: -------------------------------------------------------------------------------- 1 | GOOGLE_APPLICATION_CREDENTIALS=pathToYourJson.json 2 | PORT=1337 -------------------------------------------------------------------------------- /src/app.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | // Google Cloud Speech Playground with node.js and socket.io 4 | // Created by Vinzenz Aubry for sansho 24.01.17 5 | // Feel free to improve! 6 | // Contact: v@vinzenzaubry.com 7 | 8 | const express = require('express'); // const bodyParser = require('body-parser'); // const path = require('path'); 9 | const environmentVars = require('dotenv').config(); 10 | 11 | // Google Cloud 12 | const speech = require('@google-cloud/speech'); 13 | const speechClient = new speech.SpeechClient(); // Creates a client 14 | 15 | const app = express(); 16 | const port = process.env.PORT || 1337; 17 | const server = require('http').createServer(app); 18 | 19 | const io = require('socket.io')(server); 20 | 21 | app.use('/assets', express.static(__dirname + '/public')); 22 | app.use('/session/assets', express.static(__dirname + '/public')); 23 | app.set('view engine', 'ejs'); 24 | 25 | // =========================== ROUTERS ================================ // 26 | 27 | app.get('/', function (req, res) { 28 | res.render('index', {}); 29 | }); 30 | 31 | app.use('/', function (req, res, next) { 32 | next(); // console.log(`Request Url: ${req.url}`); 33 | }); 34 | 35 | // =========================== SOCKET.IO ================================ // 36 | 37 | io.on('connection', function (client) { 38 | console.log('Client Connected to server'); 39 | let recognizeStream = null; 40 | 41 | client.on('join', function () { 42 | client.emit('messages', 'Socket Connected to Server'); 43 | }); 44 | 45 | client.on('messages', function (data) { 46 | client.emit('broad', data); 47 | }); 48 | 49 | client.on('startGoogleCloudStream', function (data) { 50 | startRecognitionStream(this, data); 51 | }); 52 | 53 | client.on('endGoogleCloudStream', function () { 54 | stopRecognitionStream(); 55 | }); 56 | 57 | client.on('binaryData', function (data) { 58 | // console.log(data); //log binary data 59 | if (recognizeStream !== null) { 60 | recognizeStream.write(data); 61 | } 62 | }); 63 | 64 | function startRecognitionStream(client) { 65 | recognizeStream = speechClient 66 | .streamingRecognize(request) 67 | .on('error', console.error) 68 | .on('data', (data) => { 69 | process.stdout.write( 70 | data.results[0] && data.results[0].alternatives[0] 71 | ? `Transcription: ${data.results[0].alternatives[0].transcript}\n` 72 | : '\n\nReached transcription time limit, press Ctrl+C\n' 73 | ); 74 | client.emit('speechData', data); 75 | 76 | // if end of utterance, let's restart stream 77 | // this is a small hack. After 65 seconds of silence, the stream will still throw an error for speech length limit 78 | if (data.results[0] && data.results[0].isFinal) { 79 | stopRecognitionStream(); 80 | startRecognitionStream(client); 81 | // console.log('restarted stream serverside'); 82 | } 83 | }); 84 | } 85 | 86 | function stopRecognitionStream() { 87 | if (recognizeStream) { 88 | recognizeStream.end(); 89 | } 90 | recognizeStream = null; 91 | } 92 | }); 93 | 94 | // =========================== GOOGLE CLOUD SETTINGS ================================ // 95 | 96 | // The encoding of the audio file, e.g. 'LINEAR16' 97 | // The sample rate of the audio file in hertz, e.g. 16000 98 | // The BCP-47 language code to use, e.g. 'en-US' 99 | const encoding = 'LINEAR16'; 100 | const sampleRateHertz = 16000; 101 | const languageCode = 'en-US'; //en-US 102 | 103 | const request = { 104 | config: { 105 | encoding: encoding, 106 | sampleRateHertz: sampleRateHertz, 107 | languageCode: languageCode, 108 | profanityFilter: false, 109 | enableWordTimeOffsets: true, 110 | // speechContexts: [{ 111 | // phrases: ["hoful","shwazil"] 112 | // }] // add your own speech context for better recognition 113 | }, 114 | interimResults: true, // If you want interim results, set this to true 115 | }; 116 | 117 | // =========================== START SERVER ================================ // 118 | 119 | server.listen(port, '127.0.0.1', function () { 120 | //http listen, to make socket work 121 | // app.address = "127.0.0.1"; 122 | console.log('Server started on port:' + port); 123 | }); 124 | -------------------------------------------------------------------------------- /src/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "GoogleCloudSpeechPlayground", 3 | "version": "1.0.1", 4 | "description": "Google Cloud Speech Playground with node.js and socket.io.", 5 | "main": "app.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "@google-cloud/speech": "^4.2.0", 13 | "dotenv": "^8.2.0", 14 | "ejs": "^3.1.6", 15 | "express": "^4.16.2", 16 | "path": "^0.12.7", 17 | "socket.io": "^3.1.1" 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /src/public/css/main.css: -------------------------------------------------------------------------------- 1 | body { 2 | font-family: sans-serif; 3 | background-color: rgb(189, 189, 189); 4 | } 5 | 6 | p { 7 | color: black; 8 | } 9 | 10 | a { 11 | font-weight: bold; 12 | text-decoration: none; 13 | color: #2a2a2a; 14 | } 15 | 16 | a:visited { 17 | font-weight: normal; 18 | } 19 | 20 | a:hover { 21 | text-decoration: underline; 22 | } 23 | 24 | audio { 25 | width: 300px; 26 | height: auto; 27 | backgorund-color: red; 28 | } 29 | 30 | .wrapper { 31 | width: 90vw; 32 | margin: 0 auto; 33 | } 34 | 35 | .greyText { 36 | opacity: 0.4; 37 | } 38 | 39 | @-webkit-keyframes redGlow { 40 | from { 41 | background-color: #8c190a; 42 | -webkit-box-shadow: 0 0 9px #9c291a; 43 | } 44 | 50% { 45 | background-color: #9c291a; 46 | -webkit-box-shadow: 0 0 18px #bdb5b4; 47 | } 48 | to { 49 | background-color: #8c190a; 50 | -webkit-box-shadow: 0 0 9px #9c291a; 51 | } 52 | } 53 | #recordingStatus { 54 | display: inline-block; 55 | width: 18px; 56 | height: 18px; 57 | border-radius: 20px; 58 | visibility: hidden; 59 | -webkit-animation-name: redGlow; 60 | -webkit-animation-duration: 2s; 61 | -webkit-animation-iteration-count: infinite; 62 | } 63 | 64 | #ResultText { 65 | width: 80vw; 66 | } 67 | 68 | #ResultText span { 69 | display: inline-block; 70 | margin-top: 10px; 71 | } 72 | 73 | #sessionSpeechData { 74 | width: 80vw; 75 | } 76 | 77 | #sessionSpeechData span { 78 | display: inline-block; 79 | margin-top: 10px; 80 | } 81 | 82 | .nl-Adjective { 83 | background-color: #1ada47; 84 | padding: 3px; 85 | border-radius: 5px; 86 | } 87 | 88 | .nl-Noun { 89 | background-color: #151ffa; 90 | padding: 3px; 91 | border-radius: 5px; 92 | color: white; 93 | } 94 | 95 | .nl-Verb { 96 | background-color: #ff1616; 97 | padding: 3px; 98 | border-radius: 5px; 99 | } 100 | 101 | 102 | .hiddenForms { 103 | opacity: 0.2; 104 | } 105 | 106 | h1 { 107 | color: black; 108 | } 109 | 110 | 111 | /* ========================================================================== 112 | Media Queries 113 | ========================================================================== */ 114 | 115 | /*========== Non-Mobile First Method ==========*/ 116 | 117 | /*Above */ 118 | 119 | @media only screen and (min-width: 1201px) {} 120 | 121 | /* Large Devices, Wide Screens */ 122 | 123 | @media only screen and (max-width: 1200px) {} 124 | 125 | /* Medium Devices, Desktops */ 126 | 127 | @media only screen and (max-width: 992px) {} 128 | 129 | /* Small Devices, Tablets */ 130 | 131 | @media only screen and (max-width: 768px) {} 132 | 133 | /* Extra Small Devices, Phones */ 134 | 135 | @media only screen and (max-width: 480px) {} 136 | 137 | /* Custom, iPhone Retina */ 138 | 139 | @media only screen and (max-width: 320px) {} 140 | 141 | @media print, (-o-min-device-pixel-ratio: 5/4), (-webkit-min-device-pixel-ratio: 1.25), (min-resolution: 120dpi) {} 142 | 143 | /* ========================================================================== 144 | Helper classes 145 | ========================================================================== */ 146 | 147 | .hidden { 148 | display: none !important; 149 | visibility: hidden; 150 | } 151 | 152 | .visuallyhidden { 153 | border: 0; 154 | clip: rect(0 0 0 0); 155 | height: 1px; 156 | margin: -1px; 157 | overflow: hidden; 158 | padding: 0; 159 | position: absolute; 160 | width: 1px; 161 | } 162 | 163 | .visuallyhidden.focusable:active, .visuallyhidden.focusable:focus { 164 | clip: auto; 165 | height: auto; 166 | margin: 0; 167 | overflow: visible; 168 | position: static; 169 | width: auto; 170 | } 171 | 172 | .invisible { 173 | visibility: hidden; 174 | } 175 | 176 | .clearfix:before, .clearfix:after { 177 | content: " "; 178 | display: table; 179 | } 180 | 181 | .clearfix:after { 182 | clear: both; 183 | } 184 | 185 | .clearfix { 186 | *zoom: 1; 187 | } 188 | 189 | /* ========================================================================== 190 | Print styles 191 | ========================================================================== */ 192 | 193 | @media print { 194 | *, *:before, *:after { 195 | background: transparent !important; 196 | color: #000 !important; 197 | box-shadow: none !important; 198 | text-shadow: none !important; 199 | } 200 | a, a:visited { 201 | text-decoration: underline; 202 | } 203 | a[href]:after { 204 | content: " (" attr(href) ")"; 205 | } 206 | abbr[title]:after { 207 | content: " (" attr(title) ")"; 208 | } 209 | a[href^="#"]:after, a[href^="javascript:"]:after { 210 | content: ""; 211 | } 212 | pre, blockquote { 213 | border: 1px solid #999; 214 | page-break-inside: avoid; 215 | } 216 | thead { 217 | display: table-header-group; 218 | } 219 | tr, img { 220 | page-break-inside: avoid; 221 | } 222 | img { 223 | max-width: 100% !important; 224 | } 225 | p, h2, h3 { 226 | orphans: 3; 227 | widows: 3; 228 | } 229 | h2, h3 { 230 | page-break-after: avoid; 231 | } 232 | } 233 | -------------------------------------------------------------------------------- /src/public/js/client.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | // Google Cloud Speech Playground with node.js and socket.io 4 | // Created by Vinzenz Aubry for sansho 24.01.17 5 | // Feel free to improve! 6 | // Contact: v@vinzenzaubry.com 7 | 8 | //connection to socket 9 | const socket = io.connect(); 10 | 11 | //================= CONFIG ================= 12 | // Stream Audio 13 | let bufferSize = 2048, 14 | AudioContext, 15 | context, 16 | processor, 17 | input, 18 | globalStream; 19 | 20 | //vars 21 | let audioElement = document.querySelector('audio'), 22 | finalWord = false, 23 | resultText = document.getElementById('ResultText'), 24 | removeLastSentence = true, 25 | streamStreaming = false; 26 | 27 | //audioStream constraints 28 | const constraints = { 29 | audio: true, 30 | video: false, 31 | }; 32 | 33 | //================= RECORDING ================= 34 | 35 | async function initRecording() { 36 | socket.emit('startGoogleCloudStream', ''); //init socket Google Speech Connection 37 | streamStreaming = true; 38 | AudioContext = window.AudioContext || window.webkitAudioContext; 39 | context = new AudioContext({ 40 | // if Non-interactive, use 'playback' or 'balanced' // https://developer.mozilla.org/en-US/docs/Web/API/AudioContextLatencyCategory 41 | latencyHint: 'interactive', 42 | }); 43 | 44 | await context.audioWorklet.addModule('./assets/js/recorderWorkletProcessor.js') 45 | context.resume(); 46 | 47 | globalStream = await navigator.mediaDevices.getUserMedia(constraints) 48 | input = context.createMediaStreamSource(globalStream) 49 | processor = new window.AudioWorkletNode( 50 | context, 51 | 'recorder.worklet' 52 | ); 53 | processor.connect(context.destination); 54 | context.resume() 55 | input.connect(processor) 56 | processor.port.onmessage = (e) => { 57 | const audioData = e.data; 58 | microphoneProcess(audioData) 59 | } 60 | } 61 | 62 | function microphoneProcess(buffer) { 63 | socket.emit('binaryData', buffer); 64 | } 65 | 66 | //================= INTERFACE ================= 67 | var startButton = document.getElementById('startRecButton'); 68 | startButton.addEventListener('click', startRecording); 69 | 70 | var endButton = document.getElementById('stopRecButton'); 71 | endButton.addEventListener('click', stopRecording); 72 | endButton.disabled = true; 73 | 74 | var recordingStatus = document.getElementById('recordingStatus'); 75 | 76 | function startRecording() { 77 | startButton.disabled = true; 78 | endButton.disabled = false; 79 | recordingStatus.style.visibility = 'visible'; 80 | initRecording(); 81 | } 82 | 83 | function stopRecording() { 84 | // waited for FinalWord 85 | startButton.disabled = false; 86 | endButton.disabled = true; 87 | recordingStatus.style.visibility = 'hidden'; 88 | streamStreaming = false; 89 | socket.emit('endGoogleCloudStream', ''); 90 | 91 | let track = globalStream.getTracks()[0]; 92 | track.stop(); 93 | 94 | input.disconnect(processor); 95 | processor.disconnect(context.destination); 96 | context.close().then(function () { 97 | input = null; 98 | processor = null; 99 | context = null; 100 | AudioContext = null; 101 | startButton.disabled = false; 102 | }); 103 | 104 | // context.close(); 105 | 106 | // audiovideostream.stop(); 107 | 108 | // microphone_stream.disconnect(script_processor_node); 109 | // script_processor_node.disconnect(audioContext.destination); 110 | // microphone_stream = null; 111 | // script_processor_node = null; 112 | 113 | // audiovideostream.stop(); 114 | // videoElement.srcObject = null; 115 | } 116 | 117 | //================= SOCKET IO ================= 118 | socket.on('connect', function (data) { 119 | console.log('connected to socket'); 120 | socket.emit('join', 'Server Connected to Client'); 121 | }); 122 | 123 | socket.on('messages', function (data) { 124 | console.log(data); 125 | }); 126 | 127 | socket.on('speechData', function (data) { 128 | // console.log(data.results[0].alternatives[0].transcript); 129 | var dataFinal = undefined || data.results[0].isFinal; 130 | 131 | if (dataFinal === false) { 132 | // console.log(resultText.lastElementChild); 133 | if (removeLastSentence) { 134 | resultText.lastElementChild.remove(); 135 | } 136 | removeLastSentence = true; 137 | 138 | //add empty span 139 | let empty = document.createElement('span'); 140 | resultText.appendChild(empty); 141 | 142 | //add children to empty span 143 | let edit = addTimeSettingsInterim(data); 144 | 145 | for (var i = 0; i < edit.length; i++) { 146 | resultText.lastElementChild.appendChild(edit[i]); 147 | resultText.lastElementChild.appendChild( 148 | document.createTextNode('\u00A0') 149 | ); 150 | } 151 | } else if (dataFinal === true) { 152 | resultText.lastElementChild.remove(); 153 | 154 | //add empty span 155 | let empty = document.createElement('span'); 156 | resultText.appendChild(empty); 157 | 158 | //add children to empty span 159 | let edit = addTimeSettingsFinal(data); 160 | for (var i = 0; i < edit.length; i++) { 161 | if (i === 0) { 162 | edit[i].innerText = capitalize(edit[i].innerText); 163 | } 164 | resultText.lastElementChild.appendChild(edit[i]); 165 | 166 | if (i !== edit.length - 1) { 167 | resultText.lastElementChild.appendChild( 168 | document.createTextNode('\u00A0') 169 | ); 170 | } 171 | } 172 | resultText.lastElementChild.appendChild( 173 | document.createTextNode('\u002E\u00A0') 174 | ); 175 | 176 | console.log("Google Speech sent 'final' Sentence."); 177 | finalWord = true; 178 | endButton.disabled = false; 179 | 180 | removeLastSentence = false; 181 | } 182 | }); 183 | 184 | //================= Juggling Spans for nlp Coloring ================= 185 | function addTimeSettingsInterim(speechData) { 186 | let wholeString = speechData.results[0].alternatives[0].transcript; 187 | console.log(wholeString); 188 | 189 | let nlpObject = nlp(wholeString).out('terms'); 190 | 191 | let words_without_time = []; 192 | 193 | for (let i = 0; i < nlpObject.length; i++) { 194 | //data 195 | let word = nlpObject[i].text; 196 | let tags = []; 197 | 198 | //generate span 199 | let newSpan = document.createElement('span'); 200 | newSpan.innerHTML = word; 201 | 202 | //push all tags 203 | for (let j = 0; j < nlpObject[i].tags.length; j++) { 204 | tags.push(nlpObject[i].tags[j]); 205 | } 206 | 207 | //add all classes 208 | for (let j = 0; j < nlpObject[i].tags.length; j++) { 209 | let cleanClassName = tags[j]; 210 | // console.log(tags); 211 | let className = `nl-${cleanClassName}`; 212 | newSpan.classList.add(className); 213 | } 214 | 215 | words_without_time.push(newSpan); 216 | } 217 | 218 | finalWord = false; 219 | endButton.disabled = true; 220 | 221 | return words_without_time; 222 | } 223 | 224 | function addTimeSettingsFinal(speechData) { 225 | let wholeString = speechData.results[0].alternatives[0].transcript; 226 | 227 | let nlpObject = nlp(wholeString).out('terms'); 228 | let words = speechData.results[0].alternatives[0].words; 229 | 230 | let words_n_time = []; 231 | 232 | for (let i = 0; i < words.length; i++) { 233 | //data 234 | let word = words[i].word; 235 | let startTime = `${words[i].startTime.seconds}.${words[i].startTime.nanos}`; 236 | let endTime = `${words[i].endTime.seconds}.${words[i].endTime.nanos}`; 237 | let tags = []; 238 | 239 | //generate span 240 | let newSpan = document.createElement('span'); 241 | newSpan.innerHTML = word; 242 | newSpan.dataset.startTime = startTime; 243 | 244 | //push all tags 245 | for (let j = 0; j < nlpObject[i].tags.length; j++) { 246 | tags.push(nlpObject[i].tags[j]); 247 | } 248 | 249 | //add all classes 250 | for (let j = 0; j < nlpObject[i].tags.length; j++) { 251 | let cleanClassName = nlpObject[i].tags[j]; 252 | // console.log(tags); 253 | let className = `nl-${cleanClassName}`; 254 | newSpan.classList.add(className); 255 | } 256 | 257 | words_n_time.push(newSpan); 258 | } 259 | 260 | return words_n_time; 261 | } 262 | 263 | window.onbeforeunload = function () { 264 | if (streamStreaming) { 265 | socket.emit('endGoogleCloudStream', ''); 266 | } 267 | }; 268 | 269 | //================= SANTAS HELPERS ================= 270 | 271 | // sampleRateHertz 16000 //saved sound is awefull 272 | function convertFloat32ToInt16(buffer) { 273 | let l = buffer.length; 274 | let buf = new Int16Array(l / 3); 275 | 276 | while (l--) { 277 | if (l % 3 == 0) { 278 | buf[l / 3] = buffer[l] * 0xffff; 279 | } 280 | } 281 | return buf.buffer; 282 | } 283 | 284 | function capitalize(s) { 285 | if (s.length < 1) { 286 | return s; 287 | } 288 | return s.charAt(0).toUpperCase() + s.slice(1); 289 | } 290 | -------------------------------------------------------------------------------- /src/public/js/recorderWorkletProcessor.js: -------------------------------------------------------------------------------- 1 | /** 2 | An in-place replacement for ScriptProcessorNode using AudioWorklet 3 | */ 4 | class RecorderProcessor extends AudioWorkletProcessor { 5 | // 0. Determine the buffer size (this is the same as the 1st argument of ScriptProcessor) 6 | bufferSize = 2048 7 | // 1. Track the current buffer fill level 8 | _bytesWritten = 0 9 | 10 | // 2. Create a buffer of fixed size 11 | _buffer = new Float32Array(this.bufferSize) 12 | 13 | constructor() { 14 | super() 15 | this.initBuffer() 16 | } 17 | 18 | initBuffer() { 19 | this._bytesWritten = 0 20 | } 21 | 22 | isBufferEmpty() { 23 | return this._bytesWritten === 0 24 | } 25 | 26 | isBufferFull() { 27 | return this._bytesWritten === this.bufferSize 28 | } 29 | 30 | /** 31 | * @param {Float32Array[][]} inputs 32 | * @returns {boolean} 33 | */ 34 | process(inputs) { 35 | // Grabbing the 1st channel similar to ScriptProcessorNode 36 | this.append(inputs[0][0]) 37 | 38 | return true 39 | } 40 | 41 | /** 42 | * 43 | * @param {Float32Array} channelData 44 | */ 45 | append(channelData) { 46 | if (this.isBufferFull()) { 47 | this.flush() 48 | } 49 | 50 | if (!channelData) return 51 | 52 | for (let i = 0; i < channelData.length; i++) { 53 | this._buffer[this._bytesWritten++] = channelData[i] 54 | } 55 | } 56 | 57 | flush() { 58 | // trim the buffer if ended prematurely 59 | const buffer = this._bytesWritten < this.bufferSize 60 | ? this._buffer.slice(0, this._bytesWritten) 61 | : this._buffer 62 | const result = this.downsampleBuffer(buffer, 44100, 16000); 63 | this.port.postMessage(result) 64 | this.initBuffer() 65 | } 66 | 67 | downsampleBuffer (buffer, sampleRate, outSampleRate) { 68 | if (outSampleRate == sampleRate) { 69 | return buffer; 70 | } 71 | if (outSampleRate > sampleRate) { 72 | throw 'downsampling rate show be smaller than original sample rate'; 73 | } 74 | var sampleRateRatio = sampleRate / outSampleRate; 75 | var newLength = Math.round(buffer.length / sampleRateRatio); 76 | var result = new Int16Array(newLength); 77 | var offsetResult = 0; 78 | var offsetBuffer = 0; 79 | while (offsetResult < result.length) { 80 | var nextOffsetBuffer = Math.round((offsetResult + 1) * sampleRateRatio); 81 | var accum = 0, 82 | count = 0; 83 | for (var i = offsetBuffer; i < nextOffsetBuffer && i < buffer.length; i++) { 84 | accum += buffer[i]; 85 | count++; 86 | } 87 | 88 | result[offsetResult] = Math.min(1, accum / count) * 0x7fff; 89 | offsetResult++; 90 | offsetBuffer = nextOffsetBuffer; 91 | } 92 | return result.buffer; 93 | }; 94 | 95 | } 96 | 97 | registerProcessor("recorder.worklet", RecorderProcessor) -------------------------------------------------------------------------------- /src/views/index.ejs: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | GCloud Speech Recognition Node + Socket.io 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 |

Google Cloud Speech Node with Socket.io Playground

17 | 18 | 19 | 20 |
21 | 22 | 23 |
 
24 |
25 | 26 |
27 |

28 | No Speech to Text yet 29 | 30 |

31 |
32 | 33 |
34 |
35 |
36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | -------------------------------------------------------------------------------- /srcLogOnly/app.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | // Google Cloud Speech Playground with node.js and socket.io 4 | // Created by Vinzenz Aubry for sansho 24.01.17 5 | // Feel free to improve! 6 | // Contact: v@vinzenzaubry.com 7 | 8 | const express = require('express'); // const bodyParser = require('body-parser'); // const path = require('path'); 9 | const fs = require('fs'); 10 | const environmentVars = require('dotenv').config(); 11 | 12 | // Google Cloud 13 | const speech = require('@google-cloud/speech'); 14 | const speechClient = new speech.SpeechClient(); // Creates a client 15 | 16 | 17 | const app = express(); 18 | const port = process.env.PORT || 1337; 19 | const server = require('http').createServer(app); 20 | 21 | const io = require('socket.io')(server); 22 | 23 | app.use('/assets', express.static(__dirname + '/public')); 24 | app.use('/session/assets', express.static(__dirname + '/public')); 25 | app.set('view engine', 'ejs'); 26 | 27 | 28 | // =========================== ROUTERS ================================ // 29 | 30 | app.get('/', function (req, res) { 31 | res.render('index', {}); 32 | }); 33 | 34 | app.use('/', function (req, res, next) { 35 | next(); // console.log(`Request Url: ${req.url}`); 36 | }); 37 | 38 | 39 | // =========================== SOCKET.IO ================================ // 40 | 41 | io.on('connection', function (client) { 42 | console.log('Client Connected to server'); 43 | let recognizeStream = null; 44 | 45 | client.on('join', function (data) { 46 | client.emit('messages', 'Socket Connected to Server'); 47 | }); 48 | 49 | client.on('messages', function (data) { 50 | client.emit('broad', data); 51 | }); 52 | 53 | client.on('startGoogleCloudStream', function (data) { 54 | startRecognitionStream(this, data); 55 | }); 56 | 57 | client.on('endGoogleCloudStream', function (data) { 58 | stopRecognitionStream(); 59 | }); 60 | 61 | client.on('binaryData', function (data) { 62 | // console.log(data); //log binary data 63 | if (recognizeStream !== null) { 64 | recognizeStream.write(data); 65 | } 66 | }); 67 | 68 | function startRecognitionStream(client, data) { 69 | recognizeStream = speechClient.streamingRecognize(request) 70 | .on('error', console.error) 71 | .on('data', (data) => { 72 | process.stdout.write( 73 | (data.results[0] && data.results[0].alternatives[0]) 74 | ? `Transcription: ${data.results[0].alternatives[0].transcript}\n` 75 | : `\n\nReached transcription time limit, press Ctrl+C\n`); 76 | client.emit('speechData', data); 77 | 78 | // if end of utterance, let's restart stream 79 | // this is a small hack. After 65 seconds of silence, the stream will still throw an error for speech length limit 80 | if (data.results[0] && data.results[0].isFinal) { 81 | stopRecognitionStream(); 82 | startRecognitionStream(client); 83 | // console.log('restarted stream serverside'); 84 | } 85 | }); 86 | } 87 | 88 | function stopRecognitionStream() { 89 | if (recognizeStream) { 90 | recognizeStream.end(); 91 | } 92 | recognizeStream = null; 93 | } 94 | }); 95 | 96 | 97 | // =========================== GOOGLE CLOUD SETTINGS ================================ // 98 | 99 | // The encoding of the audio file, e.g. 'LINEAR16' 100 | // The sample rate of the audio file in hertz, e.g. 16000 101 | // The BCP-47 language code to use, e.g. 'en-US' 102 | const encoding = 'LINEAR16'; 103 | const sampleRateHertz = 16000; 104 | const languageCode = 'en-US'; //en-US 105 | 106 | const request = { 107 | config: { 108 | encoding: encoding, 109 | sampleRateHertz: sampleRateHertz, 110 | languageCode: languageCode, 111 | profanityFilter: false, 112 | enableWordTimeOffsets: true, 113 | // speechContexts: [{ 114 | // phrases: ["hoful","shwazil"] 115 | // }] // add your own speech context for better recognition 116 | }, 117 | interimResults: true // If you want interim results, set this to true 118 | }; 119 | 120 | 121 | // =========================== START SERVER ================================ // 122 | 123 | server.listen(port, "127.0.0.1", function () { //http listen, to make socket work 124 | // app.address = "127.0.0.1"; 125 | console.log('Server started on port:' + port) 126 | }); 127 | -------------------------------------------------------------------------------- /srcLogOnly/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "GoogleCloudSpeechPlayground", 3 | "version": "1.0.1", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "GoogleCloudSpeechPlayground", 9 | "version": "1.0.1", 10 | "license": "ISC", 11 | "dependencies": { 12 | "@google-cloud/speech": "^4.2.0", 13 | "dotenv": "^8.2.0", 14 | "ejs": "^3.1.6", 15 | "express": "^4.18.2", 16 | "path": "^0.12.7", 17 | "socket.io": "^3.1.1" 18 | } 19 | }, 20 | "node_modules/@google-cloud/common": { 21 | "version": "3.6.0", 22 | "resolved": "https://registry.npmjs.org/@google-cloud/common/-/common-3.6.0.tgz", 23 | "integrity": "sha512-aHIFTqJZmeTNO9md8XxV+ywuvXF3xBm5WNmgWeeCK+XN5X+kGW0WEX94wGwj+/MdOnrVf4dL2RvSIt9J5yJG6Q==", 24 | "dependencies": { 25 | "@google-cloud/projectify": "^2.0.0", 26 | "@google-cloud/promisify": "^2.0.0", 27 | "arrify": "^2.0.1", 28 | "duplexify": "^4.1.1", 29 | "ent": "^2.2.0", 30 | "extend": "^3.0.2", 31 | "google-auth-library": "^7.0.2", 32 | "retry-request": "^4.1.1", 33 | "teeny-request": "^7.0.0" 34 | }, 35 | "engines": { 36 | "node": ">=10" 37 | } 38 | }, 39 | "node_modules/@google-cloud/projectify": { 40 | "version": "2.0.1", 41 | "resolved": "https://registry.npmjs.org/@google-cloud/projectify/-/projectify-2.0.1.tgz", 42 | "integrity": "sha512-ZDG38U/Yy6Zr21LaR3BTiiLtpJl6RkPS/JwoRT453G+6Q1DhlV0waNf8Lfu+YVYGIIxgKnLayJRfYlFJfiI8iQ==", 43 | "engines": { 44 | "node": ">=10" 45 | } 46 | }, 47 | "node_modules/@google-cloud/promisify": { 48 | "version": "2.0.3", 49 | "resolved": "https://registry.npmjs.org/@google-cloud/promisify/-/promisify-2.0.3.tgz", 50 | "integrity": "sha512-d4VSA86eL/AFTe5xtyZX+ePUjE8dIFu2T8zmdeNBSa5/kNgXPCx/o/wbFNHAGLJdGnk1vddRuMESD9HbOC8irw==", 51 | "engines": { 52 | "node": ">=10" 53 | } 54 | }, 55 | "node_modules/@google-cloud/speech": { 56 | "version": "4.2.0", 57 | "resolved": "https://registry.npmjs.org/@google-cloud/speech/-/speech-4.2.0.tgz", 58 | "integrity": "sha512-5QlL2Gg0CGLT5kS6gWiZuRy0layCnXeS5+CkHPJsqvTmmY5Ssf+XIDoocp9uBkrVwwPjKm74mFlSTTL5HnlBwQ==", 59 | "dependencies": { 60 | "@google-cloud/common": "^3.0.0", 61 | "@types/pumpify": "^1.4.1", 62 | "google-gax": "^2.9.2", 63 | "protobufjs": "^6.8.6", 64 | "pumpify": "^2.0.0", 65 | "stream-events": "^1.0.4" 66 | }, 67 | "engines": { 68 | "node": ">=10" 69 | } 70 | }, 71 | "node_modules/@grpc/grpc-js": { 72 | "version": "1.2.7", 73 | "resolved": "https://registry.npmjs.org/@grpc/grpc-js/-/grpc-js-1.2.7.tgz", 74 | "integrity": "sha512-hBkR/vZTodu/dA/kcKpiQtPQdjMbpfKv7RKfEByT5/7qOQNpIh2O6Sr1aldLMzstFqmGrufmR7XTc56VCMH7LA==", 75 | "dependencies": { 76 | "@types/node": ">=12.12.47", 77 | "google-auth-library": "^6.1.1", 78 | "semver": "^6.2.0" 79 | }, 80 | "engines": { 81 | "node": "^8.13.0 || >=10.10.0" 82 | } 83 | }, 84 | "node_modules/@grpc/grpc-js/node_modules/google-auth-library": { 85 | "version": "6.1.6", 86 | "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-6.1.6.tgz", 87 | "integrity": "sha512-Q+ZjUEvLQj/lrVHF/IQwRo6p3s8Nc44Zk/DALsN+ac3T4HY/g/3rrufkgtl+nZ1TW7DNAw5cTChdVp4apUXVgQ==", 88 | "dependencies": { 89 | "arrify": "^2.0.0", 90 | "base64-js": "^1.3.0", 91 | "ecdsa-sig-formatter": "^1.0.11", 92 | "fast-text-encoding": "^1.0.0", 93 | "gaxios": "^4.0.0", 94 | "gcp-metadata": "^4.2.0", 95 | "gtoken": "^5.0.4", 96 | "jws": "^4.0.0", 97 | "lru-cache": "^6.0.0" 98 | }, 99 | "engines": { 100 | "node": ">=10" 101 | } 102 | }, 103 | "node_modules/@grpc/proto-loader": { 104 | "version": "0.5.6", 105 | "resolved": "https://registry.npmjs.org/@grpc/proto-loader/-/proto-loader-0.5.6.tgz", 106 | "integrity": "sha512-DT14xgw3PSzPxwS13auTEwxhMMOoz33DPUKNtmYK/QYbBSpLXJy78FGGs5yVoxVobEqPm4iW9MOIoz0A3bLTRQ==", 107 | "dependencies": { 108 | "lodash.camelcase": "^4.3.0", 109 | "protobufjs": "^6.8.6" 110 | }, 111 | "engines": { 112 | "node": ">=6" 113 | } 114 | }, 115 | "node_modules/@protobufjs/aspromise": { 116 | "version": "1.1.2", 117 | "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", 118 | "integrity": "sha1-m4sMxmPWaafY9vXQiToU00jzD78=" 119 | }, 120 | "node_modules/@protobufjs/base64": { 121 | "version": "1.1.2", 122 | "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", 123 | "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==" 124 | }, 125 | "node_modules/@protobufjs/codegen": { 126 | "version": "2.0.4", 127 | "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", 128 | "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==" 129 | }, 130 | "node_modules/@protobufjs/eventemitter": { 131 | "version": "1.1.0", 132 | "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", 133 | "integrity": "sha1-NVy8mLr61ZePntCV85diHx0Ga3A=" 134 | }, 135 | "node_modules/@protobufjs/fetch": { 136 | "version": "1.1.0", 137 | "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", 138 | "integrity": "sha1-upn7WYYUr2VwDBYZ/wbUVLDYTEU=", 139 | "dependencies": { 140 | "@protobufjs/aspromise": "^1.1.1", 141 | "@protobufjs/inquire": "^1.1.0" 142 | } 143 | }, 144 | "node_modules/@protobufjs/float": { 145 | "version": "1.0.2", 146 | "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", 147 | "integrity": "sha1-Xp4avctz/Ap8uLKR33jIy9l7h9E=" 148 | }, 149 | "node_modules/@protobufjs/inquire": { 150 | "version": "1.1.0", 151 | "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", 152 | "integrity": "sha1-/yAOPnzyQp4tyvwRQIKOjMY48Ik=" 153 | }, 154 | "node_modules/@protobufjs/path": { 155 | "version": "1.1.2", 156 | "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", 157 | "integrity": "sha1-bMKyDFya1q0NzP0hynZz2Nf79o0=" 158 | }, 159 | "node_modules/@protobufjs/pool": { 160 | "version": "1.1.0", 161 | "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", 162 | "integrity": "sha1-Cf0V8tbTq/qbZbw2ZQbWrXhG/1Q=" 163 | }, 164 | "node_modules/@protobufjs/utf8": { 165 | "version": "1.1.0", 166 | "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", 167 | "integrity": "sha1-p3c2C1s5oaLlEG+OhY8v0tBgxXA=" 168 | }, 169 | "node_modules/@tootallnate/once": { 170 | "version": "1.1.2", 171 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 172 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 173 | "engines": { 174 | "node": ">= 6" 175 | } 176 | }, 177 | "node_modules/@types/component-emitter": { 178 | "version": "1.2.10", 179 | "resolved": "https://registry.npmjs.org/@types/component-emitter/-/component-emitter-1.2.10.tgz", 180 | "integrity": "sha512-bsjleuRKWmGqajMerkzox19aGbscQX5rmmvvXl3wlIp5gMG1HgkiwPxsN5p070fBDKTNSPgojVbuY1+HWMbFhg==" 181 | }, 182 | "node_modules/@types/cookie": { 183 | "version": "0.4.0", 184 | "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.4.0.tgz", 185 | "integrity": "sha512-y7mImlc/rNkvCRmg8gC3/lj87S7pTUIJ6QGjwHR9WQJcFs+ZMTOaoPrkdFA/YdbuqVEmEbb5RdhVxMkAcgOnpg==" 186 | }, 187 | "node_modules/@types/cors": { 188 | "version": "2.8.10", 189 | "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.10.tgz", 190 | "integrity": "sha512-C7srjHiVG3Ey1nR6d511dtDkCEjxuN9W1HWAEjGq8kpcwmNM6JJkpC0xvabM7BXTG2wDq8Eu33iH9aQKa7IvLQ==" 191 | }, 192 | "node_modules/@types/duplexify": { 193 | "version": "3.6.0", 194 | "resolved": "https://registry.npmjs.org/@types/duplexify/-/duplexify-3.6.0.tgz", 195 | "integrity": "sha512-5zOA53RUlzN74bvrSGwjudssD9F3a797sDZQkiYpUOxW+WHaXTCPz4/d5Dgi6FKnOqZ2CpaTo0DhgIfsXAOE/A==", 196 | "dependencies": { 197 | "@types/node": "*" 198 | } 199 | }, 200 | "node_modules/@types/long": { 201 | "version": "4.0.1", 202 | "resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.1.tgz", 203 | "integrity": "sha512-5tXH6Bx/kNGd3MgffdmP4dy2Z+G4eaXw0SE81Tq3BNadtnMR5/ySMzX4SLEzHJzSmPNn4HIdpQsBvXMUykr58w==" 204 | }, 205 | "node_modules/@types/node": { 206 | "version": "14.14.28", 207 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.14.28.tgz", 208 | "integrity": "sha512-lg55ArB+ZiHHbBBttLpzD07akz0QPrZgUODNakeC09i62dnrywr9mFErHuaPlB6I7z+sEbK+IYmplahvplCj2g==" 209 | }, 210 | "node_modules/@types/pumpify": { 211 | "version": "1.4.1", 212 | "resolved": "https://registry.npmjs.org/@types/pumpify/-/pumpify-1.4.1.tgz", 213 | "integrity": "sha512-l7u/Dnh1OG9T7VH6TvulR0g8oE8hgIW5409mSUKi8Vxw2+JV18aTa06Sv5bvNjrD0zbsB/cuZ/iTFQgFNfzIuw==", 214 | "dependencies": { 215 | "@types/duplexify": "*", 216 | "@types/node": "*" 217 | } 218 | }, 219 | "node_modules/abort-controller": { 220 | "version": "3.0.0", 221 | "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", 222 | "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", 223 | "dependencies": { 224 | "event-target-shim": "^5.0.0" 225 | }, 226 | "engines": { 227 | "node": ">=6.5" 228 | } 229 | }, 230 | "node_modules/accepts": { 231 | "version": "1.3.8", 232 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 233 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 234 | "dependencies": { 235 | "mime-types": "~2.1.34", 236 | "negotiator": "0.6.3" 237 | }, 238 | "engines": { 239 | "node": ">= 0.6" 240 | } 241 | }, 242 | "node_modules/agent-base": { 243 | "version": "6.0.2", 244 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 245 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 246 | "dependencies": { 247 | "debug": "4" 248 | }, 249 | "engines": { 250 | "node": ">= 6.0.0" 251 | } 252 | }, 253 | "node_modules/agent-base/node_modules/debug": { 254 | "version": "4.3.1", 255 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 256 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 257 | "dependencies": { 258 | "ms": "2.1.2" 259 | }, 260 | "engines": { 261 | "node": ">=6.0" 262 | }, 263 | "peerDependenciesMeta": { 264 | "supports-color": { 265 | "optional": true 266 | } 267 | } 268 | }, 269 | "node_modules/agent-base/node_modules/ms": { 270 | "version": "2.1.2", 271 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 272 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 273 | }, 274 | "node_modules/ansi-styles": { 275 | "version": "3.2.1", 276 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 277 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 278 | "dependencies": { 279 | "color-convert": "^1.9.0" 280 | }, 281 | "engines": { 282 | "node": ">=4" 283 | } 284 | }, 285 | "node_modules/array-flatten": { 286 | "version": "1.1.1", 287 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 288 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 289 | }, 290 | "node_modules/arrify": { 291 | "version": "2.0.1", 292 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-2.0.1.tgz", 293 | "integrity": "sha512-3duEwti880xqi4eAMN8AyR4a0ByT90zoYdLlevfrvU43vb0YZwZVfxOgxWrLXXXpyugL0hNZc9G6BiB5B3nUug==", 294 | "engines": { 295 | "node": ">=8" 296 | } 297 | }, 298 | "node_modules/async": { 299 | "version": "0.9.2", 300 | "resolved": "https://registry.npmjs.org/async/-/async-0.9.2.tgz", 301 | "integrity": "sha1-rqdNXmHB+JlhO/ZL2mbUx48v0X0=" 302 | }, 303 | "node_modules/balanced-match": { 304 | "version": "1.0.0", 305 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 306 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 307 | }, 308 | "node_modules/base64-arraybuffer": { 309 | "version": "0.1.4", 310 | "resolved": "https://registry.npmjs.org/base64-arraybuffer/-/base64-arraybuffer-0.1.4.tgz", 311 | "integrity": "sha1-mBjHngWbE1X5fgQooBfIOOkLqBI=", 312 | "engines": { 313 | "node": ">= 0.6.0" 314 | } 315 | }, 316 | "node_modules/base64-js": { 317 | "version": "1.5.1", 318 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 319 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 320 | "funding": [ 321 | { 322 | "type": "github", 323 | "url": "https://github.com/sponsors/feross" 324 | }, 325 | { 326 | "type": "patreon", 327 | "url": "https://www.patreon.com/feross" 328 | }, 329 | { 330 | "type": "consulting", 331 | "url": "https://feross.org/support" 332 | } 333 | ] 334 | }, 335 | "node_modules/base64id": { 336 | "version": "2.0.0", 337 | "resolved": "https://registry.npmjs.org/base64id/-/base64id-2.0.0.tgz", 338 | "integrity": "sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog==", 339 | "engines": { 340 | "node": "^4.5.0 || >= 5.9" 341 | } 342 | }, 343 | "node_modules/bignumber.js": { 344 | "version": "9.0.1", 345 | "resolved": "https://registry.npmjs.org/bignumber.js/-/bignumber.js-9.0.1.tgz", 346 | "integrity": "sha512-IdZR9mh6ahOBv/hYGiXyVuyCetmGJhtYkqLBpTStdhEGjegpPlUawydyaF3pbIOFynJTpllEs+NP+CS9jKFLjA==", 347 | "engines": { 348 | "node": "*" 349 | } 350 | }, 351 | "node_modules/body-parser": { 352 | "version": "1.20.1", 353 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", 354 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", 355 | "dependencies": { 356 | "bytes": "3.1.2", 357 | "content-type": "~1.0.4", 358 | "debug": "2.6.9", 359 | "depd": "2.0.0", 360 | "destroy": "1.2.0", 361 | "http-errors": "2.0.0", 362 | "iconv-lite": "0.4.24", 363 | "on-finished": "2.4.1", 364 | "qs": "6.11.0", 365 | "raw-body": "2.5.1", 366 | "type-is": "~1.6.18", 367 | "unpipe": "1.0.0" 368 | }, 369 | "engines": { 370 | "node": ">= 0.8", 371 | "npm": "1.2.8000 || >= 1.4.16" 372 | } 373 | }, 374 | "node_modules/brace-expansion": { 375 | "version": "1.1.11", 376 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 377 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 378 | "dependencies": { 379 | "balanced-match": "^1.0.0", 380 | "concat-map": "0.0.1" 381 | } 382 | }, 383 | "node_modules/buffer-equal-constant-time": { 384 | "version": "1.0.1", 385 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 386 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 387 | }, 388 | "node_modules/bytes": { 389 | "version": "3.1.2", 390 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 391 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 392 | "engines": { 393 | "node": ">= 0.8" 394 | } 395 | }, 396 | "node_modules/call-bind": { 397 | "version": "1.0.2", 398 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 399 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 400 | "dependencies": { 401 | "function-bind": "^1.1.1", 402 | "get-intrinsic": "^1.0.2" 403 | }, 404 | "funding": { 405 | "url": "https://github.com/sponsors/ljharb" 406 | } 407 | }, 408 | "node_modules/chalk": { 409 | "version": "2.4.2", 410 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 411 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 412 | "dependencies": { 413 | "ansi-styles": "^3.2.1", 414 | "escape-string-regexp": "^1.0.5", 415 | "supports-color": "^5.3.0" 416 | }, 417 | "engines": { 418 | "node": ">=4" 419 | } 420 | }, 421 | "node_modules/color-convert": { 422 | "version": "1.9.3", 423 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 424 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 425 | "dependencies": { 426 | "color-name": "1.1.3" 427 | } 428 | }, 429 | "node_modules/color-name": { 430 | "version": "1.1.3", 431 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 432 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 433 | }, 434 | "node_modules/component-emitter": { 435 | "version": "1.3.0", 436 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", 437 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==" 438 | }, 439 | "node_modules/concat-map": { 440 | "version": "0.0.1", 441 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 442 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 443 | }, 444 | "node_modules/content-disposition": { 445 | "version": "0.5.4", 446 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 447 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 448 | "dependencies": { 449 | "safe-buffer": "5.2.1" 450 | }, 451 | "engines": { 452 | "node": ">= 0.6" 453 | } 454 | }, 455 | "node_modules/content-type": { 456 | "version": "1.0.4", 457 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 458 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", 459 | "engines": { 460 | "node": ">= 0.6" 461 | } 462 | }, 463 | "node_modules/cookie": { 464 | "version": "0.5.0", 465 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 466 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 467 | "engines": { 468 | "node": ">= 0.6" 469 | } 470 | }, 471 | "node_modules/cookie-signature": { 472 | "version": "1.0.6", 473 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 474 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 475 | }, 476 | "node_modules/cors": { 477 | "version": "2.8.5", 478 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 479 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 480 | "dependencies": { 481 | "object-assign": "^4", 482 | "vary": "^1" 483 | }, 484 | "engines": { 485 | "node": ">= 0.10" 486 | } 487 | }, 488 | "node_modules/debug": { 489 | "version": "2.6.9", 490 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 491 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 492 | "dependencies": { 493 | "ms": "2.0.0" 494 | } 495 | }, 496 | "node_modules/depd": { 497 | "version": "2.0.0", 498 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 499 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 500 | "engines": { 501 | "node": ">= 0.8" 502 | } 503 | }, 504 | "node_modules/destroy": { 505 | "version": "1.2.0", 506 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 507 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 508 | "engines": { 509 | "node": ">= 0.8", 510 | "npm": "1.2.8000 || >= 1.4.16" 511 | } 512 | }, 513 | "node_modules/dotenv": { 514 | "version": "8.2.0", 515 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz", 516 | "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==", 517 | "engines": { 518 | "node": ">=8" 519 | } 520 | }, 521 | "node_modules/duplexify": { 522 | "version": "4.1.1", 523 | "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-4.1.1.tgz", 524 | "integrity": "sha512-DY3xVEmVHTv1wSzKNbwoU6nVjzI369Y6sPoqfYr0/xlx3IdX2n94xIszTcjPO8W8ZIv0Wb0PXNcjuZyT4wiICA==", 525 | "dependencies": { 526 | "end-of-stream": "^1.4.1", 527 | "inherits": "^2.0.3", 528 | "readable-stream": "^3.1.1", 529 | "stream-shift": "^1.0.0" 530 | } 531 | }, 532 | "node_modules/ecdsa-sig-formatter": { 533 | "version": "1.0.11", 534 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 535 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 536 | "dependencies": { 537 | "safe-buffer": "^5.0.1" 538 | } 539 | }, 540 | "node_modules/ee-first": { 541 | "version": "1.1.1", 542 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 543 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 544 | }, 545 | "node_modules/ejs": { 546 | "version": "3.1.6", 547 | "resolved": "https://registry.npmjs.org/ejs/-/ejs-3.1.6.tgz", 548 | "integrity": "sha512-9lt9Zse4hPucPkoP7FHDF0LQAlGyF9JVpnClFLFH3aSSbxmyoqINRpp/9wePWJTUl4KOQwRL72Iw3InHPDkoGw==", 549 | "dependencies": { 550 | "jake": "^10.6.1" 551 | }, 552 | "bin": { 553 | "ejs": "bin/cli.js" 554 | }, 555 | "engines": { 556 | "node": ">=0.10.0" 557 | } 558 | }, 559 | "node_modules/encodeurl": { 560 | "version": "1.0.2", 561 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 562 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 563 | "engines": { 564 | "node": ">= 0.8" 565 | } 566 | }, 567 | "node_modules/end-of-stream": { 568 | "version": "1.4.4", 569 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 570 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 571 | "dependencies": { 572 | "once": "^1.4.0" 573 | } 574 | }, 575 | "node_modules/engine.io": { 576 | "version": "4.1.1", 577 | "resolved": "https://registry.npmjs.org/engine.io/-/engine.io-4.1.1.tgz", 578 | "integrity": "sha512-t2E9wLlssQjGw0nluF6aYyfX8LwYU8Jj0xct+pAhfWfv/YrBn6TSNtEYsgxHIfaMqfrLx07czcMg9bMN6di+3w==", 579 | "dependencies": { 580 | "accepts": "~1.3.4", 581 | "base64id": "2.0.0", 582 | "cookie": "~0.4.1", 583 | "cors": "~2.8.5", 584 | "debug": "~4.3.1", 585 | "engine.io-parser": "~4.0.0", 586 | "ws": "~7.4.2" 587 | }, 588 | "engines": { 589 | "node": ">=10.0.0" 590 | } 591 | }, 592 | "node_modules/engine.io-parser": { 593 | "version": "4.0.2", 594 | "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-4.0.2.tgz", 595 | "integrity": "sha512-sHfEQv6nmtJrq6TKuIz5kyEKH/qSdK56H/A+7DnAuUPWosnIZAS2NHNcPLmyjtY3cGS/MqJdZbUjW97JU72iYg==", 596 | "dependencies": { 597 | "base64-arraybuffer": "0.1.4" 598 | }, 599 | "engines": { 600 | "node": ">=8.0.0" 601 | } 602 | }, 603 | "node_modules/engine.io/node_modules/cookie": { 604 | "version": "0.4.1", 605 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz", 606 | "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA==", 607 | "engines": { 608 | "node": ">= 0.6" 609 | } 610 | }, 611 | "node_modules/engine.io/node_modules/debug": { 612 | "version": "4.3.1", 613 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 614 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 615 | "dependencies": { 616 | "ms": "2.1.2" 617 | }, 618 | "engines": { 619 | "node": ">=6.0" 620 | }, 621 | "peerDependenciesMeta": { 622 | "supports-color": { 623 | "optional": true 624 | } 625 | } 626 | }, 627 | "node_modules/engine.io/node_modules/ms": { 628 | "version": "2.1.2", 629 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 630 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 631 | }, 632 | "node_modules/ent": { 633 | "version": "2.2.0", 634 | "resolved": "https://registry.npmjs.org/ent/-/ent-2.2.0.tgz", 635 | "integrity": "sha1-6WQhkyWiHQX0RGai9obtbOX13R0=" 636 | }, 637 | "node_modules/escape-html": { 638 | "version": "1.0.3", 639 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 640 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 641 | }, 642 | "node_modules/escape-string-regexp": { 643 | "version": "1.0.5", 644 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 645 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 646 | "engines": { 647 | "node": ">=0.8.0" 648 | } 649 | }, 650 | "node_modules/etag": { 651 | "version": "1.8.1", 652 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 653 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 654 | "engines": { 655 | "node": ">= 0.6" 656 | } 657 | }, 658 | "node_modules/event-target-shim": { 659 | "version": "5.0.1", 660 | "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz", 661 | "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==", 662 | "engines": { 663 | "node": ">=6" 664 | } 665 | }, 666 | "node_modules/express": { 667 | "version": "4.18.2", 668 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", 669 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", 670 | "dependencies": { 671 | "accepts": "~1.3.8", 672 | "array-flatten": "1.1.1", 673 | "body-parser": "1.20.1", 674 | "content-disposition": "0.5.4", 675 | "content-type": "~1.0.4", 676 | "cookie": "0.5.0", 677 | "cookie-signature": "1.0.6", 678 | "debug": "2.6.9", 679 | "depd": "2.0.0", 680 | "encodeurl": "~1.0.2", 681 | "escape-html": "~1.0.3", 682 | "etag": "~1.8.1", 683 | "finalhandler": "1.2.0", 684 | "fresh": "0.5.2", 685 | "http-errors": "2.0.0", 686 | "merge-descriptors": "1.0.1", 687 | "methods": "~1.1.2", 688 | "on-finished": "2.4.1", 689 | "parseurl": "~1.3.3", 690 | "path-to-regexp": "0.1.7", 691 | "proxy-addr": "~2.0.7", 692 | "qs": "6.11.0", 693 | "range-parser": "~1.2.1", 694 | "safe-buffer": "5.2.1", 695 | "send": "0.18.0", 696 | "serve-static": "1.15.0", 697 | "setprototypeof": "1.2.0", 698 | "statuses": "2.0.1", 699 | "type-is": "~1.6.18", 700 | "utils-merge": "1.0.1", 701 | "vary": "~1.1.2" 702 | }, 703 | "engines": { 704 | "node": ">= 0.10.0" 705 | } 706 | }, 707 | "node_modules/extend": { 708 | "version": "3.0.2", 709 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 710 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 711 | }, 712 | "node_modules/fast-text-encoding": { 713 | "version": "1.0.3", 714 | "resolved": "https://registry.npmjs.org/fast-text-encoding/-/fast-text-encoding-1.0.3.tgz", 715 | "integrity": "sha512-dtm4QZH9nZtcDt8qJiOH9fcQd1NAgi+K1O2DbE6GG1PPCK/BWfOH3idCTRQ4ImXRUOyopDEgDEnVEE7Y/2Wrig==" 716 | }, 717 | "node_modules/filelist": { 718 | "version": "1.0.2", 719 | "resolved": "https://registry.npmjs.org/filelist/-/filelist-1.0.2.tgz", 720 | "integrity": "sha512-z7O0IS8Plc39rTCq6i6iHxk43duYOn8uFJiWSewIq0Bww1RNybVHSCjahmcC87ZqAm4OTvFzlzeGu3XAzG1ctQ==", 721 | "dependencies": { 722 | "minimatch": "^3.0.4" 723 | } 724 | }, 725 | "node_modules/finalhandler": { 726 | "version": "1.2.0", 727 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 728 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 729 | "dependencies": { 730 | "debug": "2.6.9", 731 | "encodeurl": "~1.0.2", 732 | "escape-html": "~1.0.3", 733 | "on-finished": "2.4.1", 734 | "parseurl": "~1.3.3", 735 | "statuses": "2.0.1", 736 | "unpipe": "~1.0.0" 737 | }, 738 | "engines": { 739 | "node": ">= 0.8" 740 | } 741 | }, 742 | "node_modules/forwarded": { 743 | "version": "0.2.0", 744 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 745 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 746 | "engines": { 747 | "node": ">= 0.6" 748 | } 749 | }, 750 | "node_modules/fresh": { 751 | "version": "0.5.2", 752 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 753 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 754 | "engines": { 755 | "node": ">= 0.6" 756 | } 757 | }, 758 | "node_modules/function-bind": { 759 | "version": "1.1.1", 760 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 761 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 762 | }, 763 | "node_modules/gaxios": { 764 | "version": "4.1.0", 765 | "resolved": "https://registry.npmjs.org/gaxios/-/gaxios-4.1.0.tgz", 766 | "integrity": "sha512-vb0to8xzGnA2qcgywAjtshOKKVDf2eQhJoiL6fHhgW5tVN7wNk7egnYIO9zotfn3lQ3De1VPdf7V5/BWfCtCmg==", 767 | "dependencies": { 768 | "abort-controller": "^3.0.0", 769 | "extend": "^3.0.2", 770 | "https-proxy-agent": "^5.0.0", 771 | "is-stream": "^2.0.0", 772 | "node-fetch": "^2.3.0" 773 | }, 774 | "engines": { 775 | "node": ">=10" 776 | } 777 | }, 778 | "node_modules/gcp-metadata": { 779 | "version": "4.2.1", 780 | "resolved": "https://registry.npmjs.org/gcp-metadata/-/gcp-metadata-4.2.1.tgz", 781 | "integrity": "sha512-tSk+REe5iq/N+K+SK1XjZJUrFPuDqGZVzCy2vocIHIGmPlTGsa8owXMJwGkrXr73NO0AzhPW4MF2DEHz7P2AVw==", 782 | "dependencies": { 783 | "gaxios": "^4.0.0", 784 | "json-bigint": "^1.0.0" 785 | }, 786 | "engines": { 787 | "node": ">=10" 788 | } 789 | }, 790 | "node_modules/get-intrinsic": { 791 | "version": "1.1.3", 792 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.3.tgz", 793 | "integrity": "sha512-QJVz1Tj7MS099PevUG5jvnt9tSkXN8K14dxQlikJuPt4uD9hHAHjLyLBiLR5zELelBdD9QNRAXZzsJx0WaDL9A==", 794 | "dependencies": { 795 | "function-bind": "^1.1.1", 796 | "has": "^1.0.3", 797 | "has-symbols": "^1.0.3" 798 | }, 799 | "funding": { 800 | "url": "https://github.com/sponsors/ljharb" 801 | } 802 | }, 803 | "node_modules/google-auth-library": { 804 | "version": "7.0.2", 805 | "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-7.0.2.tgz", 806 | "integrity": "sha512-vjyNZR3pDLC0u7GHLfj+Hw9tGprrJwoMwkYGqURCXYITjCrP9HprOyxVV+KekdLgATtWGuDkQG2MTh0qpUPUgg==", 807 | "dependencies": { 808 | "arrify": "^2.0.0", 809 | "base64-js": "^1.3.0", 810 | "ecdsa-sig-formatter": "^1.0.11", 811 | "fast-text-encoding": "^1.0.0", 812 | "gaxios": "^4.0.0", 813 | "gcp-metadata": "^4.2.0", 814 | "gtoken": "^5.0.4", 815 | "jws": "^4.0.0", 816 | "lru-cache": "^6.0.0" 817 | }, 818 | "engines": { 819 | "node": ">=10" 820 | } 821 | }, 822 | "node_modules/google-gax": { 823 | "version": "2.10.3", 824 | "resolved": "https://registry.npmjs.org/google-gax/-/google-gax-2.10.3.tgz", 825 | "integrity": "sha512-jESs/ME9WgMzfGQKJDu9ea2mEKjznKByRL+5xb8mKfHlbUfS/LxNLNCg/35RgXwVXcNSCqkEY90z8wHxvgdd/Q==", 826 | "dependencies": { 827 | "@grpc/grpc-js": "~1.2.0", 828 | "@grpc/proto-loader": "^0.5.1", 829 | "@types/long": "^4.0.0", 830 | "abort-controller": "^3.0.0", 831 | "duplexify": "^4.0.0", 832 | "fast-text-encoding": "^1.0.3", 833 | "google-auth-library": "^7.0.2", 834 | "is-stream-ended": "^0.1.4", 835 | "node-fetch": "^2.6.1", 836 | "protobufjs": "^6.10.2", 837 | "retry-request": "^4.0.0" 838 | }, 839 | "bin": { 840 | "compileProtos": "build/tools/compileProtos.js" 841 | }, 842 | "engines": { 843 | "node": ">=10" 844 | } 845 | }, 846 | "node_modules/google-p12-pem": { 847 | "version": "3.1.4", 848 | "resolved": "https://registry.npmjs.org/google-p12-pem/-/google-p12-pem-3.1.4.tgz", 849 | "integrity": "sha512-HHuHmkLgwjdmVRngf5+gSmpkyaRI6QmOg77J8tkNBHhNEI62sGHyw4/+UkgyZEI7h84NbWprXDJ+sa3xOYFvTg==", 850 | "dependencies": { 851 | "node-forge": "^1.3.1" 852 | }, 853 | "bin": { 854 | "gp12-pem": "build/src/bin/gp12-pem.js" 855 | }, 856 | "engines": { 857 | "node": ">=10" 858 | } 859 | }, 860 | "node_modules/gtoken": { 861 | "version": "5.2.1", 862 | "resolved": "https://registry.npmjs.org/gtoken/-/gtoken-5.2.1.tgz", 863 | "integrity": "sha512-OY0BfPKe3QnMsY9MzTHTSKn+Vl2l1CcLe6BwDEQj00mbbkl5nyQ/7EUREstg4fQNZ8iYE7br4JJ7TdKeDOPWmw==", 864 | "dependencies": { 865 | "gaxios": "^4.0.0", 866 | "google-p12-pem": "^3.0.3", 867 | "jws": "^4.0.0" 868 | }, 869 | "engines": { 870 | "node": ">=10" 871 | } 872 | }, 873 | "node_modules/has": { 874 | "version": "1.0.3", 875 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 876 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 877 | "dependencies": { 878 | "function-bind": "^1.1.1" 879 | }, 880 | "engines": { 881 | "node": ">= 0.4.0" 882 | } 883 | }, 884 | "node_modules/has-flag": { 885 | "version": "3.0.0", 886 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 887 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 888 | "engines": { 889 | "node": ">=4" 890 | } 891 | }, 892 | "node_modules/has-symbols": { 893 | "version": "1.0.3", 894 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 895 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 896 | "engines": { 897 | "node": ">= 0.4" 898 | }, 899 | "funding": { 900 | "url": "https://github.com/sponsors/ljharb" 901 | } 902 | }, 903 | "node_modules/http-errors": { 904 | "version": "2.0.0", 905 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 906 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 907 | "dependencies": { 908 | "depd": "2.0.0", 909 | "inherits": "2.0.4", 910 | "setprototypeof": "1.2.0", 911 | "statuses": "2.0.1", 912 | "toidentifier": "1.0.1" 913 | }, 914 | "engines": { 915 | "node": ">= 0.8" 916 | } 917 | }, 918 | "node_modules/http-proxy-agent": { 919 | "version": "4.0.1", 920 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 921 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 922 | "dependencies": { 923 | "@tootallnate/once": "1", 924 | "agent-base": "6", 925 | "debug": "4" 926 | }, 927 | "engines": { 928 | "node": ">= 6" 929 | } 930 | }, 931 | "node_modules/http-proxy-agent/node_modules/debug": { 932 | "version": "4.3.1", 933 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 934 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 935 | "dependencies": { 936 | "ms": "2.1.2" 937 | }, 938 | "engines": { 939 | "node": ">=6.0" 940 | }, 941 | "peerDependenciesMeta": { 942 | "supports-color": { 943 | "optional": true 944 | } 945 | } 946 | }, 947 | "node_modules/http-proxy-agent/node_modules/ms": { 948 | "version": "2.1.2", 949 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 950 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 951 | }, 952 | "node_modules/https-proxy-agent": { 953 | "version": "5.0.0", 954 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 955 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 956 | "dependencies": { 957 | "agent-base": "6", 958 | "debug": "4" 959 | }, 960 | "engines": { 961 | "node": ">= 6" 962 | } 963 | }, 964 | "node_modules/https-proxy-agent/node_modules/debug": { 965 | "version": "4.3.1", 966 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 967 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 968 | "dependencies": { 969 | "ms": "2.1.2" 970 | }, 971 | "engines": { 972 | "node": ">=6.0" 973 | }, 974 | "peerDependenciesMeta": { 975 | "supports-color": { 976 | "optional": true 977 | } 978 | } 979 | }, 980 | "node_modules/https-proxy-agent/node_modules/ms": { 981 | "version": "2.1.2", 982 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 983 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 984 | }, 985 | "node_modules/iconv-lite": { 986 | "version": "0.4.24", 987 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 988 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 989 | "dependencies": { 990 | "safer-buffer": ">= 2.1.2 < 3" 991 | }, 992 | "engines": { 993 | "node": ">=0.10.0" 994 | } 995 | }, 996 | "node_modules/inherits": { 997 | "version": "2.0.4", 998 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 999 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1000 | }, 1001 | "node_modules/ipaddr.js": { 1002 | "version": "1.9.1", 1003 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 1004 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 1005 | "engines": { 1006 | "node": ">= 0.10" 1007 | } 1008 | }, 1009 | "node_modules/is-stream": { 1010 | "version": "2.0.0", 1011 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", 1012 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==", 1013 | "engines": { 1014 | "node": ">=8" 1015 | } 1016 | }, 1017 | "node_modules/is-stream-ended": { 1018 | "version": "0.1.4", 1019 | "resolved": "https://registry.npmjs.org/is-stream-ended/-/is-stream-ended-0.1.4.tgz", 1020 | "integrity": "sha512-xj0XPvmr7bQFTvirqnFr50o0hQIh6ZItDqloxt5aJrR4NQsYeSsyFQERYGCAzfindAcnKjINnwEEgLx4IqVzQw==" 1021 | }, 1022 | "node_modules/jake": { 1023 | "version": "10.8.2", 1024 | "resolved": "https://registry.npmjs.org/jake/-/jake-10.8.2.tgz", 1025 | "integrity": "sha512-eLpKyrfG3mzvGE2Du8VoPbeSkRry093+tyNjdYaBbJS9v17knImYGNXQCUV0gLxQtF82m3E8iRb/wdSQZLoq7A==", 1026 | "dependencies": { 1027 | "async": "0.9.x", 1028 | "chalk": "^2.4.2", 1029 | "filelist": "^1.0.1", 1030 | "minimatch": "^3.0.4" 1031 | }, 1032 | "bin": { 1033 | "jake": "bin/cli.js" 1034 | }, 1035 | "engines": { 1036 | "node": "*" 1037 | } 1038 | }, 1039 | "node_modules/json-bigint": { 1040 | "version": "1.0.0", 1041 | "resolved": "https://registry.npmjs.org/json-bigint/-/json-bigint-1.0.0.tgz", 1042 | "integrity": "sha512-SiPv/8VpZuWbvLSMtTDU8hEfrZWg/mH/nV/b4o0CYbSxu1UIQPLdwKOCIyLQX+VIPO5vrLX3i8qtqFyhdPSUSQ==", 1043 | "dependencies": { 1044 | "bignumber.js": "^9.0.0" 1045 | } 1046 | }, 1047 | "node_modules/jwa": { 1048 | "version": "2.0.0", 1049 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-2.0.0.tgz", 1050 | "integrity": "sha512-jrZ2Qx916EA+fq9cEAeCROWPTfCwi1IVHqT2tapuqLEVVDKFDENFw1oL+MwrTvH6msKxsd1YTDVw6uKEcsrLEA==", 1051 | "dependencies": { 1052 | "buffer-equal-constant-time": "1.0.1", 1053 | "ecdsa-sig-formatter": "1.0.11", 1054 | "safe-buffer": "^5.0.1" 1055 | } 1056 | }, 1057 | "node_modules/jws": { 1058 | "version": "4.0.0", 1059 | "resolved": "https://registry.npmjs.org/jws/-/jws-4.0.0.tgz", 1060 | "integrity": "sha512-KDncfTmOZoOMTFG4mBlG0qUIOlc03fmzH+ru6RgYVZhPkyiy/92Owlt/8UEN+a4TXR1FQetfIpJE8ApdvdVxTg==", 1061 | "dependencies": { 1062 | "jwa": "^2.0.0", 1063 | "safe-buffer": "^5.0.1" 1064 | } 1065 | }, 1066 | "node_modules/lodash.camelcase": { 1067 | "version": "4.3.0", 1068 | "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", 1069 | "integrity": "sha1-soqmKIorn8ZRA1x3EfZathkDMaY=" 1070 | }, 1071 | "node_modules/long": { 1072 | "version": "4.0.0", 1073 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 1074 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 1075 | }, 1076 | "node_modules/lru-cache": { 1077 | "version": "6.0.0", 1078 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1079 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1080 | "dependencies": { 1081 | "yallist": "^4.0.0" 1082 | }, 1083 | "engines": { 1084 | "node": ">=10" 1085 | } 1086 | }, 1087 | "node_modules/media-typer": { 1088 | "version": "0.3.0", 1089 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1090 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 1091 | "engines": { 1092 | "node": ">= 0.6" 1093 | } 1094 | }, 1095 | "node_modules/merge-descriptors": { 1096 | "version": "1.0.1", 1097 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1098 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1099 | }, 1100 | "node_modules/methods": { 1101 | "version": "1.1.2", 1102 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1103 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", 1104 | "engines": { 1105 | "node": ">= 0.6" 1106 | } 1107 | }, 1108 | "node_modules/mime": { 1109 | "version": "1.6.0", 1110 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1111 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 1112 | "bin": { 1113 | "mime": "cli.js" 1114 | }, 1115 | "engines": { 1116 | "node": ">=4" 1117 | } 1118 | }, 1119 | "node_modules/mime-db": { 1120 | "version": "1.52.0", 1121 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1122 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 1123 | "engines": { 1124 | "node": ">= 0.6" 1125 | } 1126 | }, 1127 | "node_modules/mime-types": { 1128 | "version": "2.1.35", 1129 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1130 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1131 | "dependencies": { 1132 | "mime-db": "1.52.0" 1133 | }, 1134 | "engines": { 1135 | "node": ">= 0.6" 1136 | } 1137 | }, 1138 | "node_modules/minimatch": { 1139 | "version": "3.0.4", 1140 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1141 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1142 | "dependencies": { 1143 | "brace-expansion": "^1.1.7" 1144 | }, 1145 | "engines": { 1146 | "node": "*" 1147 | } 1148 | }, 1149 | "node_modules/ms": { 1150 | "version": "2.0.0", 1151 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1152 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 1153 | }, 1154 | "node_modules/negotiator": { 1155 | "version": "0.6.3", 1156 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1157 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 1158 | "engines": { 1159 | "node": ">= 0.6" 1160 | } 1161 | }, 1162 | "node_modules/node-fetch": { 1163 | "version": "2.6.7", 1164 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.7.tgz", 1165 | "integrity": "sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==", 1166 | "dependencies": { 1167 | "whatwg-url": "^5.0.0" 1168 | }, 1169 | "engines": { 1170 | "node": "4.x || >=6.0.0" 1171 | }, 1172 | "peerDependencies": { 1173 | "encoding": "^0.1.0" 1174 | }, 1175 | "peerDependenciesMeta": { 1176 | "encoding": { 1177 | "optional": true 1178 | } 1179 | } 1180 | }, 1181 | "node_modules/node-forge": { 1182 | "version": "1.3.1", 1183 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", 1184 | "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==", 1185 | "engines": { 1186 | "node": ">= 6.13.0" 1187 | } 1188 | }, 1189 | "node_modules/object-assign": { 1190 | "version": "4.1.1", 1191 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1192 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1193 | "engines": { 1194 | "node": ">=0.10.0" 1195 | } 1196 | }, 1197 | "node_modules/object-inspect": { 1198 | "version": "1.12.2", 1199 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz", 1200 | "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==", 1201 | "funding": { 1202 | "url": "https://github.com/sponsors/ljharb" 1203 | } 1204 | }, 1205 | "node_modules/on-finished": { 1206 | "version": "2.4.1", 1207 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 1208 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 1209 | "dependencies": { 1210 | "ee-first": "1.1.1" 1211 | }, 1212 | "engines": { 1213 | "node": ">= 0.8" 1214 | } 1215 | }, 1216 | "node_modules/once": { 1217 | "version": "1.4.0", 1218 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1219 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1220 | "dependencies": { 1221 | "wrappy": "1" 1222 | } 1223 | }, 1224 | "node_modules/parseurl": { 1225 | "version": "1.3.3", 1226 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1227 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1228 | "engines": { 1229 | "node": ">= 0.8" 1230 | } 1231 | }, 1232 | "node_modules/path": { 1233 | "version": "0.12.7", 1234 | "resolved": "https://registry.npmjs.org/path/-/path-0.12.7.tgz", 1235 | "integrity": "sha1-1NwqUGxM4hl+tIHr/NWzbAFAsQ8=", 1236 | "dependencies": { 1237 | "process": "^0.11.1", 1238 | "util": "^0.10.3" 1239 | } 1240 | }, 1241 | "node_modules/path-to-regexp": { 1242 | "version": "0.1.7", 1243 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1244 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1245 | }, 1246 | "node_modules/process": { 1247 | "version": "0.11.10", 1248 | "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", 1249 | "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=", 1250 | "engines": { 1251 | "node": ">= 0.6.0" 1252 | } 1253 | }, 1254 | "node_modules/protobufjs": { 1255 | "version": "6.10.2", 1256 | "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.10.2.tgz", 1257 | "integrity": "sha512-27yj+04uF6ya9l+qfpH187aqEzfCF4+Uit0I9ZBQVqK09hk/SQzKa2MUqUpXaVa7LOFRg1TSSr3lVxGOk6c0SQ==", 1258 | "hasInstallScript": true, 1259 | "dependencies": { 1260 | "@protobufjs/aspromise": "^1.1.2", 1261 | "@protobufjs/base64": "^1.1.2", 1262 | "@protobufjs/codegen": "^2.0.4", 1263 | "@protobufjs/eventemitter": "^1.1.0", 1264 | "@protobufjs/fetch": "^1.1.0", 1265 | "@protobufjs/float": "^1.0.2", 1266 | "@protobufjs/inquire": "^1.1.0", 1267 | "@protobufjs/path": "^1.1.2", 1268 | "@protobufjs/pool": "^1.1.0", 1269 | "@protobufjs/utf8": "^1.1.0", 1270 | "@types/long": "^4.0.1", 1271 | "@types/node": "^13.7.0", 1272 | "long": "^4.0.0" 1273 | }, 1274 | "bin": { 1275 | "pbjs": "bin/pbjs", 1276 | "pbts": "bin/pbts" 1277 | } 1278 | }, 1279 | "node_modules/protobufjs/node_modules/@types/node": { 1280 | "version": "13.13.42", 1281 | "resolved": "https://registry.npmjs.org/@types/node/-/node-13.13.42.tgz", 1282 | "integrity": "sha512-g+w2QgbW7k2CWLOXzQXbO37a7v5P9ObPvYahKphdBLV5aqpbVZRhTpWCT0SMRqX1i30Aig791ZmIM2fJGL2S8A==" 1283 | }, 1284 | "node_modules/proxy-addr": { 1285 | "version": "2.0.7", 1286 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1287 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1288 | "dependencies": { 1289 | "forwarded": "0.2.0", 1290 | "ipaddr.js": "1.9.1" 1291 | }, 1292 | "engines": { 1293 | "node": ">= 0.10" 1294 | } 1295 | }, 1296 | "node_modules/pump": { 1297 | "version": "3.0.0", 1298 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1299 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1300 | "dependencies": { 1301 | "end-of-stream": "^1.1.0", 1302 | "once": "^1.3.1" 1303 | } 1304 | }, 1305 | "node_modules/pumpify": { 1306 | "version": "2.0.1", 1307 | "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-2.0.1.tgz", 1308 | "integrity": "sha512-m7KOje7jZxrmutanlkS1daj1dS6z6BgslzOXmcSEpIlCxM3VJH7lG5QLeck/6hgF6F4crFf01UtQmNsJfweTAw==", 1309 | "dependencies": { 1310 | "duplexify": "^4.1.1", 1311 | "inherits": "^2.0.3", 1312 | "pump": "^3.0.0" 1313 | } 1314 | }, 1315 | "node_modules/qs": { 1316 | "version": "6.11.0", 1317 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 1318 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 1319 | "dependencies": { 1320 | "side-channel": "^1.0.4" 1321 | }, 1322 | "engines": { 1323 | "node": ">=0.6" 1324 | }, 1325 | "funding": { 1326 | "url": "https://github.com/sponsors/ljharb" 1327 | } 1328 | }, 1329 | "node_modules/range-parser": { 1330 | "version": "1.2.1", 1331 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1332 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1333 | "engines": { 1334 | "node": ">= 0.6" 1335 | } 1336 | }, 1337 | "node_modules/raw-body": { 1338 | "version": "2.5.1", 1339 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 1340 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 1341 | "dependencies": { 1342 | "bytes": "3.1.2", 1343 | "http-errors": "2.0.0", 1344 | "iconv-lite": "0.4.24", 1345 | "unpipe": "1.0.0" 1346 | }, 1347 | "engines": { 1348 | "node": ">= 0.8" 1349 | } 1350 | }, 1351 | "node_modules/readable-stream": { 1352 | "version": "3.6.0", 1353 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 1354 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 1355 | "dependencies": { 1356 | "inherits": "^2.0.3", 1357 | "string_decoder": "^1.1.1", 1358 | "util-deprecate": "^1.0.1" 1359 | }, 1360 | "engines": { 1361 | "node": ">= 6" 1362 | } 1363 | }, 1364 | "node_modules/retry-request": { 1365 | "version": "4.1.3", 1366 | "resolved": "https://registry.npmjs.org/retry-request/-/retry-request-4.1.3.tgz", 1367 | "integrity": "sha512-QnRZUpuPNgX0+D1xVxul6DbJ9slvo4Rm6iV/dn63e048MvGbUZiKySVt6Tenp04JqmchxjiLltGerOJys7kJYQ==", 1368 | "dependencies": { 1369 | "debug": "^4.1.1" 1370 | }, 1371 | "engines": { 1372 | "node": ">=8.10.0" 1373 | } 1374 | }, 1375 | "node_modules/retry-request/node_modules/debug": { 1376 | "version": "4.3.1", 1377 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 1378 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 1379 | "dependencies": { 1380 | "ms": "2.1.2" 1381 | }, 1382 | "engines": { 1383 | "node": ">=6.0" 1384 | }, 1385 | "peerDependenciesMeta": { 1386 | "supports-color": { 1387 | "optional": true 1388 | } 1389 | } 1390 | }, 1391 | "node_modules/retry-request/node_modules/ms": { 1392 | "version": "2.1.2", 1393 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1394 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1395 | }, 1396 | "node_modules/safe-buffer": { 1397 | "version": "5.2.1", 1398 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1399 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1400 | "funding": [ 1401 | { 1402 | "type": "github", 1403 | "url": "https://github.com/sponsors/feross" 1404 | }, 1405 | { 1406 | "type": "patreon", 1407 | "url": "https://www.patreon.com/feross" 1408 | }, 1409 | { 1410 | "type": "consulting", 1411 | "url": "https://feross.org/support" 1412 | } 1413 | ] 1414 | }, 1415 | "node_modules/safer-buffer": { 1416 | "version": "2.1.2", 1417 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1418 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1419 | }, 1420 | "node_modules/semver": { 1421 | "version": "6.3.0", 1422 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1423 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1424 | "bin": { 1425 | "semver": "bin/semver.js" 1426 | } 1427 | }, 1428 | "node_modules/send": { 1429 | "version": "0.18.0", 1430 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 1431 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 1432 | "dependencies": { 1433 | "debug": "2.6.9", 1434 | "depd": "2.0.0", 1435 | "destroy": "1.2.0", 1436 | "encodeurl": "~1.0.2", 1437 | "escape-html": "~1.0.3", 1438 | "etag": "~1.8.1", 1439 | "fresh": "0.5.2", 1440 | "http-errors": "2.0.0", 1441 | "mime": "1.6.0", 1442 | "ms": "2.1.3", 1443 | "on-finished": "2.4.1", 1444 | "range-parser": "~1.2.1", 1445 | "statuses": "2.0.1" 1446 | }, 1447 | "engines": { 1448 | "node": ">= 0.8.0" 1449 | } 1450 | }, 1451 | "node_modules/send/node_modules/ms": { 1452 | "version": "2.1.3", 1453 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1454 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1455 | }, 1456 | "node_modules/serve-static": { 1457 | "version": "1.15.0", 1458 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 1459 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 1460 | "dependencies": { 1461 | "encodeurl": "~1.0.2", 1462 | "escape-html": "~1.0.3", 1463 | "parseurl": "~1.3.3", 1464 | "send": "0.18.0" 1465 | }, 1466 | "engines": { 1467 | "node": ">= 0.8.0" 1468 | } 1469 | }, 1470 | "node_modules/setprototypeof": { 1471 | "version": "1.2.0", 1472 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1473 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1474 | }, 1475 | "node_modules/side-channel": { 1476 | "version": "1.0.4", 1477 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1478 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1479 | "dependencies": { 1480 | "call-bind": "^1.0.0", 1481 | "get-intrinsic": "^1.0.2", 1482 | "object-inspect": "^1.9.0" 1483 | }, 1484 | "funding": { 1485 | "url": "https://github.com/sponsors/ljharb" 1486 | } 1487 | }, 1488 | "node_modules/socket.io": { 1489 | "version": "3.1.1", 1490 | "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-3.1.1.tgz", 1491 | "integrity": "sha512-7cBWdsDC7bbyEF6WbBqffjizc/H4YF1wLdZoOzuYfo2uMNSFjJKuQ36t0H40o9B20DO6p+mSytEd92oP4S15bA==", 1492 | "dependencies": { 1493 | "@types/cookie": "^0.4.0", 1494 | "@types/cors": "^2.8.8", 1495 | "@types/node": "^14.14.10", 1496 | "accepts": "~1.3.4", 1497 | "base64id": "~2.0.0", 1498 | "debug": "~4.3.1", 1499 | "engine.io": "~4.1.0", 1500 | "socket.io-adapter": "~2.1.0", 1501 | "socket.io-parser": "~4.0.3" 1502 | }, 1503 | "engines": { 1504 | "node": ">=10.0.0" 1505 | } 1506 | }, 1507 | "node_modules/socket.io-adapter": { 1508 | "version": "2.1.0", 1509 | "resolved": "https://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-2.1.0.tgz", 1510 | "integrity": "sha512-+vDov/aTsLjViYTwS9fPy5pEtTkrbEKsw2M+oVSoFGw6OD1IpvlV1VPhUzNbofCQ8oyMbdYJqDtGdmHQK6TdPg==" 1511 | }, 1512 | "node_modules/socket.io-parser": { 1513 | "version": "4.0.5", 1514 | "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-4.0.5.tgz", 1515 | "integrity": "sha512-sNjbT9dX63nqUFIOv95tTVm6elyIU4RvB1m8dOeZt+IgWwcWklFDOdmGcfo3zSiRsnR/3pJkjY5lfoGqEe4Eig==", 1516 | "dependencies": { 1517 | "@types/component-emitter": "^1.2.10", 1518 | "component-emitter": "~1.3.0", 1519 | "debug": "~4.3.1" 1520 | }, 1521 | "engines": { 1522 | "node": ">=10.0.0" 1523 | } 1524 | }, 1525 | "node_modules/socket.io-parser/node_modules/debug": { 1526 | "version": "4.3.1", 1527 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 1528 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 1529 | "dependencies": { 1530 | "ms": "2.1.2" 1531 | }, 1532 | "engines": { 1533 | "node": ">=6.0" 1534 | }, 1535 | "peerDependenciesMeta": { 1536 | "supports-color": { 1537 | "optional": true 1538 | } 1539 | } 1540 | }, 1541 | "node_modules/socket.io-parser/node_modules/ms": { 1542 | "version": "2.1.2", 1543 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1544 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1545 | }, 1546 | "node_modules/socket.io/node_modules/debug": { 1547 | "version": "4.3.1", 1548 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 1549 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 1550 | "dependencies": { 1551 | "ms": "2.1.2" 1552 | }, 1553 | "engines": { 1554 | "node": ">=6.0" 1555 | }, 1556 | "peerDependenciesMeta": { 1557 | "supports-color": { 1558 | "optional": true 1559 | } 1560 | } 1561 | }, 1562 | "node_modules/socket.io/node_modules/ms": { 1563 | "version": "2.1.2", 1564 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1565 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1566 | }, 1567 | "node_modules/statuses": { 1568 | "version": "2.0.1", 1569 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 1570 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 1571 | "engines": { 1572 | "node": ">= 0.8" 1573 | } 1574 | }, 1575 | "node_modules/stream-events": { 1576 | "version": "1.0.5", 1577 | "resolved": "https://registry.npmjs.org/stream-events/-/stream-events-1.0.5.tgz", 1578 | "integrity": "sha512-E1GUzBSgvct8Jsb3v2X15pjzN1tYebtbLaMg+eBOUOAxgbLoSbT2NS91ckc5lJD1KfLjId+jXJRgo0qnV5Nerg==", 1579 | "dependencies": { 1580 | "stubs": "^3.0.0" 1581 | } 1582 | }, 1583 | "node_modules/stream-shift": { 1584 | "version": "1.0.1", 1585 | "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.1.tgz", 1586 | "integrity": "sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ==" 1587 | }, 1588 | "node_modules/string_decoder": { 1589 | "version": "1.3.0", 1590 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 1591 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 1592 | "dependencies": { 1593 | "safe-buffer": "~5.2.0" 1594 | } 1595 | }, 1596 | "node_modules/stubs": { 1597 | "version": "3.0.0", 1598 | "resolved": "https://registry.npmjs.org/stubs/-/stubs-3.0.0.tgz", 1599 | "integrity": "sha1-6NK6H6nJBXAwPAMLaQD31fiavls=" 1600 | }, 1601 | "node_modules/supports-color": { 1602 | "version": "5.5.0", 1603 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1604 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1605 | "dependencies": { 1606 | "has-flag": "^3.0.0" 1607 | }, 1608 | "engines": { 1609 | "node": ">=4" 1610 | } 1611 | }, 1612 | "node_modules/teeny-request": { 1613 | "version": "7.0.1", 1614 | "resolved": "https://registry.npmjs.org/teeny-request/-/teeny-request-7.0.1.tgz", 1615 | "integrity": "sha512-sasJmQ37klOlplL4Ia/786M5YlOcoLGQyq2TE4WHSRupbAuDaQW0PfVxV4MtdBtRJ4ngzS+1qim8zP6Zp35qCw==", 1616 | "dependencies": { 1617 | "http-proxy-agent": "^4.0.0", 1618 | "https-proxy-agent": "^5.0.0", 1619 | "node-fetch": "^2.6.1", 1620 | "stream-events": "^1.0.5", 1621 | "uuid": "^8.0.0" 1622 | }, 1623 | "engines": { 1624 | "node": ">=10" 1625 | } 1626 | }, 1627 | "node_modules/toidentifier": { 1628 | "version": "1.0.1", 1629 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1630 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1631 | "engines": { 1632 | "node": ">=0.6" 1633 | } 1634 | }, 1635 | "node_modules/tr46": { 1636 | "version": "0.0.3", 1637 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 1638 | "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" 1639 | }, 1640 | "node_modules/type-is": { 1641 | "version": "1.6.18", 1642 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1643 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1644 | "dependencies": { 1645 | "media-typer": "0.3.0", 1646 | "mime-types": "~2.1.24" 1647 | }, 1648 | "engines": { 1649 | "node": ">= 0.6" 1650 | } 1651 | }, 1652 | "node_modules/unpipe": { 1653 | "version": "1.0.0", 1654 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1655 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 1656 | "engines": { 1657 | "node": ">= 0.8" 1658 | } 1659 | }, 1660 | "node_modules/util": { 1661 | "version": "0.10.4", 1662 | "resolved": "https://registry.npmjs.org/util/-/util-0.10.4.tgz", 1663 | "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==", 1664 | "dependencies": { 1665 | "inherits": "2.0.3" 1666 | } 1667 | }, 1668 | "node_modules/util-deprecate": { 1669 | "version": "1.0.2", 1670 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1671 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1672 | }, 1673 | "node_modules/util/node_modules/inherits": { 1674 | "version": "2.0.3", 1675 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1676 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1677 | }, 1678 | "node_modules/utils-merge": { 1679 | "version": "1.0.1", 1680 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1681 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 1682 | "engines": { 1683 | "node": ">= 0.4.0" 1684 | } 1685 | }, 1686 | "node_modules/uuid": { 1687 | "version": "8.3.2", 1688 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 1689 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", 1690 | "bin": { 1691 | "uuid": "dist/bin/uuid" 1692 | } 1693 | }, 1694 | "node_modules/vary": { 1695 | "version": "1.1.2", 1696 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1697 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", 1698 | "engines": { 1699 | "node": ">= 0.8" 1700 | } 1701 | }, 1702 | "node_modules/webidl-conversions": { 1703 | "version": "3.0.1", 1704 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 1705 | "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" 1706 | }, 1707 | "node_modules/whatwg-url": { 1708 | "version": "5.0.0", 1709 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 1710 | "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", 1711 | "dependencies": { 1712 | "tr46": "~0.0.3", 1713 | "webidl-conversions": "^3.0.0" 1714 | } 1715 | }, 1716 | "node_modules/wrappy": { 1717 | "version": "1.0.2", 1718 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1719 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1720 | }, 1721 | "node_modules/ws": { 1722 | "version": "7.4.3", 1723 | "resolved": "https://registry.npmjs.org/ws/-/ws-7.4.3.tgz", 1724 | "integrity": "sha512-hr6vCR76GsossIRsr8OLR9acVVm1jyfEWvhbNjtgPOrfvAlKzvyeg/P6r8RuDjRyrcQoPQT7K0DGEPc7Ae6jzA==", 1725 | "engines": { 1726 | "node": ">=8.3.0" 1727 | }, 1728 | "peerDependencies": { 1729 | "bufferutil": "^4.0.1", 1730 | "utf-8-validate": "^5.0.2" 1731 | }, 1732 | "peerDependenciesMeta": { 1733 | "bufferutil": { 1734 | "optional": true 1735 | }, 1736 | "utf-8-validate": { 1737 | "optional": true 1738 | } 1739 | } 1740 | }, 1741 | "node_modules/yallist": { 1742 | "version": "4.0.0", 1743 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1744 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1745 | } 1746 | }, 1747 | "dependencies": { 1748 | "@google-cloud/common": { 1749 | "version": "3.6.0", 1750 | "resolved": "https://registry.npmjs.org/@google-cloud/common/-/common-3.6.0.tgz", 1751 | "integrity": "sha512-aHIFTqJZmeTNO9md8XxV+ywuvXF3xBm5WNmgWeeCK+XN5X+kGW0WEX94wGwj+/MdOnrVf4dL2RvSIt9J5yJG6Q==", 1752 | "requires": { 1753 | "@google-cloud/projectify": "^2.0.0", 1754 | "@google-cloud/promisify": "^2.0.0", 1755 | "arrify": "^2.0.1", 1756 | "duplexify": "^4.1.1", 1757 | "ent": "^2.2.0", 1758 | "extend": "^3.0.2", 1759 | "google-auth-library": "^7.0.2", 1760 | "retry-request": "^4.1.1", 1761 | "teeny-request": "^7.0.0" 1762 | } 1763 | }, 1764 | "@google-cloud/projectify": { 1765 | "version": "2.0.1", 1766 | "resolved": "https://registry.npmjs.org/@google-cloud/projectify/-/projectify-2.0.1.tgz", 1767 | "integrity": "sha512-ZDG38U/Yy6Zr21LaR3BTiiLtpJl6RkPS/JwoRT453G+6Q1DhlV0waNf8Lfu+YVYGIIxgKnLayJRfYlFJfiI8iQ==" 1768 | }, 1769 | "@google-cloud/promisify": { 1770 | "version": "2.0.3", 1771 | "resolved": "https://registry.npmjs.org/@google-cloud/promisify/-/promisify-2.0.3.tgz", 1772 | "integrity": "sha512-d4VSA86eL/AFTe5xtyZX+ePUjE8dIFu2T8zmdeNBSa5/kNgXPCx/o/wbFNHAGLJdGnk1vddRuMESD9HbOC8irw==" 1773 | }, 1774 | "@google-cloud/speech": { 1775 | "version": "4.2.0", 1776 | "resolved": "https://registry.npmjs.org/@google-cloud/speech/-/speech-4.2.0.tgz", 1777 | "integrity": "sha512-5QlL2Gg0CGLT5kS6gWiZuRy0layCnXeS5+CkHPJsqvTmmY5Ssf+XIDoocp9uBkrVwwPjKm74mFlSTTL5HnlBwQ==", 1778 | "requires": { 1779 | "@google-cloud/common": "^3.0.0", 1780 | "@types/pumpify": "^1.4.1", 1781 | "google-gax": "^2.9.2", 1782 | "protobufjs": "^6.8.6", 1783 | "pumpify": "^2.0.0", 1784 | "stream-events": "^1.0.4" 1785 | } 1786 | }, 1787 | "@grpc/grpc-js": { 1788 | "version": "1.2.7", 1789 | "resolved": "https://registry.npmjs.org/@grpc/grpc-js/-/grpc-js-1.2.7.tgz", 1790 | "integrity": "sha512-hBkR/vZTodu/dA/kcKpiQtPQdjMbpfKv7RKfEByT5/7qOQNpIh2O6Sr1aldLMzstFqmGrufmR7XTc56VCMH7LA==", 1791 | "requires": { 1792 | "@types/node": ">=12.12.47", 1793 | "google-auth-library": "^6.1.1", 1794 | "semver": "^6.2.0" 1795 | }, 1796 | "dependencies": { 1797 | "google-auth-library": { 1798 | "version": "6.1.6", 1799 | "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-6.1.6.tgz", 1800 | "integrity": "sha512-Q+ZjUEvLQj/lrVHF/IQwRo6p3s8Nc44Zk/DALsN+ac3T4HY/g/3rrufkgtl+nZ1TW7DNAw5cTChdVp4apUXVgQ==", 1801 | "requires": { 1802 | "arrify": "^2.0.0", 1803 | "base64-js": "^1.3.0", 1804 | "ecdsa-sig-formatter": "^1.0.11", 1805 | "fast-text-encoding": "^1.0.0", 1806 | "gaxios": "^4.0.0", 1807 | "gcp-metadata": "^4.2.0", 1808 | "gtoken": "^5.0.4", 1809 | "jws": "^4.0.0", 1810 | "lru-cache": "^6.0.0" 1811 | } 1812 | } 1813 | } 1814 | }, 1815 | "@grpc/proto-loader": { 1816 | "version": "0.5.6", 1817 | "resolved": "https://registry.npmjs.org/@grpc/proto-loader/-/proto-loader-0.5.6.tgz", 1818 | "integrity": "sha512-DT14xgw3PSzPxwS13auTEwxhMMOoz33DPUKNtmYK/QYbBSpLXJy78FGGs5yVoxVobEqPm4iW9MOIoz0A3bLTRQ==", 1819 | "requires": { 1820 | "lodash.camelcase": "^4.3.0", 1821 | "protobufjs": "^6.8.6" 1822 | } 1823 | }, 1824 | "@protobufjs/aspromise": { 1825 | "version": "1.1.2", 1826 | "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", 1827 | "integrity": "sha1-m4sMxmPWaafY9vXQiToU00jzD78=" 1828 | }, 1829 | "@protobufjs/base64": { 1830 | "version": "1.1.2", 1831 | "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", 1832 | "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==" 1833 | }, 1834 | "@protobufjs/codegen": { 1835 | "version": "2.0.4", 1836 | "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", 1837 | "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==" 1838 | }, 1839 | "@protobufjs/eventemitter": { 1840 | "version": "1.1.0", 1841 | "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", 1842 | "integrity": "sha1-NVy8mLr61ZePntCV85diHx0Ga3A=" 1843 | }, 1844 | "@protobufjs/fetch": { 1845 | "version": "1.1.0", 1846 | "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", 1847 | "integrity": "sha1-upn7WYYUr2VwDBYZ/wbUVLDYTEU=", 1848 | "requires": { 1849 | "@protobufjs/aspromise": "^1.1.1", 1850 | "@protobufjs/inquire": "^1.1.0" 1851 | } 1852 | }, 1853 | "@protobufjs/float": { 1854 | "version": "1.0.2", 1855 | "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", 1856 | "integrity": "sha1-Xp4avctz/Ap8uLKR33jIy9l7h9E=" 1857 | }, 1858 | "@protobufjs/inquire": { 1859 | "version": "1.1.0", 1860 | "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", 1861 | "integrity": "sha1-/yAOPnzyQp4tyvwRQIKOjMY48Ik=" 1862 | }, 1863 | "@protobufjs/path": { 1864 | "version": "1.1.2", 1865 | "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", 1866 | "integrity": "sha1-bMKyDFya1q0NzP0hynZz2Nf79o0=" 1867 | }, 1868 | "@protobufjs/pool": { 1869 | "version": "1.1.0", 1870 | "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", 1871 | "integrity": "sha1-Cf0V8tbTq/qbZbw2ZQbWrXhG/1Q=" 1872 | }, 1873 | "@protobufjs/utf8": { 1874 | "version": "1.1.0", 1875 | "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", 1876 | "integrity": "sha1-p3c2C1s5oaLlEG+OhY8v0tBgxXA=" 1877 | }, 1878 | "@tootallnate/once": { 1879 | "version": "1.1.2", 1880 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 1881 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==" 1882 | }, 1883 | "@types/component-emitter": { 1884 | "version": "1.2.10", 1885 | "resolved": "https://registry.npmjs.org/@types/component-emitter/-/component-emitter-1.2.10.tgz", 1886 | "integrity": "sha512-bsjleuRKWmGqajMerkzox19aGbscQX5rmmvvXl3wlIp5gMG1HgkiwPxsN5p070fBDKTNSPgojVbuY1+HWMbFhg==" 1887 | }, 1888 | "@types/cookie": { 1889 | "version": "0.4.0", 1890 | "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.4.0.tgz", 1891 | "integrity": "sha512-y7mImlc/rNkvCRmg8gC3/lj87S7pTUIJ6QGjwHR9WQJcFs+ZMTOaoPrkdFA/YdbuqVEmEbb5RdhVxMkAcgOnpg==" 1892 | }, 1893 | "@types/cors": { 1894 | "version": "2.8.10", 1895 | "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.10.tgz", 1896 | "integrity": "sha512-C7srjHiVG3Ey1nR6d511dtDkCEjxuN9W1HWAEjGq8kpcwmNM6JJkpC0xvabM7BXTG2wDq8Eu33iH9aQKa7IvLQ==" 1897 | }, 1898 | "@types/duplexify": { 1899 | "version": "3.6.0", 1900 | "resolved": "https://registry.npmjs.org/@types/duplexify/-/duplexify-3.6.0.tgz", 1901 | "integrity": "sha512-5zOA53RUlzN74bvrSGwjudssD9F3a797sDZQkiYpUOxW+WHaXTCPz4/d5Dgi6FKnOqZ2CpaTo0DhgIfsXAOE/A==", 1902 | "requires": { 1903 | "@types/node": "*" 1904 | } 1905 | }, 1906 | "@types/long": { 1907 | "version": "4.0.1", 1908 | "resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.1.tgz", 1909 | "integrity": "sha512-5tXH6Bx/kNGd3MgffdmP4dy2Z+G4eaXw0SE81Tq3BNadtnMR5/ySMzX4SLEzHJzSmPNn4HIdpQsBvXMUykr58w==" 1910 | }, 1911 | "@types/node": { 1912 | "version": "14.14.28", 1913 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.14.28.tgz", 1914 | "integrity": "sha512-lg55ArB+ZiHHbBBttLpzD07akz0QPrZgUODNakeC09i62dnrywr9mFErHuaPlB6I7z+sEbK+IYmplahvplCj2g==" 1915 | }, 1916 | "@types/pumpify": { 1917 | "version": "1.4.1", 1918 | "resolved": "https://registry.npmjs.org/@types/pumpify/-/pumpify-1.4.1.tgz", 1919 | "integrity": "sha512-l7u/Dnh1OG9T7VH6TvulR0g8oE8hgIW5409mSUKi8Vxw2+JV18aTa06Sv5bvNjrD0zbsB/cuZ/iTFQgFNfzIuw==", 1920 | "requires": { 1921 | "@types/duplexify": "*", 1922 | "@types/node": "*" 1923 | } 1924 | }, 1925 | "abort-controller": { 1926 | "version": "3.0.0", 1927 | "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", 1928 | "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", 1929 | "requires": { 1930 | "event-target-shim": "^5.0.0" 1931 | } 1932 | }, 1933 | "accepts": { 1934 | "version": "1.3.8", 1935 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 1936 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 1937 | "requires": { 1938 | "mime-types": "~2.1.34", 1939 | "negotiator": "0.6.3" 1940 | } 1941 | }, 1942 | "agent-base": { 1943 | "version": "6.0.2", 1944 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 1945 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 1946 | "requires": { 1947 | "debug": "4" 1948 | }, 1949 | "dependencies": { 1950 | "debug": { 1951 | "version": "4.3.1", 1952 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 1953 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 1954 | "requires": { 1955 | "ms": "2.1.2" 1956 | } 1957 | }, 1958 | "ms": { 1959 | "version": "2.1.2", 1960 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1961 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1962 | } 1963 | } 1964 | }, 1965 | "ansi-styles": { 1966 | "version": "3.2.1", 1967 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1968 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1969 | "requires": { 1970 | "color-convert": "^1.9.0" 1971 | } 1972 | }, 1973 | "array-flatten": { 1974 | "version": "1.1.1", 1975 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 1976 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 1977 | }, 1978 | "arrify": { 1979 | "version": "2.0.1", 1980 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-2.0.1.tgz", 1981 | "integrity": "sha512-3duEwti880xqi4eAMN8AyR4a0ByT90zoYdLlevfrvU43vb0YZwZVfxOgxWrLXXXpyugL0hNZc9G6BiB5B3nUug==" 1982 | }, 1983 | "async": { 1984 | "version": "0.9.2", 1985 | "resolved": "https://registry.npmjs.org/async/-/async-0.9.2.tgz", 1986 | "integrity": "sha1-rqdNXmHB+JlhO/ZL2mbUx48v0X0=" 1987 | }, 1988 | "balanced-match": { 1989 | "version": "1.0.0", 1990 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 1991 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 1992 | }, 1993 | "base64-arraybuffer": { 1994 | "version": "0.1.4", 1995 | "resolved": "https://registry.npmjs.org/base64-arraybuffer/-/base64-arraybuffer-0.1.4.tgz", 1996 | "integrity": "sha1-mBjHngWbE1X5fgQooBfIOOkLqBI=" 1997 | }, 1998 | "base64-js": { 1999 | "version": "1.5.1", 2000 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 2001 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==" 2002 | }, 2003 | "base64id": { 2004 | "version": "2.0.0", 2005 | "resolved": "https://registry.npmjs.org/base64id/-/base64id-2.0.0.tgz", 2006 | "integrity": "sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog==" 2007 | }, 2008 | "bignumber.js": { 2009 | "version": "9.0.1", 2010 | "resolved": "https://registry.npmjs.org/bignumber.js/-/bignumber.js-9.0.1.tgz", 2011 | "integrity": "sha512-IdZR9mh6ahOBv/hYGiXyVuyCetmGJhtYkqLBpTStdhEGjegpPlUawydyaF3pbIOFynJTpllEs+NP+CS9jKFLjA==" 2012 | }, 2013 | "body-parser": { 2014 | "version": "1.20.1", 2015 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", 2016 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", 2017 | "requires": { 2018 | "bytes": "3.1.2", 2019 | "content-type": "~1.0.4", 2020 | "debug": "2.6.9", 2021 | "depd": "2.0.0", 2022 | "destroy": "1.2.0", 2023 | "http-errors": "2.0.0", 2024 | "iconv-lite": "0.4.24", 2025 | "on-finished": "2.4.1", 2026 | "qs": "6.11.0", 2027 | "raw-body": "2.5.1", 2028 | "type-is": "~1.6.18", 2029 | "unpipe": "1.0.0" 2030 | } 2031 | }, 2032 | "brace-expansion": { 2033 | "version": "1.1.11", 2034 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2035 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2036 | "requires": { 2037 | "balanced-match": "^1.0.0", 2038 | "concat-map": "0.0.1" 2039 | } 2040 | }, 2041 | "buffer-equal-constant-time": { 2042 | "version": "1.0.1", 2043 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 2044 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 2045 | }, 2046 | "bytes": { 2047 | "version": "3.1.2", 2048 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 2049 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==" 2050 | }, 2051 | "call-bind": { 2052 | "version": "1.0.2", 2053 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 2054 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 2055 | "requires": { 2056 | "function-bind": "^1.1.1", 2057 | "get-intrinsic": "^1.0.2" 2058 | } 2059 | }, 2060 | "chalk": { 2061 | "version": "2.4.2", 2062 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 2063 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 2064 | "requires": { 2065 | "ansi-styles": "^3.2.1", 2066 | "escape-string-regexp": "^1.0.5", 2067 | "supports-color": "^5.3.0" 2068 | } 2069 | }, 2070 | "color-convert": { 2071 | "version": "1.9.3", 2072 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2073 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2074 | "requires": { 2075 | "color-name": "1.1.3" 2076 | } 2077 | }, 2078 | "color-name": { 2079 | "version": "1.1.3", 2080 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2081 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 2082 | }, 2083 | "component-emitter": { 2084 | "version": "1.3.0", 2085 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", 2086 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==" 2087 | }, 2088 | "concat-map": { 2089 | "version": "0.0.1", 2090 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2091 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 2092 | }, 2093 | "content-disposition": { 2094 | "version": "0.5.4", 2095 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 2096 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 2097 | "requires": { 2098 | "safe-buffer": "5.2.1" 2099 | } 2100 | }, 2101 | "content-type": { 2102 | "version": "1.0.4", 2103 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 2104 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 2105 | }, 2106 | "cookie": { 2107 | "version": "0.5.0", 2108 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 2109 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==" 2110 | }, 2111 | "cookie-signature": { 2112 | "version": "1.0.6", 2113 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 2114 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 2115 | }, 2116 | "cors": { 2117 | "version": "2.8.5", 2118 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 2119 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 2120 | "requires": { 2121 | "object-assign": "^4", 2122 | "vary": "^1" 2123 | } 2124 | }, 2125 | "debug": { 2126 | "version": "2.6.9", 2127 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2128 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2129 | "requires": { 2130 | "ms": "2.0.0" 2131 | } 2132 | }, 2133 | "depd": { 2134 | "version": "2.0.0", 2135 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 2136 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==" 2137 | }, 2138 | "destroy": { 2139 | "version": "1.2.0", 2140 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 2141 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==" 2142 | }, 2143 | "dotenv": { 2144 | "version": "8.2.0", 2145 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz", 2146 | "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==" 2147 | }, 2148 | "duplexify": { 2149 | "version": "4.1.1", 2150 | "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-4.1.1.tgz", 2151 | "integrity": "sha512-DY3xVEmVHTv1wSzKNbwoU6nVjzI369Y6sPoqfYr0/xlx3IdX2n94xIszTcjPO8W8ZIv0Wb0PXNcjuZyT4wiICA==", 2152 | "requires": { 2153 | "end-of-stream": "^1.4.1", 2154 | "inherits": "^2.0.3", 2155 | "readable-stream": "^3.1.1", 2156 | "stream-shift": "^1.0.0" 2157 | } 2158 | }, 2159 | "ecdsa-sig-formatter": { 2160 | "version": "1.0.11", 2161 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 2162 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 2163 | "requires": { 2164 | "safe-buffer": "^5.0.1" 2165 | } 2166 | }, 2167 | "ee-first": { 2168 | "version": "1.1.1", 2169 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 2170 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 2171 | }, 2172 | "ejs": { 2173 | "version": "3.1.6", 2174 | "resolved": "https://registry.npmjs.org/ejs/-/ejs-3.1.6.tgz", 2175 | "integrity": "sha512-9lt9Zse4hPucPkoP7FHDF0LQAlGyF9JVpnClFLFH3aSSbxmyoqINRpp/9wePWJTUl4KOQwRL72Iw3InHPDkoGw==", 2176 | "requires": { 2177 | "jake": "^10.6.1" 2178 | } 2179 | }, 2180 | "encodeurl": { 2181 | "version": "1.0.2", 2182 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 2183 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==" 2184 | }, 2185 | "end-of-stream": { 2186 | "version": "1.4.4", 2187 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 2188 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 2189 | "requires": { 2190 | "once": "^1.4.0" 2191 | } 2192 | }, 2193 | "engine.io": { 2194 | "version": "4.1.1", 2195 | "resolved": "https://registry.npmjs.org/engine.io/-/engine.io-4.1.1.tgz", 2196 | "integrity": "sha512-t2E9wLlssQjGw0nluF6aYyfX8LwYU8Jj0xct+pAhfWfv/YrBn6TSNtEYsgxHIfaMqfrLx07czcMg9bMN6di+3w==", 2197 | "requires": { 2198 | "accepts": "~1.3.4", 2199 | "base64id": "2.0.0", 2200 | "cookie": "~0.4.1", 2201 | "cors": "~2.8.5", 2202 | "debug": "~4.3.1", 2203 | "engine.io-parser": "~4.0.0", 2204 | "ws": "~7.4.2" 2205 | }, 2206 | "dependencies": { 2207 | "cookie": { 2208 | "version": "0.4.1", 2209 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz", 2210 | "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA==" 2211 | }, 2212 | "debug": { 2213 | "version": "4.3.1", 2214 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 2215 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 2216 | "requires": { 2217 | "ms": "2.1.2" 2218 | } 2219 | }, 2220 | "ms": { 2221 | "version": "2.1.2", 2222 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2223 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2224 | } 2225 | } 2226 | }, 2227 | "engine.io-parser": { 2228 | "version": "4.0.2", 2229 | "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-4.0.2.tgz", 2230 | "integrity": "sha512-sHfEQv6nmtJrq6TKuIz5kyEKH/qSdK56H/A+7DnAuUPWosnIZAS2NHNcPLmyjtY3cGS/MqJdZbUjW97JU72iYg==", 2231 | "requires": { 2232 | "base64-arraybuffer": "0.1.4" 2233 | } 2234 | }, 2235 | "ent": { 2236 | "version": "2.2.0", 2237 | "resolved": "https://registry.npmjs.org/ent/-/ent-2.2.0.tgz", 2238 | "integrity": "sha1-6WQhkyWiHQX0RGai9obtbOX13R0=" 2239 | }, 2240 | "escape-html": { 2241 | "version": "1.0.3", 2242 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 2243 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 2244 | }, 2245 | "escape-string-regexp": { 2246 | "version": "1.0.5", 2247 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 2248 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" 2249 | }, 2250 | "etag": { 2251 | "version": "1.8.1", 2252 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 2253 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==" 2254 | }, 2255 | "event-target-shim": { 2256 | "version": "5.0.1", 2257 | "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz", 2258 | "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==" 2259 | }, 2260 | "express": { 2261 | "version": "4.18.2", 2262 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", 2263 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", 2264 | "requires": { 2265 | "accepts": "~1.3.8", 2266 | "array-flatten": "1.1.1", 2267 | "body-parser": "1.20.1", 2268 | "content-disposition": "0.5.4", 2269 | "content-type": "~1.0.4", 2270 | "cookie": "0.5.0", 2271 | "cookie-signature": "1.0.6", 2272 | "debug": "2.6.9", 2273 | "depd": "2.0.0", 2274 | "encodeurl": "~1.0.2", 2275 | "escape-html": "~1.0.3", 2276 | "etag": "~1.8.1", 2277 | "finalhandler": "1.2.0", 2278 | "fresh": "0.5.2", 2279 | "http-errors": "2.0.0", 2280 | "merge-descriptors": "1.0.1", 2281 | "methods": "~1.1.2", 2282 | "on-finished": "2.4.1", 2283 | "parseurl": "~1.3.3", 2284 | "path-to-regexp": "0.1.7", 2285 | "proxy-addr": "~2.0.7", 2286 | "qs": "6.11.0", 2287 | "range-parser": "~1.2.1", 2288 | "safe-buffer": "5.2.1", 2289 | "send": "0.18.0", 2290 | "serve-static": "1.15.0", 2291 | "setprototypeof": "1.2.0", 2292 | "statuses": "2.0.1", 2293 | "type-is": "~1.6.18", 2294 | "utils-merge": "1.0.1", 2295 | "vary": "~1.1.2" 2296 | } 2297 | }, 2298 | "extend": { 2299 | "version": "3.0.2", 2300 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 2301 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 2302 | }, 2303 | "fast-text-encoding": { 2304 | "version": "1.0.3", 2305 | "resolved": "https://registry.npmjs.org/fast-text-encoding/-/fast-text-encoding-1.0.3.tgz", 2306 | "integrity": "sha512-dtm4QZH9nZtcDt8qJiOH9fcQd1NAgi+K1O2DbE6GG1PPCK/BWfOH3idCTRQ4ImXRUOyopDEgDEnVEE7Y/2Wrig==" 2307 | }, 2308 | "filelist": { 2309 | "version": "1.0.2", 2310 | "resolved": "https://registry.npmjs.org/filelist/-/filelist-1.0.2.tgz", 2311 | "integrity": "sha512-z7O0IS8Plc39rTCq6i6iHxk43duYOn8uFJiWSewIq0Bww1RNybVHSCjahmcC87ZqAm4OTvFzlzeGu3XAzG1ctQ==", 2312 | "requires": { 2313 | "minimatch": "^3.0.4" 2314 | } 2315 | }, 2316 | "finalhandler": { 2317 | "version": "1.2.0", 2318 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 2319 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 2320 | "requires": { 2321 | "debug": "2.6.9", 2322 | "encodeurl": "~1.0.2", 2323 | "escape-html": "~1.0.3", 2324 | "on-finished": "2.4.1", 2325 | "parseurl": "~1.3.3", 2326 | "statuses": "2.0.1", 2327 | "unpipe": "~1.0.0" 2328 | } 2329 | }, 2330 | "forwarded": { 2331 | "version": "0.2.0", 2332 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 2333 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 2334 | }, 2335 | "fresh": { 2336 | "version": "0.5.2", 2337 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 2338 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==" 2339 | }, 2340 | "function-bind": { 2341 | "version": "1.1.1", 2342 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2343 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 2344 | }, 2345 | "gaxios": { 2346 | "version": "4.1.0", 2347 | "resolved": "https://registry.npmjs.org/gaxios/-/gaxios-4.1.0.tgz", 2348 | "integrity": "sha512-vb0to8xzGnA2qcgywAjtshOKKVDf2eQhJoiL6fHhgW5tVN7wNk7egnYIO9zotfn3lQ3De1VPdf7V5/BWfCtCmg==", 2349 | "requires": { 2350 | "abort-controller": "^3.0.0", 2351 | "extend": "^3.0.2", 2352 | "https-proxy-agent": "^5.0.0", 2353 | "is-stream": "^2.0.0", 2354 | "node-fetch": "^2.3.0" 2355 | } 2356 | }, 2357 | "gcp-metadata": { 2358 | "version": "4.2.1", 2359 | "resolved": "https://registry.npmjs.org/gcp-metadata/-/gcp-metadata-4.2.1.tgz", 2360 | "integrity": "sha512-tSk+REe5iq/N+K+SK1XjZJUrFPuDqGZVzCy2vocIHIGmPlTGsa8owXMJwGkrXr73NO0AzhPW4MF2DEHz7P2AVw==", 2361 | "requires": { 2362 | "gaxios": "^4.0.0", 2363 | "json-bigint": "^1.0.0" 2364 | } 2365 | }, 2366 | "get-intrinsic": { 2367 | "version": "1.1.3", 2368 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.3.tgz", 2369 | "integrity": "sha512-QJVz1Tj7MS099PevUG5jvnt9tSkXN8K14dxQlikJuPt4uD9hHAHjLyLBiLR5zELelBdD9QNRAXZzsJx0WaDL9A==", 2370 | "requires": { 2371 | "function-bind": "^1.1.1", 2372 | "has": "^1.0.3", 2373 | "has-symbols": "^1.0.3" 2374 | } 2375 | }, 2376 | "google-auth-library": { 2377 | "version": "7.0.2", 2378 | "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-7.0.2.tgz", 2379 | "integrity": "sha512-vjyNZR3pDLC0u7GHLfj+Hw9tGprrJwoMwkYGqURCXYITjCrP9HprOyxVV+KekdLgATtWGuDkQG2MTh0qpUPUgg==", 2380 | "requires": { 2381 | "arrify": "^2.0.0", 2382 | "base64-js": "^1.3.0", 2383 | "ecdsa-sig-formatter": "^1.0.11", 2384 | "fast-text-encoding": "^1.0.0", 2385 | "gaxios": "^4.0.0", 2386 | "gcp-metadata": "^4.2.0", 2387 | "gtoken": "^5.0.4", 2388 | "jws": "^4.0.0", 2389 | "lru-cache": "^6.0.0" 2390 | } 2391 | }, 2392 | "google-gax": { 2393 | "version": "2.10.3", 2394 | "resolved": "https://registry.npmjs.org/google-gax/-/google-gax-2.10.3.tgz", 2395 | "integrity": "sha512-jESs/ME9WgMzfGQKJDu9ea2mEKjznKByRL+5xb8mKfHlbUfS/LxNLNCg/35RgXwVXcNSCqkEY90z8wHxvgdd/Q==", 2396 | "requires": { 2397 | "@grpc/grpc-js": "~1.2.0", 2398 | "@grpc/proto-loader": "^0.5.1", 2399 | "@types/long": "^4.0.0", 2400 | "abort-controller": "^3.0.0", 2401 | "duplexify": "^4.0.0", 2402 | "fast-text-encoding": "^1.0.3", 2403 | "google-auth-library": "^7.0.2", 2404 | "is-stream-ended": "^0.1.4", 2405 | "node-fetch": "^2.6.1", 2406 | "protobufjs": "^6.10.2", 2407 | "retry-request": "^4.0.0" 2408 | } 2409 | }, 2410 | "google-p12-pem": { 2411 | "version": "3.1.4", 2412 | "resolved": "https://registry.npmjs.org/google-p12-pem/-/google-p12-pem-3.1.4.tgz", 2413 | "integrity": "sha512-HHuHmkLgwjdmVRngf5+gSmpkyaRI6QmOg77J8tkNBHhNEI62sGHyw4/+UkgyZEI7h84NbWprXDJ+sa3xOYFvTg==", 2414 | "requires": { 2415 | "node-forge": "^1.3.1" 2416 | } 2417 | }, 2418 | "gtoken": { 2419 | "version": "5.2.1", 2420 | "resolved": "https://registry.npmjs.org/gtoken/-/gtoken-5.2.1.tgz", 2421 | "integrity": "sha512-OY0BfPKe3QnMsY9MzTHTSKn+Vl2l1CcLe6BwDEQj00mbbkl5nyQ/7EUREstg4fQNZ8iYE7br4JJ7TdKeDOPWmw==", 2422 | "requires": { 2423 | "gaxios": "^4.0.0", 2424 | "google-p12-pem": "^3.0.3", 2425 | "jws": "^4.0.0" 2426 | } 2427 | }, 2428 | "has": { 2429 | "version": "1.0.3", 2430 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2431 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2432 | "requires": { 2433 | "function-bind": "^1.1.1" 2434 | } 2435 | }, 2436 | "has-flag": { 2437 | "version": "3.0.0", 2438 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2439 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 2440 | }, 2441 | "has-symbols": { 2442 | "version": "1.0.3", 2443 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 2444 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==" 2445 | }, 2446 | "http-errors": { 2447 | "version": "2.0.0", 2448 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 2449 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 2450 | "requires": { 2451 | "depd": "2.0.0", 2452 | "inherits": "2.0.4", 2453 | "setprototypeof": "1.2.0", 2454 | "statuses": "2.0.1", 2455 | "toidentifier": "1.0.1" 2456 | } 2457 | }, 2458 | "http-proxy-agent": { 2459 | "version": "4.0.1", 2460 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 2461 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 2462 | "requires": { 2463 | "@tootallnate/once": "1", 2464 | "agent-base": "6", 2465 | "debug": "4" 2466 | }, 2467 | "dependencies": { 2468 | "debug": { 2469 | "version": "4.3.1", 2470 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 2471 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 2472 | "requires": { 2473 | "ms": "2.1.2" 2474 | } 2475 | }, 2476 | "ms": { 2477 | "version": "2.1.2", 2478 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2479 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2480 | } 2481 | } 2482 | }, 2483 | "https-proxy-agent": { 2484 | "version": "5.0.0", 2485 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 2486 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 2487 | "requires": { 2488 | "agent-base": "6", 2489 | "debug": "4" 2490 | }, 2491 | "dependencies": { 2492 | "debug": { 2493 | "version": "4.3.1", 2494 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 2495 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 2496 | "requires": { 2497 | "ms": "2.1.2" 2498 | } 2499 | }, 2500 | "ms": { 2501 | "version": "2.1.2", 2502 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2503 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2504 | } 2505 | } 2506 | }, 2507 | "iconv-lite": { 2508 | "version": "0.4.24", 2509 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 2510 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 2511 | "requires": { 2512 | "safer-buffer": ">= 2.1.2 < 3" 2513 | } 2514 | }, 2515 | "inherits": { 2516 | "version": "2.0.4", 2517 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2518 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 2519 | }, 2520 | "ipaddr.js": { 2521 | "version": "1.9.1", 2522 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 2523 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 2524 | }, 2525 | "is-stream": { 2526 | "version": "2.0.0", 2527 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", 2528 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==" 2529 | }, 2530 | "is-stream-ended": { 2531 | "version": "0.1.4", 2532 | "resolved": "https://registry.npmjs.org/is-stream-ended/-/is-stream-ended-0.1.4.tgz", 2533 | "integrity": "sha512-xj0XPvmr7bQFTvirqnFr50o0hQIh6ZItDqloxt5aJrR4NQsYeSsyFQERYGCAzfindAcnKjINnwEEgLx4IqVzQw==" 2534 | }, 2535 | "jake": { 2536 | "version": "10.8.2", 2537 | "resolved": "https://registry.npmjs.org/jake/-/jake-10.8.2.tgz", 2538 | "integrity": "sha512-eLpKyrfG3mzvGE2Du8VoPbeSkRry093+tyNjdYaBbJS9v17knImYGNXQCUV0gLxQtF82m3E8iRb/wdSQZLoq7A==", 2539 | "requires": { 2540 | "async": "0.9.x", 2541 | "chalk": "^2.4.2", 2542 | "filelist": "^1.0.1", 2543 | "minimatch": "^3.0.4" 2544 | } 2545 | }, 2546 | "json-bigint": { 2547 | "version": "1.0.0", 2548 | "resolved": "https://registry.npmjs.org/json-bigint/-/json-bigint-1.0.0.tgz", 2549 | "integrity": "sha512-SiPv/8VpZuWbvLSMtTDU8hEfrZWg/mH/nV/b4o0CYbSxu1UIQPLdwKOCIyLQX+VIPO5vrLX3i8qtqFyhdPSUSQ==", 2550 | "requires": { 2551 | "bignumber.js": "^9.0.0" 2552 | } 2553 | }, 2554 | "jwa": { 2555 | "version": "2.0.0", 2556 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-2.0.0.tgz", 2557 | "integrity": "sha512-jrZ2Qx916EA+fq9cEAeCROWPTfCwi1IVHqT2tapuqLEVVDKFDENFw1oL+MwrTvH6msKxsd1YTDVw6uKEcsrLEA==", 2558 | "requires": { 2559 | "buffer-equal-constant-time": "1.0.1", 2560 | "ecdsa-sig-formatter": "1.0.11", 2561 | "safe-buffer": "^5.0.1" 2562 | } 2563 | }, 2564 | "jws": { 2565 | "version": "4.0.0", 2566 | "resolved": "https://registry.npmjs.org/jws/-/jws-4.0.0.tgz", 2567 | "integrity": "sha512-KDncfTmOZoOMTFG4mBlG0qUIOlc03fmzH+ru6RgYVZhPkyiy/92Owlt/8UEN+a4TXR1FQetfIpJE8ApdvdVxTg==", 2568 | "requires": { 2569 | "jwa": "^2.0.0", 2570 | "safe-buffer": "^5.0.1" 2571 | } 2572 | }, 2573 | "lodash.camelcase": { 2574 | "version": "4.3.0", 2575 | "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", 2576 | "integrity": "sha1-soqmKIorn8ZRA1x3EfZathkDMaY=" 2577 | }, 2578 | "long": { 2579 | "version": "4.0.0", 2580 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 2581 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 2582 | }, 2583 | "lru-cache": { 2584 | "version": "6.0.0", 2585 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2586 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2587 | "requires": { 2588 | "yallist": "^4.0.0" 2589 | } 2590 | }, 2591 | "media-typer": { 2592 | "version": "0.3.0", 2593 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 2594 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==" 2595 | }, 2596 | "merge-descriptors": { 2597 | "version": "1.0.1", 2598 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 2599 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 2600 | }, 2601 | "methods": { 2602 | "version": "1.1.2", 2603 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 2604 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 2605 | }, 2606 | "mime": { 2607 | "version": "1.6.0", 2608 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 2609 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 2610 | }, 2611 | "mime-db": { 2612 | "version": "1.52.0", 2613 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 2614 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" 2615 | }, 2616 | "mime-types": { 2617 | "version": "2.1.35", 2618 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 2619 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 2620 | "requires": { 2621 | "mime-db": "1.52.0" 2622 | } 2623 | }, 2624 | "minimatch": { 2625 | "version": "3.0.4", 2626 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2627 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2628 | "requires": { 2629 | "brace-expansion": "^1.1.7" 2630 | } 2631 | }, 2632 | "ms": { 2633 | "version": "2.0.0", 2634 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2635 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 2636 | }, 2637 | "negotiator": { 2638 | "version": "0.6.3", 2639 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 2640 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==" 2641 | }, 2642 | "node-fetch": { 2643 | "version": "2.6.7", 2644 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.7.tgz", 2645 | "integrity": "sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==", 2646 | "requires": { 2647 | "whatwg-url": "^5.0.0" 2648 | } 2649 | }, 2650 | "node-forge": { 2651 | "version": "1.3.1", 2652 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", 2653 | "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==" 2654 | }, 2655 | "object-assign": { 2656 | "version": "4.1.1", 2657 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2658 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 2659 | }, 2660 | "object-inspect": { 2661 | "version": "1.12.2", 2662 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz", 2663 | "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==" 2664 | }, 2665 | "on-finished": { 2666 | "version": "2.4.1", 2667 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 2668 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 2669 | "requires": { 2670 | "ee-first": "1.1.1" 2671 | } 2672 | }, 2673 | "once": { 2674 | "version": "1.4.0", 2675 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2676 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2677 | "requires": { 2678 | "wrappy": "1" 2679 | } 2680 | }, 2681 | "parseurl": { 2682 | "version": "1.3.3", 2683 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 2684 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 2685 | }, 2686 | "path": { 2687 | "version": "0.12.7", 2688 | "resolved": "https://registry.npmjs.org/path/-/path-0.12.7.tgz", 2689 | "integrity": "sha1-1NwqUGxM4hl+tIHr/NWzbAFAsQ8=", 2690 | "requires": { 2691 | "process": "^0.11.1", 2692 | "util": "^0.10.3" 2693 | } 2694 | }, 2695 | "path-to-regexp": { 2696 | "version": "0.1.7", 2697 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 2698 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 2699 | }, 2700 | "process": { 2701 | "version": "0.11.10", 2702 | "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", 2703 | "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=" 2704 | }, 2705 | "protobufjs": { 2706 | "version": "6.10.2", 2707 | "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.10.2.tgz", 2708 | "integrity": "sha512-27yj+04uF6ya9l+qfpH187aqEzfCF4+Uit0I9ZBQVqK09hk/SQzKa2MUqUpXaVa7LOFRg1TSSr3lVxGOk6c0SQ==", 2709 | "requires": { 2710 | "@protobufjs/aspromise": "^1.1.2", 2711 | "@protobufjs/base64": "^1.1.2", 2712 | "@protobufjs/codegen": "^2.0.4", 2713 | "@protobufjs/eventemitter": "^1.1.0", 2714 | "@protobufjs/fetch": "^1.1.0", 2715 | "@protobufjs/float": "^1.0.2", 2716 | "@protobufjs/inquire": "^1.1.0", 2717 | "@protobufjs/path": "^1.1.2", 2718 | "@protobufjs/pool": "^1.1.0", 2719 | "@protobufjs/utf8": "^1.1.0", 2720 | "@types/long": "^4.0.1", 2721 | "@types/node": "^13.7.0", 2722 | "long": "^4.0.0" 2723 | }, 2724 | "dependencies": { 2725 | "@types/node": { 2726 | "version": "13.13.42", 2727 | "resolved": "https://registry.npmjs.org/@types/node/-/node-13.13.42.tgz", 2728 | "integrity": "sha512-g+w2QgbW7k2CWLOXzQXbO37a7v5P9ObPvYahKphdBLV5aqpbVZRhTpWCT0SMRqX1i30Aig791ZmIM2fJGL2S8A==" 2729 | } 2730 | } 2731 | }, 2732 | "proxy-addr": { 2733 | "version": "2.0.7", 2734 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 2735 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 2736 | "requires": { 2737 | "forwarded": "0.2.0", 2738 | "ipaddr.js": "1.9.1" 2739 | } 2740 | }, 2741 | "pump": { 2742 | "version": "3.0.0", 2743 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 2744 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 2745 | "requires": { 2746 | "end-of-stream": "^1.1.0", 2747 | "once": "^1.3.1" 2748 | } 2749 | }, 2750 | "pumpify": { 2751 | "version": "2.0.1", 2752 | "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-2.0.1.tgz", 2753 | "integrity": "sha512-m7KOje7jZxrmutanlkS1daj1dS6z6BgslzOXmcSEpIlCxM3VJH7lG5QLeck/6hgF6F4crFf01UtQmNsJfweTAw==", 2754 | "requires": { 2755 | "duplexify": "^4.1.1", 2756 | "inherits": "^2.0.3", 2757 | "pump": "^3.0.0" 2758 | } 2759 | }, 2760 | "qs": { 2761 | "version": "6.11.0", 2762 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 2763 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 2764 | "requires": { 2765 | "side-channel": "^1.0.4" 2766 | } 2767 | }, 2768 | "range-parser": { 2769 | "version": "1.2.1", 2770 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 2771 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 2772 | }, 2773 | "raw-body": { 2774 | "version": "2.5.1", 2775 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 2776 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 2777 | "requires": { 2778 | "bytes": "3.1.2", 2779 | "http-errors": "2.0.0", 2780 | "iconv-lite": "0.4.24", 2781 | "unpipe": "1.0.0" 2782 | } 2783 | }, 2784 | "readable-stream": { 2785 | "version": "3.6.0", 2786 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 2787 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 2788 | "requires": { 2789 | "inherits": "^2.0.3", 2790 | "string_decoder": "^1.1.1", 2791 | "util-deprecate": "^1.0.1" 2792 | } 2793 | }, 2794 | "retry-request": { 2795 | "version": "4.1.3", 2796 | "resolved": "https://registry.npmjs.org/retry-request/-/retry-request-4.1.3.tgz", 2797 | "integrity": "sha512-QnRZUpuPNgX0+D1xVxul6DbJ9slvo4Rm6iV/dn63e048MvGbUZiKySVt6Tenp04JqmchxjiLltGerOJys7kJYQ==", 2798 | "requires": { 2799 | "debug": "^4.1.1" 2800 | }, 2801 | "dependencies": { 2802 | "debug": { 2803 | "version": "4.3.1", 2804 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 2805 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 2806 | "requires": { 2807 | "ms": "2.1.2" 2808 | } 2809 | }, 2810 | "ms": { 2811 | "version": "2.1.2", 2812 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2813 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2814 | } 2815 | } 2816 | }, 2817 | "safe-buffer": { 2818 | "version": "5.2.1", 2819 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2820 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 2821 | }, 2822 | "safer-buffer": { 2823 | "version": "2.1.2", 2824 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2825 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2826 | }, 2827 | "semver": { 2828 | "version": "6.3.0", 2829 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2830 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 2831 | }, 2832 | "send": { 2833 | "version": "0.18.0", 2834 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 2835 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 2836 | "requires": { 2837 | "debug": "2.6.9", 2838 | "depd": "2.0.0", 2839 | "destroy": "1.2.0", 2840 | "encodeurl": "~1.0.2", 2841 | "escape-html": "~1.0.3", 2842 | "etag": "~1.8.1", 2843 | "fresh": "0.5.2", 2844 | "http-errors": "2.0.0", 2845 | "mime": "1.6.0", 2846 | "ms": "2.1.3", 2847 | "on-finished": "2.4.1", 2848 | "range-parser": "~1.2.1", 2849 | "statuses": "2.0.1" 2850 | }, 2851 | "dependencies": { 2852 | "ms": { 2853 | "version": "2.1.3", 2854 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2855 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 2856 | } 2857 | } 2858 | }, 2859 | "serve-static": { 2860 | "version": "1.15.0", 2861 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 2862 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 2863 | "requires": { 2864 | "encodeurl": "~1.0.2", 2865 | "escape-html": "~1.0.3", 2866 | "parseurl": "~1.3.3", 2867 | "send": "0.18.0" 2868 | } 2869 | }, 2870 | "setprototypeof": { 2871 | "version": "1.2.0", 2872 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 2873 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 2874 | }, 2875 | "side-channel": { 2876 | "version": "1.0.4", 2877 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 2878 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 2879 | "requires": { 2880 | "call-bind": "^1.0.0", 2881 | "get-intrinsic": "^1.0.2", 2882 | "object-inspect": "^1.9.0" 2883 | } 2884 | }, 2885 | "socket.io": { 2886 | "version": "3.1.1", 2887 | "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-3.1.1.tgz", 2888 | "integrity": "sha512-7cBWdsDC7bbyEF6WbBqffjizc/H4YF1wLdZoOzuYfo2uMNSFjJKuQ36t0H40o9B20DO6p+mSytEd92oP4S15bA==", 2889 | "requires": { 2890 | "@types/cookie": "^0.4.0", 2891 | "@types/cors": "^2.8.8", 2892 | "@types/node": "^14.14.10", 2893 | "accepts": "~1.3.4", 2894 | "base64id": "~2.0.0", 2895 | "debug": "~4.3.1", 2896 | "engine.io": "~4.1.0", 2897 | "socket.io-adapter": "~2.1.0", 2898 | "socket.io-parser": "~4.0.3" 2899 | }, 2900 | "dependencies": { 2901 | "debug": { 2902 | "version": "4.3.1", 2903 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 2904 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 2905 | "requires": { 2906 | "ms": "2.1.2" 2907 | } 2908 | }, 2909 | "ms": { 2910 | "version": "2.1.2", 2911 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2912 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2913 | } 2914 | } 2915 | }, 2916 | "socket.io-adapter": { 2917 | "version": "2.1.0", 2918 | "resolved": "https://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-2.1.0.tgz", 2919 | "integrity": "sha512-+vDov/aTsLjViYTwS9fPy5pEtTkrbEKsw2M+oVSoFGw6OD1IpvlV1VPhUzNbofCQ8oyMbdYJqDtGdmHQK6TdPg==" 2920 | }, 2921 | "socket.io-parser": { 2922 | "version": "4.0.5", 2923 | "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-4.0.5.tgz", 2924 | "integrity": "sha512-sNjbT9dX63nqUFIOv95tTVm6elyIU4RvB1m8dOeZt+IgWwcWklFDOdmGcfo3zSiRsnR/3pJkjY5lfoGqEe4Eig==", 2925 | "requires": { 2926 | "@types/component-emitter": "^1.2.10", 2927 | "component-emitter": "~1.3.0", 2928 | "debug": "~4.3.1" 2929 | }, 2930 | "dependencies": { 2931 | "debug": { 2932 | "version": "4.3.1", 2933 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 2934 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 2935 | "requires": { 2936 | "ms": "2.1.2" 2937 | } 2938 | }, 2939 | "ms": { 2940 | "version": "2.1.2", 2941 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2942 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2943 | } 2944 | } 2945 | }, 2946 | "statuses": { 2947 | "version": "2.0.1", 2948 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 2949 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==" 2950 | }, 2951 | "stream-events": { 2952 | "version": "1.0.5", 2953 | "resolved": "https://registry.npmjs.org/stream-events/-/stream-events-1.0.5.tgz", 2954 | "integrity": "sha512-E1GUzBSgvct8Jsb3v2X15pjzN1tYebtbLaMg+eBOUOAxgbLoSbT2NS91ckc5lJD1KfLjId+jXJRgo0qnV5Nerg==", 2955 | "requires": { 2956 | "stubs": "^3.0.0" 2957 | } 2958 | }, 2959 | "stream-shift": { 2960 | "version": "1.0.1", 2961 | "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.1.tgz", 2962 | "integrity": "sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ==" 2963 | }, 2964 | "string_decoder": { 2965 | "version": "1.3.0", 2966 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 2967 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 2968 | "requires": { 2969 | "safe-buffer": "~5.2.0" 2970 | } 2971 | }, 2972 | "stubs": { 2973 | "version": "3.0.0", 2974 | "resolved": "https://registry.npmjs.org/stubs/-/stubs-3.0.0.tgz", 2975 | "integrity": "sha1-6NK6H6nJBXAwPAMLaQD31fiavls=" 2976 | }, 2977 | "supports-color": { 2978 | "version": "5.5.0", 2979 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2980 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2981 | "requires": { 2982 | "has-flag": "^3.0.0" 2983 | } 2984 | }, 2985 | "teeny-request": { 2986 | "version": "7.0.1", 2987 | "resolved": "https://registry.npmjs.org/teeny-request/-/teeny-request-7.0.1.tgz", 2988 | "integrity": "sha512-sasJmQ37klOlplL4Ia/786M5YlOcoLGQyq2TE4WHSRupbAuDaQW0PfVxV4MtdBtRJ4ngzS+1qim8zP6Zp35qCw==", 2989 | "requires": { 2990 | "http-proxy-agent": "^4.0.0", 2991 | "https-proxy-agent": "^5.0.0", 2992 | "node-fetch": "^2.6.1", 2993 | "stream-events": "^1.0.5", 2994 | "uuid": "^8.0.0" 2995 | } 2996 | }, 2997 | "toidentifier": { 2998 | "version": "1.0.1", 2999 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 3000 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==" 3001 | }, 3002 | "tr46": { 3003 | "version": "0.0.3", 3004 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 3005 | "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" 3006 | }, 3007 | "type-is": { 3008 | "version": "1.6.18", 3009 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 3010 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 3011 | "requires": { 3012 | "media-typer": "0.3.0", 3013 | "mime-types": "~2.1.24" 3014 | } 3015 | }, 3016 | "unpipe": { 3017 | "version": "1.0.0", 3018 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 3019 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==" 3020 | }, 3021 | "util": { 3022 | "version": "0.10.4", 3023 | "resolved": "https://registry.npmjs.org/util/-/util-0.10.4.tgz", 3024 | "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==", 3025 | "requires": { 3026 | "inherits": "2.0.3" 3027 | }, 3028 | "dependencies": { 3029 | "inherits": { 3030 | "version": "2.0.3", 3031 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 3032 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 3033 | } 3034 | } 3035 | }, 3036 | "util-deprecate": { 3037 | "version": "1.0.2", 3038 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3039 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 3040 | }, 3041 | "utils-merge": { 3042 | "version": "1.0.1", 3043 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 3044 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 3045 | }, 3046 | "uuid": { 3047 | "version": "8.3.2", 3048 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 3049 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==" 3050 | }, 3051 | "vary": { 3052 | "version": "1.1.2", 3053 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 3054 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 3055 | }, 3056 | "webidl-conversions": { 3057 | "version": "3.0.1", 3058 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 3059 | "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" 3060 | }, 3061 | "whatwg-url": { 3062 | "version": "5.0.0", 3063 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 3064 | "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", 3065 | "requires": { 3066 | "tr46": "~0.0.3", 3067 | "webidl-conversions": "^3.0.0" 3068 | } 3069 | }, 3070 | "wrappy": { 3071 | "version": "1.0.2", 3072 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3073 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 3074 | }, 3075 | "ws": { 3076 | "version": "7.4.3", 3077 | "resolved": "https://registry.npmjs.org/ws/-/ws-7.4.3.tgz", 3078 | "integrity": "sha512-hr6vCR76GsossIRsr8OLR9acVVm1jyfEWvhbNjtgPOrfvAlKzvyeg/P6r8RuDjRyrcQoPQT7K0DGEPc7Ae6jzA==", 3079 | "requires": {} 3080 | }, 3081 | "yallist": { 3082 | "version": "4.0.0", 3083 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3084 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 3085 | } 3086 | } 3087 | } 3088 | -------------------------------------------------------------------------------- /srcLogOnly/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "GoogleCloudSpeechPlayground", 3 | "version": "1.0.1", 4 | "description": "Google Cloud Speech Playground with node.js and socket.io.", 5 | "main": "app.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "@google-cloud/speech": "^4.2.0", 13 | "dotenv": "^8.2.0", 14 | "ejs": "^3.1.6", 15 | "express": "^4.18.2", 16 | "path": "^0.12.7", 17 | "socket.io": "^3.1.1" 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /srcLogOnly/public/css/main-min.css: -------------------------------------------------------------------------------- 1 | body{font-family:sans-serif;background-color:white}.wrapper{width:90vw;margin:0 auto;margin-top:25px} 2 | -------------------------------------------------------------------------------- /srcLogOnly/public/css/main.css: -------------------------------------------------------------------------------- 1 | body { 2 | font-family: sans-serif; 3 | background-color: white; 4 | } 5 | 6 | .wrapper { 7 | width: 90vw; 8 | margin: 0 auto; 9 | margin-top: 25px; 10 | } -------------------------------------------------------------------------------- /srcLogOnly/public/js/client.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | // Google Cloud Speech Playground with node.js and socket.io 4 | // Created by Vinzenz Aubry for sansho 24.01.17 5 | // Feel free to improve! 6 | // Contact: v@vinzenzaubry.com 7 | 8 | //connection to socket 9 | const socket = io.connect(); 10 | 11 | //================= CONFIG ================= 12 | // Stream Audio 13 | let bufferSize = 2048, 14 | AudioContext, 15 | context, 16 | processor, 17 | input, 18 | globalStream; 19 | 20 | //vars 21 | let audioElement = document.querySelector('audio'), 22 | finalWord = false, 23 | resultText = document.getElementById('ResultText'), 24 | removeLastSentence = true, 25 | streamStreaming = false; 26 | 27 | //audioStream constraints 28 | const constraints = { 29 | audio: true, 30 | video: false, 31 | }; 32 | 33 | //================= RECORDING ================= 34 | 35 | function initRecording() { 36 | socket.emit('startGoogleCloudStream', ''); //init socket Google Speech Connection 37 | streamStreaming = true; 38 | AudioContext = window.AudioContext || window.webkitAudioContext; 39 | context = new AudioContext({ 40 | // if Non-interactive, use 'playback' or 'balanced' // https://developer.mozilla.org/en-US/docs/Web/API/AudioContextLatencyCategory 41 | latencyHint: 'interactive', 42 | }); 43 | processor = context.createScriptProcessor(bufferSize, 1, 1); 44 | processor.connect(context.destination); 45 | context.resume(); 46 | 47 | var handleSuccess = function (stream) { 48 | globalStream = stream; 49 | input = context.createMediaStreamSource(stream); 50 | input.connect(processor); 51 | 52 | processor.onaudioprocess = function (e) { 53 | microphoneProcess(e); 54 | }; 55 | }; 56 | 57 | navigator.mediaDevices.getUserMedia(constraints).then(handleSuccess); 58 | } 59 | 60 | function microphoneProcess(e) { 61 | var left = e.inputBuffer.getChannelData(0); 62 | // var left16 = convertFloat32ToInt16(left); // old 32 to 16 function 63 | var left16 = downsampleBuffer(left, 44100, 16000); 64 | socket.emit('binaryData', left16); 65 | } 66 | 67 | //================= INTERFACE ================= 68 | var startButton = document.getElementById('startRecButton'); 69 | startButton.addEventListener('click', startRecording); 70 | 71 | var endButton = document.getElementById('stopRecButton'); 72 | endButton.addEventListener('click', stopRecording); 73 | endButton.disabled = true; 74 | 75 | var recordingStatus = document.getElementById('recordingStatus'); 76 | 77 | function startRecording() { 78 | startButton.disabled = true; 79 | endButton.disabled = false; 80 | recordingStatus.style.visibility = 'visible'; 81 | initRecording(); 82 | } 83 | 84 | function stopRecording() { 85 | // waited for FinalWord 86 | startButton.disabled = false; 87 | endButton.disabled = true; 88 | recordingStatus.style.visibility = 'hidden'; 89 | streamStreaming = false; 90 | socket.emit('endGoogleCloudStream', ''); 91 | 92 | let track = globalStream.getTracks()[0]; 93 | track.stop(); 94 | 95 | input.disconnect(processor); 96 | processor.disconnect(context.destination); 97 | context.close().then(function () { 98 | input = null; 99 | processor = null; 100 | context = null; 101 | AudioContext = null; 102 | startButton.disabled = false; 103 | }); 104 | 105 | // context.close(); 106 | 107 | // audiovideostream.stop(); 108 | 109 | // microphone_stream.disconnect(script_processor_node); 110 | // script_processor_node.disconnect(audioContext.destination); 111 | // microphone_stream = null; 112 | // script_processor_node = null; 113 | 114 | // audiovideostream.stop(); 115 | // videoElement.srcObject = null; 116 | } 117 | 118 | //================= SOCKET IO ================= 119 | socket.on('connect', function (data) { 120 | console.log('connected to socket'); 121 | socket.emit('join', 'Server Connected to Client'); 122 | }); 123 | 124 | socket.on('messages', function (data) { 125 | console.log(data); 126 | }); 127 | 128 | socket.on('speechData', function (data) { 129 | // console.log(data.results[0].alternatives[0].transcript); 130 | var dataFinal = undefined || data.results[0].isFinal; 131 | 132 | if (dataFinal === false) { 133 | // console.log(resultText.lastElementChild); 134 | if (removeLastSentence) { 135 | resultText.lastElementChild.remove(); 136 | } 137 | removeLastSentence = true; 138 | 139 | //add empty span 140 | let empty = document.createElement('span'); 141 | resultText.appendChild(empty); 142 | 143 | //add children to empty span 144 | let edit = addTimeSettingsInterim(data); 145 | 146 | for (var i = 0; i < edit.length; i++) { 147 | resultText.lastElementChild.appendChild(edit[i]); 148 | resultText.lastElementChild.appendChild( 149 | document.createTextNode('\u00A0') 150 | ); 151 | } 152 | } else if (dataFinal === true) { 153 | resultText.lastElementChild.remove(); 154 | 155 | //add empty span 156 | let empty = document.createElement('span'); 157 | resultText.appendChild(empty); 158 | 159 | //add children to empty span 160 | let edit = addTimeSettingsFinal(data); 161 | for (var i = 0; i < edit.length; i++) { 162 | if (i === 0) { 163 | edit[i].innerText = capitalize(edit[i].innerText); 164 | } 165 | resultText.lastElementChild.appendChild(edit[i]); 166 | 167 | if (i !== edit.length - 1) { 168 | resultText.lastElementChild.appendChild( 169 | document.createTextNode('\u00A0') 170 | ); 171 | } 172 | } 173 | resultText.lastElementChild.appendChild( 174 | document.createTextNode('\u002E\u00A0') 175 | ); 176 | 177 | console.log("Google Speech sent 'final' Sentence."); 178 | finalWord = true; 179 | endButton.disabled = false; 180 | 181 | removeLastSentence = false; 182 | } 183 | }); 184 | 185 | //================= Juggling Spans for nlp Coloring ================= 186 | function addTimeSettingsInterim(speechData) { 187 | let wholeString = speechData.results[0].alternatives[0].transcript; 188 | console.log(wholeString); 189 | 190 | let nlpObject = nlp(wholeString).out('terms'); 191 | 192 | let words_without_time = []; 193 | 194 | for (let i = 0; i < nlpObject.length; i++) { 195 | //data 196 | let word = nlpObject[i].text; 197 | let tags = []; 198 | 199 | //generate span 200 | let newSpan = document.createElement('span'); 201 | newSpan.innerHTML = word; 202 | 203 | //push all tags 204 | for (let j = 0; j < nlpObject[i].tags.length; j++) { 205 | tags.push(nlpObject[i].tags[j]); 206 | } 207 | 208 | //add all classes 209 | for (let j = 0; j < nlpObject[i].tags.length; j++) { 210 | let cleanClassName = tags[j]; 211 | // console.log(tags); 212 | let className = `nl-${cleanClassName}`; 213 | newSpan.classList.add(className); 214 | } 215 | 216 | words_without_time.push(newSpan); 217 | } 218 | 219 | finalWord = false; 220 | endButton.disabled = true; 221 | 222 | return words_without_time; 223 | } 224 | 225 | function addTimeSettingsFinal(speechData) { 226 | let wholeString = speechData.results[0].alternatives[0].transcript; 227 | 228 | let nlpObject = nlp(wholeString).out('terms'); 229 | let words = speechData.results[0].alternatives[0].words; 230 | 231 | let words_n_time = []; 232 | 233 | for (let i = 0; i < words.length; i++) { 234 | //data 235 | let word = words[i].word; 236 | let startTime = `${words[i].startTime.seconds}.${words[i].startTime.nanos}`; 237 | let endTime = `${words[i].endTime.seconds}.${words[i].endTime.nanos}`; 238 | let tags = []; 239 | 240 | //generate span 241 | let newSpan = document.createElement('span'); 242 | newSpan.innerHTML = word; 243 | newSpan.dataset.startTime = startTime; 244 | 245 | //push all tags 246 | for (let j = 0; j < nlpObject[i].tags.length; j++) { 247 | tags.push(nlpObject[i].tags[j]); 248 | } 249 | 250 | //add all classes 251 | for (let j = 0; j < nlpObject[i].tags.length; j++) { 252 | let cleanClassName = nlpObject[i].tags[j]; 253 | // console.log(tags); 254 | let className = `nl-${cleanClassName}`; 255 | newSpan.classList.add(className); 256 | } 257 | 258 | words_n_time.push(newSpan); 259 | } 260 | 261 | return words_n_time; 262 | } 263 | 264 | window.onbeforeunload = function () { 265 | if (streamStreaming) { 266 | socket.emit('endGoogleCloudStream', ''); 267 | } 268 | }; 269 | 270 | //================= SANTAS HELPERS ================= 271 | 272 | // sampleRateHertz 16000 //saved sound is awefull 273 | function convertFloat32ToInt16(buffer) { 274 | let l = buffer.length; 275 | let buf = new Int16Array(l / 3); 276 | 277 | while (l--) { 278 | if (l % 3 == 0) { 279 | buf[l / 3] = buffer[l] * 0xffff; 280 | } 281 | } 282 | return buf.buffer; 283 | } 284 | 285 | var downsampleBuffer = function (buffer, sampleRate, outSampleRate) { 286 | if (outSampleRate == sampleRate) { 287 | return buffer; 288 | } 289 | if (outSampleRate > sampleRate) { 290 | throw 'downsampling rate show be smaller than original sample rate'; 291 | } 292 | var sampleRateRatio = sampleRate / outSampleRate; 293 | var newLength = Math.round(buffer.length / sampleRateRatio); 294 | var result = new Int16Array(newLength); 295 | var offsetResult = 0; 296 | var offsetBuffer = 0; 297 | while (offsetResult < result.length) { 298 | var nextOffsetBuffer = Math.round((offsetResult + 1) * sampleRateRatio); 299 | var accum = 0, 300 | count = 0; 301 | for (var i = offsetBuffer; i < nextOffsetBuffer && i < buffer.length; i++) { 302 | accum += buffer[i]; 303 | count++; 304 | } 305 | 306 | result[offsetResult] = Math.min(1, accum / count) * 0x7fff; 307 | offsetResult++; 308 | offsetBuffer = nextOffsetBuffer; 309 | } 310 | return result.buffer; 311 | }; 312 | 313 | function capitalize(s) { 314 | if (s.length < 1) { 315 | return s; 316 | } 317 | return s.charAt(0).toUpperCase() + s.slice(1); 318 | } 319 | -------------------------------------------------------------------------------- /srcLogOnly/views/index.ejs: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | A Human Foundry Christmas 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | --------------------------------------------------------------------------------