├── .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 | [](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 | 
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 |
--------------------------------------------------------------------------------