├── .dockerignore ├── .github └── workflows │ └── main.yml ├── .gitignore ├── Dockerfile ├── README.md ├── package-lock.json ├── package.json ├── src └── server.ts └── tsconfig.json /.dockerignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | -------------------------------------------------------------------------------- /.github/workflows/main.yml: -------------------------------------------------------------------------------- 1 | name: rtmp-webrtc-adapter-cicd 2 | 3 | on: 4 | push: 5 | branches: [ master ] 6 | 7 | jobs: 8 | build: 9 | runs-on: ubuntu-latest 10 | steps: 11 | - name: Checkout 12 | uses: actions/checkout@v2 13 | 14 | - name: Docker build & publish 15 | uses: docker/build-push-action@v1 16 | with: 17 | username: "${{ secrets.DOCKER_USERNAME }}" 18 | password: "${{ secrets.DOCKER_PASSWORD }}" 19 | registry: registry.cn-beijing.aliyuncs.com 20 | repository: mengli/rtmp-webrtc-adapter 21 | tags: latest 22 | 23 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | dist/ 3 | .idea/ 4 | -------------------------------------------------------------------------------- /Dockerfile: -------------------------------------------------------------------------------- 1 | FROM node:10-alpine 2 | 3 | RUN apk add --no-cache linux-headers g++ make python2 ffmpeg 4 | 5 | WORKDIR /home/node/app 6 | COPY src /home/node/app/src 7 | COPY package.json /home/node/app/ 8 | COPY package-lock.json /home/node/app/ 9 | COPY tsconfig.json /home/node/app/ 10 | 11 | RUN npm ci 12 | RUN npm run build 13 | 14 | ENTRYPOINT [ "sh", "-c", "npm start" ] 15 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # rtmp-webrtc-adapter 2 | Feed rtmp stream to webrtc based on mediasoup 3 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "mediasoup-test", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@types/body-parser": { 8 | "version": "1.19.0", 9 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.0.tgz", 10 | "integrity": "sha512-W98JrE0j2K78swW4ukqMleo8R7h/pFETjM2DQ90MF6XK2i4LO4W3gQ71Lt4w3bfm2EvVSyWHplECvB5sK22yFQ==", 11 | "dev": true, 12 | "requires": { 13 | "@types/connect": "*", 14 | "@types/node": "*" 15 | } 16 | }, 17 | "@types/connect": { 18 | "version": "3.4.33", 19 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.33.tgz", 20 | "integrity": "sha512-2+FrkXY4zllzTNfJth7jOqEHC+enpLeGslEhpnTAkg21GkRrWV4SsAtqchtT4YS9/nODBU2/ZfsBY2X4J/dX7A==", 21 | "dev": true, 22 | "requires": { 23 | "@types/node": "*" 24 | } 25 | }, 26 | "@types/engine.io": { 27 | "version": "3.1.4", 28 | "resolved": "https://registry.npmjs.org/@types/engine.io/-/engine.io-3.1.4.tgz", 29 | "integrity": "sha512-98rXVukLD6/ozrQ2O80NAlWDGA4INg+tqsEReWJldqyi2fulC9V7Use/n28SWgROXKm6003ycWV4gZHoF8GA6w==", 30 | "dev": true, 31 | "requires": { 32 | "@types/node": "*" 33 | } 34 | }, 35 | "@types/express": { 36 | "version": "4.17.8", 37 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.8.tgz", 38 | "integrity": "sha512-wLhcKh3PMlyA2cNAB9sjM1BntnhPMiM0JOBwPBqttjHev2428MLEB4AYVN+d8s2iyCVZac+o41Pflm/ZH5vLXQ==", 39 | "dev": true, 40 | "requires": { 41 | "@types/body-parser": "*", 42 | "@types/express-serve-static-core": "*", 43 | "@types/qs": "*", 44 | "@types/serve-static": "*" 45 | } 46 | }, 47 | "@types/express-serve-static-core": { 48 | "version": "4.17.12", 49 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.12.tgz", 50 | "integrity": "sha512-EaEdY+Dty1jEU7U6J4CUWwxL+hyEGMkO5jan5gplfegUgCUsIUWqXxqw47uGjimeT4Qgkz/XUfwoau08+fgvKA==", 51 | "dev": true, 52 | "requires": { 53 | "@types/node": "*", 54 | "@types/qs": "*", 55 | "@types/range-parser": "*" 56 | } 57 | }, 58 | "@types/mime": { 59 | "version": "2.0.3", 60 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-2.0.3.tgz", 61 | "integrity": "sha512-Jus9s4CDbqwocc5pOAnh8ShfrnMcPHuJYzVcSUU7lrh8Ni5HuIqX3oilL86p3dlTrk0LzHRCgA/GQ7uNCw6l2Q==", 62 | "dev": true 63 | }, 64 | "@types/node": { 65 | "version": "14.10.1", 66 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.10.1.tgz", 67 | "integrity": "sha512-aYNbO+FZ/3KGeQCEkNhHFRIzBOUgc7QvcVNKXbfnhDkSfwUv91JsQQa10rDgKSTSLkXZ1UIyPe4FJJNVgw1xWQ==" 68 | }, 69 | "@types/qs": { 70 | "version": "6.9.4", 71 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.4.tgz", 72 | "integrity": "sha512-+wYo+L6ZF6BMoEjtf8zB2esQsqdV6WsjRK/GP9WOgLPrq87PbNWgIxS76dS5uvl/QXtHGakZmwTznIfcPXcKlQ==", 73 | "dev": true 74 | }, 75 | "@types/range-parser": { 76 | "version": "1.2.3", 77 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.3.tgz", 78 | "integrity": "sha512-ewFXqrQHlFsgc09MK5jP5iR7vumV/BYayNC6PgJO2LPe8vrnNFyjQjSppfEngITi0qvfKtzFvgKymGheFM9UOA==", 79 | "dev": true 80 | }, 81 | "@types/serve-static": { 82 | "version": "1.13.5", 83 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.5.tgz", 84 | "integrity": "sha512-6M64P58N+OXjU432WoLLBQxbA0LRGBCRm7aAGQJ+SMC1IMl0dgRVi9EFfoDcS2a7Xogygk/eGN94CfwU9UF7UQ==", 85 | "dev": true, 86 | "requires": { 87 | "@types/express-serve-static-core": "*", 88 | "@types/mime": "*" 89 | } 90 | }, 91 | "@types/socket.io": { 92 | "version": "2.1.11", 93 | "resolved": "https://registry.npmjs.org/@types/socket.io/-/socket.io-2.1.11.tgz", 94 | "integrity": "sha512-bVprmqPhJMLb9ZCm8g0Xy8kwBFRbnanOWSxzWkDkkIwxTvud5tKMfAJymXX6LQbizUKCS1yima7JM4BeLqjNqA==", 95 | "dev": true, 96 | "requires": { 97 | "@types/engine.io": "*", 98 | "@types/node": "*" 99 | } 100 | }, 101 | "accepts": { 102 | "version": "1.3.7", 103 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 104 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 105 | "requires": { 106 | "mime-types": "~2.1.24", 107 | "negotiator": "0.6.2" 108 | } 109 | }, 110 | "after": { 111 | "version": "0.8.2", 112 | "resolved": "https://registry.npmjs.org/after/-/after-0.8.2.tgz", 113 | "integrity": "sha1-/ts5T58OAqqXaOcCvaI7UF+ufh8=" 114 | }, 115 | "ajv": { 116 | "version": "6.12.4", 117 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.4.tgz", 118 | "integrity": "sha512-eienB2c9qVQs2KWexhkrdMLVDoIQCz5KSeLxwg9Lzk4DOfBtIK9PQwwufcsn1jjGuf9WZmqPMbGxOzfcuphJCQ==", 119 | "optional": true, 120 | "requires": { 121 | "fast-deep-equal": "^3.1.1", 122 | "fast-json-stable-stringify": "^2.0.0", 123 | "json-schema-traverse": "^0.4.1", 124 | "uri-js": "^4.2.2" 125 | } 126 | }, 127 | "arg": { 128 | "version": "4.1.3", 129 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 130 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 131 | "dev": true 132 | }, 133 | "array-find-index": { 134 | "version": "1.0.2", 135 | "resolved": "https://registry.npmjs.org/array-find-index/-/array-find-index-1.0.2.tgz", 136 | "integrity": "sha1-3wEKoSh+Fku9pvlyOwqWoexBh6E=", 137 | "optional": true 138 | }, 139 | "array-flatten": { 140 | "version": "1.1.1", 141 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 142 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 143 | }, 144 | "arraybuffer.slice": { 145 | "version": "0.0.7", 146 | "resolved": "https://registry.npmjs.org/arraybuffer.slice/-/arraybuffer.slice-0.0.7.tgz", 147 | "integrity": "sha512-wGUIVQXuehL5TCqQun8OW81jGzAWycqzFF8lFp+GOM5BXLYj3bKNsYC4daB7n6XjCqxQA/qgTJ+8ANR3acjrog==" 148 | }, 149 | "asn1": { 150 | "version": "0.2.4", 151 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 152 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 153 | "optional": true, 154 | "requires": { 155 | "safer-buffer": "~2.1.0" 156 | } 157 | }, 158 | "assert-plus": { 159 | "version": "1.0.0", 160 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 161 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 162 | "optional": true 163 | }, 164 | "async-limiter": { 165 | "version": "1.0.1", 166 | "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", 167 | "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==" 168 | }, 169 | "asynckit": { 170 | "version": "0.4.0", 171 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 172 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 173 | "optional": true 174 | }, 175 | "awaitqueue": { 176 | "version": "2.2.3", 177 | "resolved": "https://registry.npmjs.org/awaitqueue/-/awaitqueue-2.2.3.tgz", 178 | "integrity": "sha512-vKY8hHHt1FT05UBxaTKWoA8+A3APnyzcOO1UBY5wQ7ENzXCFi3Yy4wSKsqrO0ncDD/5CI6IZDN1nVZQKziWIqg==" 179 | }, 180 | "aws-sign2": { 181 | "version": "0.7.0", 182 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 183 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 184 | "optional": true 185 | }, 186 | "aws4": { 187 | "version": "1.10.1", 188 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.10.1.tgz", 189 | "integrity": "sha512-zg7Hz2k5lI8kb7U32998pRRFin7zJlkfezGJjUc2heaD4Pw2wObakCDVzkKztTm/Ln7eiVvYsjqak0Ed4LkMDA==", 190 | "optional": true 191 | }, 192 | "backo2": { 193 | "version": "1.0.2", 194 | "resolved": "https://registry.npmjs.org/backo2/-/backo2-1.0.2.tgz", 195 | "integrity": "sha1-MasayLEpNjRj41s+u2n038+6eUc=" 196 | }, 197 | "base64-arraybuffer": { 198 | "version": "0.1.5", 199 | "resolved": "https://registry.npmjs.org/base64-arraybuffer/-/base64-arraybuffer-0.1.5.tgz", 200 | "integrity": "sha1-c5JncZI7Whl0etZmqlzUv5xunOg=" 201 | }, 202 | "base64id": { 203 | "version": "2.0.0", 204 | "resolved": "https://registry.npmjs.org/base64id/-/base64id-2.0.0.tgz", 205 | "integrity": "sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog==" 206 | }, 207 | "bcrypt-pbkdf": { 208 | "version": "1.0.2", 209 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 210 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 211 | "optional": true, 212 | "requires": { 213 | "tweetnacl": "^0.14.3" 214 | } 215 | }, 216 | "better-assert": { 217 | "version": "1.0.2", 218 | "resolved": "https://registry.npmjs.org/better-assert/-/better-assert-1.0.2.tgz", 219 | "integrity": "sha1-QIZrnhueC1W0gYlDEeaPr/rrxSI=", 220 | "requires": { 221 | "callsite": "1.0.0" 222 | } 223 | }, 224 | "blob": { 225 | "version": "0.0.5", 226 | "resolved": "https://registry.npmjs.org/blob/-/blob-0.0.5.tgz", 227 | "integrity": "sha512-gaqbzQPqOoamawKg0LGVd7SzLgXS+JH61oWprSLH+P+abTczqJbhTR8CmJ2u9/bUYNmHTGJx/UEmn6doAvvuig==" 228 | }, 229 | "body-parser": { 230 | "version": "1.19.0", 231 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 232 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 233 | "requires": { 234 | "bytes": "3.1.0", 235 | "content-type": "~1.0.4", 236 | "debug": "2.6.9", 237 | "depd": "~1.1.2", 238 | "http-errors": "1.7.2", 239 | "iconv-lite": "0.4.24", 240 | "on-finished": "~2.3.0", 241 | "qs": "6.7.0", 242 | "raw-body": "2.4.0", 243 | "type-is": "~1.6.17" 244 | }, 245 | "dependencies": { 246 | "debug": { 247 | "version": "2.6.9", 248 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 249 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 250 | "requires": { 251 | "ms": "2.0.0" 252 | } 253 | }, 254 | "qs": { 255 | "version": "6.7.0", 256 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 257 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 258 | } 259 | } 260 | }, 261 | "buffer-from": { 262 | "version": "1.1.1", 263 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 264 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 265 | "dev": true 266 | }, 267 | "bytes": { 268 | "version": "3.1.0", 269 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 270 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 271 | }, 272 | "callsite": { 273 | "version": "1.0.0", 274 | "resolved": "https://registry.npmjs.org/callsite/-/callsite-1.0.0.tgz", 275 | "integrity": "sha1-KAOY5dZkvXQDi28JBRU+borxvCA=" 276 | }, 277 | "camelcase": { 278 | "version": "2.1.1", 279 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-2.1.1.tgz", 280 | "integrity": "sha1-fB0W1nmhu+WcoCys7PsBHiAfWh8=", 281 | "optional": true 282 | }, 283 | "camelcase-keys": { 284 | "version": "2.1.0", 285 | "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-2.1.0.tgz", 286 | "integrity": "sha1-MIvur/3ygRkFHvodkyITyRuPkuc=", 287 | "optional": true, 288 | "requires": { 289 | "camelcase": "^2.0.0", 290 | "map-obj": "^1.0.0" 291 | } 292 | }, 293 | "caseless": { 294 | "version": "0.12.0", 295 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 296 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", 297 | "optional": true 298 | }, 299 | "clang-tools-prebuilt": { 300 | "version": "0.1.4", 301 | "resolved": "https://registry.npmjs.org/clang-tools-prebuilt/-/clang-tools-prebuilt-0.1.4.tgz", 302 | "integrity": "sha1-8gINNlN2CMDPrQeuvglNmXMFkLM=", 303 | "optional": true, 304 | "requires": { 305 | "home-path": "^0.1.1", 306 | "mkdirp": "^0.5.0", 307 | "nugget": "^1.5.1", 308 | "path-exists": "^1.0.0" 309 | } 310 | }, 311 | "combined-stream": { 312 | "version": "1.0.8", 313 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 314 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 315 | "optional": true, 316 | "requires": { 317 | "delayed-stream": "~1.0.0" 318 | } 319 | }, 320 | "component-bind": { 321 | "version": "1.0.0", 322 | "resolved": "https://registry.npmjs.org/component-bind/-/component-bind-1.0.0.tgz", 323 | "integrity": "sha1-AMYIq33Nk4l8AAllGx06jh5zu9E=" 324 | }, 325 | "component-emitter": { 326 | "version": "1.2.1", 327 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", 328 | "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=" 329 | }, 330 | "component-inherit": { 331 | "version": "0.0.3", 332 | "resolved": "https://registry.npmjs.org/component-inherit/-/component-inherit-0.0.3.tgz", 333 | "integrity": "sha1-ZF/ErfWLcrZJ1crmUTVhnbJv8UM=" 334 | }, 335 | "content-disposition": { 336 | "version": "0.5.3", 337 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 338 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 339 | "requires": { 340 | "safe-buffer": "5.1.2" 341 | }, 342 | "dependencies": { 343 | "safe-buffer": { 344 | "version": "5.1.2", 345 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 346 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 347 | } 348 | } 349 | }, 350 | "content-type": { 351 | "version": "1.0.4", 352 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 353 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 354 | }, 355 | "cookie": { 356 | "version": "0.4.0", 357 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 358 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 359 | }, 360 | "cookie-signature": { 361 | "version": "1.0.6", 362 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 363 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 364 | }, 365 | "core-util-is": { 366 | "version": "1.0.2", 367 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 368 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 369 | "optional": true 370 | }, 371 | "currently-unhandled": { 372 | "version": "0.4.1", 373 | "resolved": "https://registry.npmjs.org/currently-unhandled/-/currently-unhandled-0.4.1.tgz", 374 | "integrity": "sha1-mI3zP+qxke95mmE2nddsF635V+o=", 375 | "optional": true, 376 | "requires": { 377 | "array-find-index": "^1.0.1" 378 | } 379 | }, 380 | "dashdash": { 381 | "version": "1.14.1", 382 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 383 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 384 | "optional": true, 385 | "requires": { 386 | "assert-plus": "^1.0.0" 387 | } 388 | }, 389 | "debug": { 390 | "version": "4.1.1", 391 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 392 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 393 | "requires": { 394 | "ms": "^2.1.1" 395 | }, 396 | "dependencies": { 397 | "ms": { 398 | "version": "2.1.2", 399 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 400 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 401 | } 402 | } 403 | }, 404 | "decamelize": { 405 | "version": "1.2.0", 406 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 407 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 408 | "optional": true 409 | }, 410 | "delayed-stream": { 411 | "version": "1.0.0", 412 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 413 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 414 | "optional": true 415 | }, 416 | "depd": { 417 | "version": "1.1.2", 418 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 419 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 420 | }, 421 | "destroy": { 422 | "version": "1.0.4", 423 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 424 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 425 | }, 426 | "diff": { 427 | "version": "4.0.2", 428 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 429 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 430 | "dev": true 431 | }, 432 | "ecc-jsbn": { 433 | "version": "0.1.2", 434 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 435 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 436 | "optional": true, 437 | "requires": { 438 | "jsbn": "~0.1.0", 439 | "safer-buffer": "^2.1.0" 440 | } 441 | }, 442 | "ee-first": { 443 | "version": "1.1.1", 444 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 445 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 446 | }, 447 | "encodeurl": { 448 | "version": "1.0.2", 449 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 450 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 451 | }, 452 | "engine.io": { 453 | "version": "3.4.2", 454 | "resolved": "https://registry.npmjs.org/engine.io/-/engine.io-3.4.2.tgz", 455 | "integrity": "sha512-b4Q85dFkGw+TqgytGPrGgACRUhsdKc9S9ErRAXpPGy/CXKs4tYoHDkvIRdsseAF7NjfVwjRFIn6KTnbw7LwJZg==", 456 | "requires": { 457 | "accepts": "~1.3.4", 458 | "base64id": "2.0.0", 459 | "cookie": "0.3.1", 460 | "debug": "~4.1.0", 461 | "engine.io-parser": "~2.2.0", 462 | "ws": "^7.1.2" 463 | }, 464 | "dependencies": { 465 | "cookie": { 466 | "version": "0.3.1", 467 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 468 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=" 469 | } 470 | } 471 | }, 472 | "engine.io-client": { 473 | "version": "3.4.3", 474 | "resolved": "https://registry.npmjs.org/engine.io-client/-/engine.io-client-3.4.3.tgz", 475 | "integrity": "sha512-0NGY+9hioejTEJCaSJZfWZLk4FPI9dN+1H1C4+wj2iuFba47UgZbJzfWs4aNFajnX/qAaYKbe2lLTfEEWzCmcw==", 476 | "requires": { 477 | "component-emitter": "~1.3.0", 478 | "component-inherit": "0.0.3", 479 | "debug": "~4.1.0", 480 | "engine.io-parser": "~2.2.0", 481 | "has-cors": "1.1.0", 482 | "indexof": "0.0.1", 483 | "parseqs": "0.0.5", 484 | "parseuri": "0.0.5", 485 | "ws": "~6.1.0", 486 | "xmlhttprequest-ssl": "~1.5.4", 487 | "yeast": "0.1.2" 488 | }, 489 | "dependencies": { 490 | "component-emitter": { 491 | "version": "1.3.0", 492 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", 493 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==" 494 | }, 495 | "ws": { 496 | "version": "6.1.4", 497 | "resolved": "https://registry.npmjs.org/ws/-/ws-6.1.4.tgz", 498 | "integrity": "sha512-eqZfL+NE/YQc1/ZynhojeV8q+H050oR8AZ2uIev7RU10svA9ZnJUddHcOUZTJLinZ9yEfdA2kSATS2qZK5fhJA==", 499 | "requires": { 500 | "async-limiter": "~1.0.0" 501 | } 502 | } 503 | } 504 | }, 505 | "engine.io-parser": { 506 | "version": "2.2.0", 507 | "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-2.2.0.tgz", 508 | "integrity": "sha512-6I3qD9iUxotsC5HEMuuGsKA0cXerGz+4uGcXQEkfBidgKf0amsjrrtwcbwK/nzpZBxclXlV7gGl9dgWvu4LF6w==", 509 | "requires": { 510 | "after": "0.8.2", 511 | "arraybuffer.slice": "~0.0.7", 512 | "base64-arraybuffer": "0.1.5", 513 | "blob": "0.0.5", 514 | "has-binary2": "~1.0.2" 515 | } 516 | }, 517 | "error-ex": { 518 | "version": "1.3.2", 519 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 520 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 521 | "optional": true, 522 | "requires": { 523 | "is-arrayish": "^0.2.1" 524 | } 525 | }, 526 | "escape-html": { 527 | "version": "1.0.3", 528 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 529 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 530 | }, 531 | "etag": { 532 | "version": "1.8.1", 533 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 534 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 535 | }, 536 | "express": { 537 | "version": "4.17.1", 538 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 539 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 540 | "requires": { 541 | "accepts": "~1.3.7", 542 | "array-flatten": "1.1.1", 543 | "body-parser": "1.19.0", 544 | "content-disposition": "0.5.3", 545 | "content-type": "~1.0.4", 546 | "cookie": "0.4.0", 547 | "cookie-signature": "1.0.6", 548 | "debug": "2.6.9", 549 | "depd": "~1.1.2", 550 | "encodeurl": "~1.0.2", 551 | "escape-html": "~1.0.3", 552 | "etag": "~1.8.1", 553 | "finalhandler": "~1.1.2", 554 | "fresh": "0.5.2", 555 | "merge-descriptors": "1.0.1", 556 | "methods": "~1.1.2", 557 | "on-finished": "~2.3.0", 558 | "parseurl": "~1.3.3", 559 | "path-to-regexp": "0.1.7", 560 | "proxy-addr": "~2.0.5", 561 | "qs": "6.7.0", 562 | "range-parser": "~1.2.1", 563 | "safe-buffer": "5.1.2", 564 | "send": "0.17.1", 565 | "serve-static": "1.14.1", 566 | "setprototypeof": "1.1.1", 567 | "statuses": "~1.5.0", 568 | "type-is": "~1.6.18", 569 | "utils-merge": "1.0.1", 570 | "vary": "~1.1.2" 571 | }, 572 | "dependencies": { 573 | "debug": { 574 | "version": "2.6.9", 575 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 576 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 577 | "requires": { 578 | "ms": "2.0.0" 579 | } 580 | }, 581 | "qs": { 582 | "version": "6.7.0", 583 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 584 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 585 | }, 586 | "safe-buffer": { 587 | "version": "5.1.2", 588 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 589 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 590 | } 591 | } 592 | }, 593 | "extend": { 594 | "version": "3.0.2", 595 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 596 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 597 | "optional": true 598 | }, 599 | "extsprintf": { 600 | "version": "1.3.0", 601 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 602 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 603 | "optional": true 604 | }, 605 | "fast-deep-equal": { 606 | "version": "3.1.3", 607 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 608 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 609 | "optional": true 610 | }, 611 | "fast-json-stable-stringify": { 612 | "version": "2.1.0", 613 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 614 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 615 | "optional": true 616 | }, 617 | "finalhandler": { 618 | "version": "1.1.2", 619 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 620 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 621 | "requires": { 622 | "debug": "2.6.9", 623 | "encodeurl": "~1.0.2", 624 | "escape-html": "~1.0.3", 625 | "on-finished": "~2.3.0", 626 | "parseurl": "~1.3.3", 627 | "statuses": "~1.5.0", 628 | "unpipe": "~1.0.0" 629 | }, 630 | "dependencies": { 631 | "debug": { 632 | "version": "2.6.9", 633 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 634 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 635 | "requires": { 636 | "ms": "2.0.0" 637 | } 638 | } 639 | } 640 | }, 641 | "find-up": { 642 | "version": "1.1.2", 643 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", 644 | "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", 645 | "optional": true, 646 | "requires": { 647 | "path-exists": "^2.0.0", 648 | "pinkie-promise": "^2.0.0" 649 | }, 650 | "dependencies": { 651 | "path-exists": { 652 | "version": "2.1.0", 653 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", 654 | "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", 655 | "optional": true, 656 | "requires": { 657 | "pinkie-promise": "^2.0.0" 658 | } 659 | } 660 | } 661 | }, 662 | "forever-agent": { 663 | "version": "0.6.1", 664 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 665 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 666 | "optional": true 667 | }, 668 | "form-data": { 669 | "version": "2.3.3", 670 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 671 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 672 | "optional": true, 673 | "requires": { 674 | "asynckit": "^0.4.0", 675 | "combined-stream": "^1.0.6", 676 | "mime-types": "^2.1.12" 677 | } 678 | }, 679 | "forwarded": { 680 | "version": "0.1.2", 681 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 682 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 683 | }, 684 | "fresh": { 685 | "version": "0.5.2", 686 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 687 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 688 | }, 689 | "get-stdin": { 690 | "version": "4.0.1", 691 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-4.0.1.tgz", 692 | "integrity": "sha1-uWjGsKBDhDJJAui/Gl3zJXmkUP4=", 693 | "optional": true 694 | }, 695 | "getpass": { 696 | "version": "0.1.7", 697 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 698 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 699 | "optional": true, 700 | "requires": { 701 | "assert-plus": "^1.0.0" 702 | } 703 | }, 704 | "graceful-fs": { 705 | "version": "4.2.4", 706 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 707 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==", 708 | "optional": true 709 | }, 710 | "h264-profile-level-id": { 711 | "version": "1.0.1", 712 | "resolved": "https://registry.npmjs.org/h264-profile-level-id/-/h264-profile-level-id-1.0.1.tgz", 713 | "integrity": "sha512-D3Rln/jKNjKDW5ZTJTK3niSoOGE+pFqPvRHHVgQN3G7umcn/zWGPUo8Q8VpDj16x3hKz++zVviRNRmXu5cpN+Q==", 714 | "requires": { 715 | "debug": "^4.1.1" 716 | } 717 | }, 718 | "har-schema": { 719 | "version": "2.0.0", 720 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 721 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 722 | "optional": true 723 | }, 724 | "har-validator": { 725 | "version": "5.1.5", 726 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.5.tgz", 727 | "integrity": "sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w==", 728 | "optional": true, 729 | "requires": { 730 | "ajv": "^6.12.3", 731 | "har-schema": "^2.0.0" 732 | } 733 | }, 734 | "has-binary2": { 735 | "version": "1.0.3", 736 | "resolved": "https://registry.npmjs.org/has-binary2/-/has-binary2-1.0.3.tgz", 737 | "integrity": "sha512-G1LWKhDSvhGeAQ8mPVQlqNcOB2sJdwATtZKl2pDKKHfpf/rYj24lkinxf69blJbnsvtqqNU+L3SL50vzZhXOnw==", 738 | "requires": { 739 | "isarray": "2.0.1" 740 | }, 741 | "dependencies": { 742 | "isarray": { 743 | "version": "2.0.1", 744 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.1.tgz", 745 | "integrity": "sha1-o32U7ZzaLVmGXJ92/llu4fM4dB4=" 746 | } 747 | } 748 | }, 749 | "has-cors": { 750 | "version": "1.1.0", 751 | "resolved": "https://registry.npmjs.org/has-cors/-/has-cors-1.1.0.tgz", 752 | "integrity": "sha1-XkdHk/fqmEPRu5nCPu9J/xJv/zk=" 753 | }, 754 | "has-flag": { 755 | "version": "4.0.0", 756 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 757 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" 758 | }, 759 | "home-path": { 760 | "version": "0.1.2", 761 | "resolved": "https://registry.npmjs.org/home-path/-/home-path-0.1.2.tgz", 762 | "integrity": "sha1-PbJsojrcFE/uqPHi18j2yJDL/io=", 763 | "optional": true 764 | }, 765 | "hosted-git-info": { 766 | "version": "2.8.8", 767 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.8.tgz", 768 | "integrity": "sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg==", 769 | "optional": true 770 | }, 771 | "http-errors": { 772 | "version": "1.7.2", 773 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 774 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 775 | "requires": { 776 | "depd": "~1.1.2", 777 | "inherits": "2.0.3", 778 | "setprototypeof": "1.1.1", 779 | "statuses": ">= 1.5.0 < 2", 780 | "toidentifier": "1.0.0" 781 | }, 782 | "dependencies": { 783 | "inherits": { 784 | "version": "2.0.3", 785 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 786 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 787 | } 788 | } 789 | }, 790 | "http-signature": { 791 | "version": "1.2.0", 792 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 793 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 794 | "optional": true, 795 | "requires": { 796 | "assert-plus": "^1.0.0", 797 | "jsprim": "^1.2.2", 798 | "sshpk": "^1.7.0" 799 | } 800 | }, 801 | "iconv-lite": { 802 | "version": "0.4.24", 803 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 804 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 805 | "requires": { 806 | "safer-buffer": ">= 2.1.2 < 3" 807 | } 808 | }, 809 | "indent-string": { 810 | "version": "2.1.0", 811 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-2.1.0.tgz", 812 | "integrity": "sha1-ji1INIdCEhtKghi3oTfppSBJ3IA=", 813 | "optional": true, 814 | "requires": { 815 | "repeating": "^2.0.0" 816 | } 817 | }, 818 | "indexof": { 819 | "version": "0.0.1", 820 | "resolved": "https://registry.npmjs.org/indexof/-/indexof-0.0.1.tgz", 821 | "integrity": "sha1-gtwzbSMrkGIXnQWrMpOmYFn9Q10=" 822 | }, 823 | "inherits": { 824 | "version": "2.0.4", 825 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 826 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 827 | "optional": true 828 | }, 829 | "ipaddr.js": { 830 | "version": "1.9.1", 831 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 832 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 833 | }, 834 | "is-arrayish": { 835 | "version": "0.2.1", 836 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 837 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 838 | "optional": true 839 | }, 840 | "is-finite": { 841 | "version": "1.1.0", 842 | "resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.1.0.tgz", 843 | "integrity": "sha512-cdyMtqX/BOqqNBBiKlIVkytNHm49MtMlYyn1zxzvJKWmFMlGzm+ry5BBfYyeY9YmNKbRSo/o7OX9w9ale0wg3w==", 844 | "optional": true 845 | }, 846 | "is-typedarray": { 847 | "version": "1.0.0", 848 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 849 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 850 | "optional": true 851 | }, 852 | "is-utf8": { 853 | "version": "0.2.1", 854 | "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", 855 | "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=", 856 | "optional": true 857 | }, 858 | "isarray": { 859 | "version": "0.0.1", 860 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 861 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 862 | "optional": true 863 | }, 864 | "isstream": { 865 | "version": "0.1.2", 866 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 867 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", 868 | "optional": true 869 | }, 870 | "jsbn": { 871 | "version": "0.1.1", 872 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 873 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 874 | "optional": true 875 | }, 876 | "json-schema": { 877 | "version": "0.2.3", 878 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 879 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", 880 | "optional": true 881 | }, 882 | "json-schema-traverse": { 883 | "version": "0.4.1", 884 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 885 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 886 | "optional": true 887 | }, 888 | "json-stringify-safe": { 889 | "version": "5.0.1", 890 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 891 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", 892 | "optional": true 893 | }, 894 | "jsprim": { 895 | "version": "1.4.1", 896 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 897 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 898 | "optional": true, 899 | "requires": { 900 | "assert-plus": "1.0.0", 901 | "extsprintf": "1.3.0", 902 | "json-schema": "0.2.3", 903 | "verror": "1.10.0" 904 | } 905 | }, 906 | "load-json-file": { 907 | "version": "1.1.0", 908 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz", 909 | "integrity": "sha1-lWkFcI1YtLq0wiYbBPWfMcmTdMA=", 910 | "optional": true, 911 | "requires": { 912 | "graceful-fs": "^4.1.2", 913 | "parse-json": "^2.2.0", 914 | "pify": "^2.0.0", 915 | "pinkie-promise": "^2.0.0", 916 | "strip-bom": "^2.0.0" 917 | } 918 | }, 919 | "loud-rejection": { 920 | "version": "1.6.0", 921 | "resolved": "https://registry.npmjs.org/loud-rejection/-/loud-rejection-1.6.0.tgz", 922 | "integrity": "sha1-W0b4AUft7leIcPCG0Eghz5mOVR8=", 923 | "optional": true, 924 | "requires": { 925 | "currently-unhandled": "^0.4.1", 926 | "signal-exit": "^3.0.0" 927 | } 928 | }, 929 | "make-error": { 930 | "version": "1.3.6", 931 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 932 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 933 | "dev": true 934 | }, 935 | "map-obj": { 936 | "version": "1.0.1", 937 | "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-1.0.1.tgz", 938 | "integrity": "sha1-2TPOuSBdgr3PSIb2dCvcK03qFG0=", 939 | "optional": true 940 | }, 941 | "media-typer": { 942 | "version": "0.3.0", 943 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 944 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 945 | }, 946 | "mediasoup": { 947 | "version": "3.6.20", 948 | "resolved": "https://registry.npmjs.org/mediasoup/-/mediasoup-3.6.20.tgz", 949 | "integrity": "sha512-ZZ5Z7neFzGc7rXR0aL5VSAuiHDnkPCWr5eIr+14GOu15QFDjmdPuJ3mYb4sjjO48VGKyfJd4UxWmtsEBf8mFCg==", 950 | "requires": { 951 | "@types/node": "^14.10.0", 952 | "awaitqueue": "^2.2.3", 953 | "clang-tools-prebuilt": "^0.1.4", 954 | "debug": "^4.1.1", 955 | "h264-profile-level-id": "^1.0.1", 956 | "netstring": "^0.3.0", 957 | "random-number": "^0.0.9", 958 | "supports-color": "^7.2.0", 959 | "uuid": "^8.3.0" 960 | } 961 | }, 962 | "meow": { 963 | "version": "3.7.0", 964 | "resolved": "https://registry.npmjs.org/meow/-/meow-3.7.0.tgz", 965 | "integrity": "sha1-cstmi0JSKCkKu/qFaJJYcwioAfs=", 966 | "optional": true, 967 | "requires": { 968 | "camelcase-keys": "^2.0.0", 969 | "decamelize": "^1.1.2", 970 | "loud-rejection": "^1.0.0", 971 | "map-obj": "^1.0.1", 972 | "minimist": "^1.1.3", 973 | "normalize-package-data": "^2.3.4", 974 | "object-assign": "^4.0.1", 975 | "read-pkg-up": "^1.0.1", 976 | "redent": "^1.0.0", 977 | "trim-newlines": "^1.0.0" 978 | } 979 | }, 980 | "merge-descriptors": { 981 | "version": "1.0.1", 982 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 983 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 984 | }, 985 | "methods": { 986 | "version": "1.1.2", 987 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 988 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 989 | }, 990 | "mime": { 991 | "version": "1.6.0", 992 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 993 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 994 | }, 995 | "mime-db": { 996 | "version": "1.44.0", 997 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.44.0.tgz", 998 | "integrity": "sha512-/NOTfLrsPBVeH7YtFPgsVWveuL+4SjjYxaQ1xtM1KMFj7HdxlBlxeyNLzhyJVx7r4rZGJAZ/6lkKCitSc/Nmpg==" 999 | }, 1000 | "mime-types": { 1001 | "version": "2.1.27", 1002 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.27.tgz", 1003 | "integrity": "sha512-JIhqnCasI9yD+SsmkquHBxTSEuZdQX5BuQnS2Vc7puQQQ+8yiP5AY5uWhpdv4YL4VM5c6iliiYWPgJ/nJQLp7w==", 1004 | "requires": { 1005 | "mime-db": "1.44.0" 1006 | } 1007 | }, 1008 | "minimist": { 1009 | "version": "1.2.5", 1010 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1011 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1012 | "optional": true 1013 | }, 1014 | "mkdirp": { 1015 | "version": "0.5.5", 1016 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1017 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1018 | "optional": true, 1019 | "requires": { 1020 | "minimist": "^1.2.5" 1021 | } 1022 | }, 1023 | "ms": { 1024 | "version": "2.0.0", 1025 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1026 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1027 | }, 1028 | "negotiator": { 1029 | "version": "0.6.2", 1030 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 1031 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 1032 | }, 1033 | "netstring": { 1034 | "version": "0.3.0", 1035 | "resolved": "https://registry.npmjs.org/netstring/-/netstring-0.3.0.tgz", 1036 | "integrity": "sha1-ho3FsgxY0/cwVTHUk2jqqr0ZtxI=" 1037 | }, 1038 | "normalize-package-data": { 1039 | "version": "2.5.0", 1040 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1041 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1042 | "optional": true, 1043 | "requires": { 1044 | "hosted-git-info": "^2.1.4", 1045 | "resolve": "^1.10.0", 1046 | "semver": "2 || 3 || 4 || 5", 1047 | "validate-npm-package-license": "^3.0.1" 1048 | } 1049 | }, 1050 | "nugget": { 1051 | "version": "1.6.2", 1052 | "resolved": "https://registry.npmjs.org/nugget/-/nugget-1.6.2.tgz", 1053 | "integrity": "sha1-iMpuA7pXBqmRc/XaCQJZPWvK4Qc=", 1054 | "optional": true, 1055 | "requires": { 1056 | "debug": "^2.1.3", 1057 | "minimist": "^1.1.0", 1058 | "pretty-bytes": "^1.0.2", 1059 | "progress-stream": "^1.1.0", 1060 | "request": "^2.45.0", 1061 | "single-line-log": "^0.4.1", 1062 | "throttleit": "0.0.2" 1063 | }, 1064 | "dependencies": { 1065 | "debug": { 1066 | "version": "2.6.9", 1067 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1068 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1069 | "optional": true, 1070 | "requires": { 1071 | "ms": "2.0.0" 1072 | } 1073 | } 1074 | } 1075 | }, 1076 | "oauth-sign": { 1077 | "version": "0.9.0", 1078 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 1079 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", 1080 | "optional": true 1081 | }, 1082 | "object-assign": { 1083 | "version": "4.1.1", 1084 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1085 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1086 | "optional": true 1087 | }, 1088 | "object-component": { 1089 | "version": "0.0.3", 1090 | "resolved": "https://registry.npmjs.org/object-component/-/object-component-0.0.3.tgz", 1091 | "integrity": "sha1-8MaapQ78lbhmwYb0AKM3acsvEpE=" 1092 | }, 1093 | "object-keys": { 1094 | "version": "0.4.0", 1095 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-0.4.0.tgz", 1096 | "integrity": "sha1-KKaq50KN0sOpLz2V8hM13SBOAzY=", 1097 | "optional": true 1098 | }, 1099 | "on-finished": { 1100 | "version": "2.3.0", 1101 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1102 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1103 | "requires": { 1104 | "ee-first": "1.1.1" 1105 | } 1106 | }, 1107 | "parse-json": { 1108 | "version": "2.2.0", 1109 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 1110 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 1111 | "optional": true, 1112 | "requires": { 1113 | "error-ex": "^1.2.0" 1114 | } 1115 | }, 1116 | "parseqs": { 1117 | "version": "0.0.5", 1118 | "resolved": "https://registry.npmjs.org/parseqs/-/parseqs-0.0.5.tgz", 1119 | "integrity": "sha1-1SCKNzjkZ2bikbouoXNoSSGouJ0=", 1120 | "requires": { 1121 | "better-assert": "~1.0.0" 1122 | } 1123 | }, 1124 | "parseuri": { 1125 | "version": "0.0.5", 1126 | "resolved": "https://registry.npmjs.org/parseuri/-/parseuri-0.0.5.tgz", 1127 | "integrity": "sha1-gCBKUNTbt3m/3G6+J3jZDkvOMgo=", 1128 | "requires": { 1129 | "better-assert": "~1.0.0" 1130 | } 1131 | }, 1132 | "parseurl": { 1133 | "version": "1.3.3", 1134 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1135 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 1136 | }, 1137 | "path-exists": { 1138 | "version": "1.0.0", 1139 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-1.0.0.tgz", 1140 | "integrity": "sha1-1aiZjrce83p0w06w2eum6HjuoIE=", 1141 | "optional": true 1142 | }, 1143 | "path-parse": { 1144 | "version": "1.0.6", 1145 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1146 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 1147 | "optional": true 1148 | }, 1149 | "path-to-regexp": { 1150 | "version": "0.1.7", 1151 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1152 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1153 | }, 1154 | "path-type": { 1155 | "version": "1.1.0", 1156 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-1.1.0.tgz", 1157 | "integrity": "sha1-WcRPfuSR2nBNpBXaWkBwuk+P5EE=", 1158 | "optional": true, 1159 | "requires": { 1160 | "graceful-fs": "^4.1.2", 1161 | "pify": "^2.0.0", 1162 | "pinkie-promise": "^2.0.0" 1163 | } 1164 | }, 1165 | "performance-now": { 1166 | "version": "2.1.0", 1167 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 1168 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", 1169 | "optional": true 1170 | }, 1171 | "pify": { 1172 | "version": "2.3.0", 1173 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1174 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1175 | "optional": true 1176 | }, 1177 | "pinkie": { 1178 | "version": "2.0.4", 1179 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", 1180 | "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", 1181 | "optional": true 1182 | }, 1183 | "pinkie-promise": { 1184 | "version": "2.0.1", 1185 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", 1186 | "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", 1187 | "optional": true, 1188 | "requires": { 1189 | "pinkie": "^2.0.0" 1190 | } 1191 | }, 1192 | "pretty-bytes": { 1193 | "version": "1.0.4", 1194 | "resolved": "https://registry.npmjs.org/pretty-bytes/-/pretty-bytes-1.0.4.tgz", 1195 | "integrity": "sha1-CiLoIQYJrTVUL4yNXSFZr/B1HIQ=", 1196 | "optional": true, 1197 | "requires": { 1198 | "get-stdin": "^4.0.1", 1199 | "meow": "^3.1.0" 1200 | } 1201 | }, 1202 | "progress-stream": { 1203 | "version": "1.2.0", 1204 | "resolved": "https://registry.npmjs.org/progress-stream/-/progress-stream-1.2.0.tgz", 1205 | "integrity": "sha1-LNPP6jO6OonJwSHsM0er6asSX3c=", 1206 | "optional": true, 1207 | "requires": { 1208 | "speedometer": "~0.1.2", 1209 | "through2": "~0.2.3" 1210 | } 1211 | }, 1212 | "proxy-addr": { 1213 | "version": "2.0.6", 1214 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz", 1215 | "integrity": "sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw==", 1216 | "requires": { 1217 | "forwarded": "~0.1.2", 1218 | "ipaddr.js": "1.9.1" 1219 | } 1220 | }, 1221 | "psl": { 1222 | "version": "1.8.0", 1223 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz", 1224 | "integrity": "sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==", 1225 | "optional": true 1226 | }, 1227 | "punycode": { 1228 | "version": "2.1.1", 1229 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1230 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1231 | "optional": true 1232 | }, 1233 | "qs": { 1234 | "version": "6.5.2", 1235 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 1236 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", 1237 | "optional": true 1238 | }, 1239 | "random-number": { 1240 | "version": "0.0.9", 1241 | "resolved": "https://registry.npmjs.org/random-number/-/random-number-0.0.9.tgz", 1242 | "integrity": "sha512-ipG3kRCREi/YQpi2A5QGcvDz1KemohovWmH6qGfboVyyGdR2t/7zQz0vFxrfxpbHQgPPdtVlUDaks3aikD1Ljw==" 1243 | }, 1244 | "range-parser": { 1245 | "version": "1.2.1", 1246 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1247 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 1248 | }, 1249 | "raw-body": { 1250 | "version": "2.4.0", 1251 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 1252 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 1253 | "requires": { 1254 | "bytes": "3.1.0", 1255 | "http-errors": "1.7.2", 1256 | "iconv-lite": "0.4.24", 1257 | "unpipe": "1.0.0" 1258 | } 1259 | }, 1260 | "read-pkg": { 1261 | "version": "1.1.0", 1262 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-1.1.0.tgz", 1263 | "integrity": "sha1-9f+qXs0pyzHAR0vKfXVra7KePyg=", 1264 | "optional": true, 1265 | "requires": { 1266 | "load-json-file": "^1.0.0", 1267 | "normalize-package-data": "^2.3.2", 1268 | "path-type": "^1.0.0" 1269 | } 1270 | }, 1271 | "read-pkg-up": { 1272 | "version": "1.0.1", 1273 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-1.0.1.tgz", 1274 | "integrity": "sha1-nWPBMnbAZZGNV/ACpX9AobZD+wI=", 1275 | "optional": true, 1276 | "requires": { 1277 | "find-up": "^1.0.0", 1278 | "read-pkg": "^1.0.0" 1279 | } 1280 | }, 1281 | "readable-stream": { 1282 | "version": "1.1.14", 1283 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", 1284 | "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", 1285 | "optional": true, 1286 | "requires": { 1287 | "core-util-is": "~1.0.0", 1288 | "inherits": "~2.0.1", 1289 | "isarray": "0.0.1", 1290 | "string_decoder": "~0.10.x" 1291 | } 1292 | }, 1293 | "redent": { 1294 | "version": "1.0.0", 1295 | "resolved": "https://registry.npmjs.org/redent/-/redent-1.0.0.tgz", 1296 | "integrity": "sha1-z5Fqsf1fHxbfsggi3W7H9zDCr94=", 1297 | "optional": true, 1298 | "requires": { 1299 | "indent-string": "^2.1.0", 1300 | "strip-indent": "^1.0.1" 1301 | } 1302 | }, 1303 | "repeating": { 1304 | "version": "2.0.1", 1305 | "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz", 1306 | "integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=", 1307 | "optional": true, 1308 | "requires": { 1309 | "is-finite": "^1.0.0" 1310 | } 1311 | }, 1312 | "request": { 1313 | "version": "2.88.2", 1314 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz", 1315 | "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==", 1316 | "optional": true, 1317 | "requires": { 1318 | "aws-sign2": "~0.7.0", 1319 | "aws4": "^1.8.0", 1320 | "caseless": "~0.12.0", 1321 | "combined-stream": "~1.0.6", 1322 | "extend": "~3.0.2", 1323 | "forever-agent": "~0.6.1", 1324 | "form-data": "~2.3.2", 1325 | "har-validator": "~5.1.3", 1326 | "http-signature": "~1.2.0", 1327 | "is-typedarray": "~1.0.0", 1328 | "isstream": "~0.1.2", 1329 | "json-stringify-safe": "~5.0.1", 1330 | "mime-types": "~2.1.19", 1331 | "oauth-sign": "~0.9.0", 1332 | "performance-now": "^2.1.0", 1333 | "qs": "~6.5.2", 1334 | "safe-buffer": "^5.1.2", 1335 | "tough-cookie": "~2.5.0", 1336 | "tunnel-agent": "^0.6.0", 1337 | "uuid": "^3.3.2" 1338 | }, 1339 | "dependencies": { 1340 | "uuid": { 1341 | "version": "3.4.0", 1342 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 1343 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", 1344 | "optional": true 1345 | } 1346 | } 1347 | }, 1348 | "resolve": { 1349 | "version": "1.17.0", 1350 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz", 1351 | "integrity": "sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==", 1352 | "optional": true, 1353 | "requires": { 1354 | "path-parse": "^1.0.6" 1355 | } 1356 | }, 1357 | "safe-buffer": { 1358 | "version": "5.2.1", 1359 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1360 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1361 | "optional": true 1362 | }, 1363 | "safer-buffer": { 1364 | "version": "2.1.2", 1365 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1366 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1367 | }, 1368 | "semver": { 1369 | "version": "5.7.1", 1370 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1371 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1372 | "optional": true 1373 | }, 1374 | "send": { 1375 | "version": "0.17.1", 1376 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 1377 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 1378 | "requires": { 1379 | "debug": "2.6.9", 1380 | "depd": "~1.1.2", 1381 | "destroy": "~1.0.4", 1382 | "encodeurl": "~1.0.2", 1383 | "escape-html": "~1.0.3", 1384 | "etag": "~1.8.1", 1385 | "fresh": "0.5.2", 1386 | "http-errors": "~1.7.2", 1387 | "mime": "1.6.0", 1388 | "ms": "2.1.1", 1389 | "on-finished": "~2.3.0", 1390 | "range-parser": "~1.2.1", 1391 | "statuses": "~1.5.0" 1392 | }, 1393 | "dependencies": { 1394 | "debug": { 1395 | "version": "2.6.9", 1396 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1397 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1398 | "requires": { 1399 | "ms": "2.0.0" 1400 | }, 1401 | "dependencies": { 1402 | "ms": { 1403 | "version": "2.0.0", 1404 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1405 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1406 | } 1407 | } 1408 | }, 1409 | "ms": { 1410 | "version": "2.1.1", 1411 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1412 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1413 | } 1414 | } 1415 | }, 1416 | "serve-static": { 1417 | "version": "1.14.1", 1418 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 1419 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 1420 | "requires": { 1421 | "encodeurl": "~1.0.2", 1422 | "escape-html": "~1.0.3", 1423 | "parseurl": "~1.3.3", 1424 | "send": "0.17.1" 1425 | } 1426 | }, 1427 | "setprototypeof": { 1428 | "version": "1.1.1", 1429 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 1430 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 1431 | }, 1432 | "signal-exit": { 1433 | "version": "3.0.3", 1434 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 1435 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 1436 | "optional": true 1437 | }, 1438 | "single-line-log": { 1439 | "version": "0.4.1", 1440 | "resolved": "https://registry.npmjs.org/single-line-log/-/single-line-log-0.4.1.tgz", 1441 | "integrity": "sha1-h6VWSfdJ14PsDc2AToFA2Yc8fO4=", 1442 | "optional": true 1443 | }, 1444 | "socket.io": { 1445 | "version": "2.3.0", 1446 | "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-2.3.0.tgz", 1447 | "integrity": "sha512-2A892lrj0GcgR/9Qk81EaY2gYhCBxurV0PfmmESO6p27QPrUK1J3zdns+5QPqvUYK2q657nSj0guoIil9+7eFg==", 1448 | "requires": { 1449 | "debug": "~4.1.0", 1450 | "engine.io": "~3.4.0", 1451 | "has-binary2": "~1.0.2", 1452 | "socket.io-adapter": "~1.1.0", 1453 | "socket.io-client": "2.3.0", 1454 | "socket.io-parser": "~3.4.0" 1455 | } 1456 | }, 1457 | "socket.io-adapter": { 1458 | "version": "1.1.2", 1459 | "resolved": "https://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-1.1.2.tgz", 1460 | "integrity": "sha512-WzZRUj1kUjrTIrUKpZLEzFZ1OLj5FwLlAFQs9kuZJzJi5DKdU7FsWc36SNmA8iDOtwBQyT8FkrriRM8vXLYz8g==" 1461 | }, 1462 | "socket.io-client": { 1463 | "version": "2.3.0", 1464 | "resolved": "https://registry.npmjs.org/socket.io-client/-/socket.io-client-2.3.0.tgz", 1465 | "integrity": "sha512-cEQQf24gET3rfhxZ2jJ5xzAOo/xhZwK+mOqtGRg5IowZsMgwvHwnf/mCRapAAkadhM26y+iydgwsXGObBB5ZdA==", 1466 | "requires": { 1467 | "backo2": "1.0.2", 1468 | "base64-arraybuffer": "0.1.5", 1469 | "component-bind": "1.0.0", 1470 | "component-emitter": "1.2.1", 1471 | "debug": "~4.1.0", 1472 | "engine.io-client": "~3.4.0", 1473 | "has-binary2": "~1.0.2", 1474 | "has-cors": "1.1.0", 1475 | "indexof": "0.0.1", 1476 | "object-component": "0.0.3", 1477 | "parseqs": "0.0.5", 1478 | "parseuri": "0.0.5", 1479 | "socket.io-parser": "~3.3.0", 1480 | "to-array": "0.1.4" 1481 | }, 1482 | "dependencies": { 1483 | "isarray": { 1484 | "version": "2.0.1", 1485 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.1.tgz", 1486 | "integrity": "sha1-o32U7ZzaLVmGXJ92/llu4fM4dB4=" 1487 | }, 1488 | "socket.io-parser": { 1489 | "version": "3.3.0", 1490 | "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-3.3.0.tgz", 1491 | "integrity": "sha512-hczmV6bDgdaEbVqhAeVMM/jfUfzuEZHsQg6eOmLgJht6G3mPKMxYm75w2+qhAQZ+4X+1+ATZ+QFKeOZD5riHng==", 1492 | "requires": { 1493 | "component-emitter": "1.2.1", 1494 | "debug": "~3.1.0", 1495 | "isarray": "2.0.1" 1496 | }, 1497 | "dependencies": { 1498 | "debug": { 1499 | "version": "3.1.0", 1500 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1501 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1502 | "requires": { 1503 | "ms": "2.0.0" 1504 | } 1505 | } 1506 | } 1507 | } 1508 | } 1509 | }, 1510 | "socket.io-parser": { 1511 | "version": "3.4.1", 1512 | "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-3.4.1.tgz", 1513 | "integrity": "sha512-11hMgzL+WCLWf1uFtHSNvliI++tcRUWdoeYuwIl+Axvwy9z2gQM+7nJyN3STj1tLj5JyIUH8/gpDGxzAlDdi0A==", 1514 | "requires": { 1515 | "component-emitter": "1.2.1", 1516 | "debug": "~4.1.0", 1517 | "isarray": "2.0.1" 1518 | }, 1519 | "dependencies": { 1520 | "isarray": { 1521 | "version": "2.0.1", 1522 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.1.tgz", 1523 | "integrity": "sha1-o32U7ZzaLVmGXJ92/llu4fM4dB4=" 1524 | } 1525 | } 1526 | }, 1527 | "source-map": { 1528 | "version": "0.6.1", 1529 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1530 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1531 | "dev": true 1532 | }, 1533 | "source-map-support": { 1534 | "version": "0.5.19", 1535 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.19.tgz", 1536 | "integrity": "sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw==", 1537 | "dev": true, 1538 | "requires": { 1539 | "buffer-from": "^1.0.0", 1540 | "source-map": "^0.6.0" 1541 | } 1542 | }, 1543 | "spdx-correct": { 1544 | "version": "3.1.1", 1545 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", 1546 | "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", 1547 | "optional": true, 1548 | "requires": { 1549 | "spdx-expression-parse": "^3.0.0", 1550 | "spdx-license-ids": "^3.0.0" 1551 | } 1552 | }, 1553 | "spdx-exceptions": { 1554 | "version": "2.3.0", 1555 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 1556 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", 1557 | "optional": true 1558 | }, 1559 | "spdx-expression-parse": { 1560 | "version": "3.0.1", 1561 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 1562 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 1563 | "optional": true, 1564 | "requires": { 1565 | "spdx-exceptions": "^2.1.0", 1566 | "spdx-license-ids": "^3.0.0" 1567 | } 1568 | }, 1569 | "spdx-license-ids": { 1570 | "version": "3.0.5", 1571 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz", 1572 | "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==", 1573 | "optional": true 1574 | }, 1575 | "speedometer": { 1576 | "version": "0.1.4", 1577 | "resolved": "https://registry.npmjs.org/speedometer/-/speedometer-0.1.4.tgz", 1578 | "integrity": "sha1-mHbb0qFp0xFUAtSObqYynIgWpQ0=", 1579 | "optional": true 1580 | }, 1581 | "sshpk": { 1582 | "version": "1.16.1", 1583 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", 1584 | "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", 1585 | "optional": true, 1586 | "requires": { 1587 | "asn1": "~0.2.3", 1588 | "assert-plus": "^1.0.0", 1589 | "bcrypt-pbkdf": "^1.0.0", 1590 | "dashdash": "^1.12.0", 1591 | "ecc-jsbn": "~0.1.1", 1592 | "getpass": "^0.1.1", 1593 | "jsbn": "~0.1.0", 1594 | "safer-buffer": "^2.0.2", 1595 | "tweetnacl": "~0.14.0" 1596 | } 1597 | }, 1598 | "statuses": { 1599 | "version": "1.5.0", 1600 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1601 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 1602 | }, 1603 | "string_decoder": { 1604 | "version": "0.10.31", 1605 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 1606 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", 1607 | "optional": true 1608 | }, 1609 | "strip-bom": { 1610 | "version": "2.0.0", 1611 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz", 1612 | "integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=", 1613 | "optional": true, 1614 | "requires": { 1615 | "is-utf8": "^0.2.0" 1616 | } 1617 | }, 1618 | "strip-indent": { 1619 | "version": "1.0.1", 1620 | "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-1.0.1.tgz", 1621 | "integrity": "sha1-DHlipq3vp7vUrDZkYKY4VSrhoKI=", 1622 | "optional": true, 1623 | "requires": { 1624 | "get-stdin": "^4.0.1" 1625 | } 1626 | }, 1627 | "supports-color": { 1628 | "version": "7.2.0", 1629 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1630 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1631 | "requires": { 1632 | "has-flag": "^4.0.0" 1633 | } 1634 | }, 1635 | "throttleit": { 1636 | "version": "0.0.2", 1637 | "resolved": "https://registry.npmjs.org/throttleit/-/throttleit-0.0.2.tgz", 1638 | "integrity": "sha1-z+34jmDADdlpe2H90qg0OptoDq8=", 1639 | "optional": true 1640 | }, 1641 | "through2": { 1642 | "version": "0.2.3", 1643 | "resolved": "https://registry.npmjs.org/through2/-/through2-0.2.3.tgz", 1644 | "integrity": "sha1-6zKE2k6jEbbMis42U3SKUqvyWj8=", 1645 | "optional": true, 1646 | "requires": { 1647 | "readable-stream": "~1.1.9", 1648 | "xtend": "~2.1.1" 1649 | } 1650 | }, 1651 | "to-array": { 1652 | "version": "0.1.4", 1653 | "resolved": "https://registry.npmjs.org/to-array/-/to-array-0.1.4.tgz", 1654 | "integrity": "sha1-F+bBH3PdTz10zaek/zI46a2b+JA=" 1655 | }, 1656 | "toidentifier": { 1657 | "version": "1.0.0", 1658 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 1659 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 1660 | }, 1661 | "tough-cookie": { 1662 | "version": "2.5.0", 1663 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", 1664 | "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", 1665 | "optional": true, 1666 | "requires": { 1667 | "psl": "^1.1.28", 1668 | "punycode": "^2.1.1" 1669 | } 1670 | }, 1671 | "trim-newlines": { 1672 | "version": "1.0.0", 1673 | "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-1.0.0.tgz", 1674 | "integrity": "sha1-WIeWa7WCpFA6QetST301ARgVphM=", 1675 | "optional": true 1676 | }, 1677 | "ts-node": { 1678 | "version": "9.0.0", 1679 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-9.0.0.tgz", 1680 | "integrity": "sha512-/TqB4SnererCDR/vb4S/QvSZvzQMJN8daAslg7MeaiHvD8rDZsSfXmNeNumyZZzMned72Xoq/isQljYSt8Ynfg==", 1681 | "dev": true, 1682 | "requires": { 1683 | "arg": "^4.1.0", 1684 | "diff": "^4.0.1", 1685 | "make-error": "^1.1.1", 1686 | "source-map-support": "^0.5.17", 1687 | "yn": "3.1.1" 1688 | } 1689 | }, 1690 | "tunnel-agent": { 1691 | "version": "0.6.0", 1692 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 1693 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 1694 | "optional": true, 1695 | "requires": { 1696 | "safe-buffer": "^5.0.1" 1697 | } 1698 | }, 1699 | "tweetnacl": { 1700 | "version": "0.14.5", 1701 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 1702 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 1703 | "optional": true 1704 | }, 1705 | "type-is": { 1706 | "version": "1.6.18", 1707 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1708 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1709 | "requires": { 1710 | "media-typer": "0.3.0", 1711 | "mime-types": "~2.1.24" 1712 | } 1713 | }, 1714 | "typescript": { 1715 | "version": "4.0.2", 1716 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.0.2.tgz", 1717 | "integrity": "sha512-e4ERvRV2wb+rRZ/IQeb3jm2VxBsirQLpQhdxplZ2MEzGvDkkMmPglecnNDfSUBivMjP93vRbngYYDQqQ/78bcQ==", 1718 | "dev": true 1719 | }, 1720 | "unpipe": { 1721 | "version": "1.0.0", 1722 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1723 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 1724 | }, 1725 | "uri-js": { 1726 | "version": "4.4.0", 1727 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.0.tgz", 1728 | "integrity": "sha512-B0yRTzYdUCCn9n+F4+Gh4yIDtMQcaJsmYBDsTSG8g/OejKBodLQ2IHfN3bM7jUsRXndopT7OIXWdYqc1fjmV6g==", 1729 | "optional": true, 1730 | "requires": { 1731 | "punycode": "^2.1.0" 1732 | } 1733 | }, 1734 | "utils-merge": { 1735 | "version": "1.0.1", 1736 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1737 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 1738 | }, 1739 | "uuid": { 1740 | "version": "8.3.0", 1741 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.0.tgz", 1742 | "integrity": "sha512-fX6Z5o4m6XsXBdli9g7DtWgAx+osMsRRZFKma1mIUsLCz6vRvv+pz5VNbyu9UEDzpMWulZfvpgb/cmDXVulYFQ==" 1743 | }, 1744 | "validate-npm-package-license": { 1745 | "version": "3.0.4", 1746 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 1747 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 1748 | "optional": true, 1749 | "requires": { 1750 | "spdx-correct": "^3.0.0", 1751 | "spdx-expression-parse": "^3.0.0" 1752 | } 1753 | }, 1754 | "vary": { 1755 | "version": "1.1.2", 1756 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1757 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 1758 | }, 1759 | "verror": { 1760 | "version": "1.10.0", 1761 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 1762 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 1763 | "optional": true, 1764 | "requires": { 1765 | "assert-plus": "^1.0.0", 1766 | "core-util-is": "1.0.2", 1767 | "extsprintf": "^1.2.0" 1768 | } 1769 | }, 1770 | "ws": { 1771 | "version": "7.3.1", 1772 | "resolved": "https://registry.npmjs.org/ws/-/ws-7.3.1.tgz", 1773 | "integrity": "sha512-D3RuNkynyHmEJIpD2qrgVkc9DQ23OrN/moAwZX4L8DfvszsJxpjQuUq3LMx6HoYji9fbIOBY18XWBsAux1ZZUA==" 1774 | }, 1775 | "xmlhttprequest-ssl": { 1776 | "version": "1.5.5", 1777 | "resolved": "https://registry.npmjs.org/xmlhttprequest-ssl/-/xmlhttprequest-ssl-1.5.5.tgz", 1778 | "integrity": "sha1-wodrBhaKrcQOV9l+gRkayPQ5iz4=" 1779 | }, 1780 | "xtend": { 1781 | "version": "2.1.2", 1782 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-2.1.2.tgz", 1783 | "integrity": "sha1-bv7MKk2tjmlixJAbM3znuoe10os=", 1784 | "optional": true, 1785 | "requires": { 1786 | "object-keys": "~0.4.0" 1787 | } 1788 | }, 1789 | "yeast": { 1790 | "version": "0.1.2", 1791 | "resolved": "https://registry.npmjs.org/yeast/-/yeast-0.1.2.tgz", 1792 | "integrity": "sha1-AI4G2AlDIMNy28L47XagymyKxBk=" 1793 | }, 1794 | "yn": { 1795 | "version": "3.1.1", 1796 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 1797 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 1798 | "dev": true 1799 | } 1800 | } 1801 | } 1802 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "rtmp-webrtc-adapter", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "build": "rm -rf dist/ && tsc", 8 | "start": "node dist/server.js" 9 | }, 10 | "author": "", 11 | "license": "ISC", 12 | "dependencies": { 13 | "express": "^4.17.1", 14 | "mediasoup": "^3.6.20", 15 | "socket.io": "^2.3.0" 16 | }, 17 | "devDependencies": { 18 | "@types/express": "^4.17.8", 19 | "@types/socket.io": "^2.1.11", 20 | "ts-node": "^9.0.0", 21 | "typescript": "^4.0.2" 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /src/server.ts: -------------------------------------------------------------------------------- 1 | import * as mediasoup from 'mediasoup'; 2 | import * as express from 'express'; 3 | import * as http from 'http'; 4 | import * as socketIO from 'socket.io'; 5 | import * as child_process from 'child_process'; 6 | 7 | interface Source { 8 | name: string; 9 | rtmpUrl: string; 10 | } 11 | 12 | const PORT = process.env.PORT || 3000; 13 | const RTC_MIN_PORT = Number(process.env.RTC_MIN_PORT || 30000); 14 | const RTC_MAX_PORT = Number(process.env.RTC_MAX_PORT || 31000); 15 | const RTC_LISTEN_IP = process.env.RTC_LISTEN_IP || '127.0.0.1'; 16 | const RTC_ANNOUNCED_IP = process.env.RTC_ANNOUNCED_IP || '0.0.0.0'; 17 | 18 | let expressApp: express.Express; 19 | let httpServer: http.Server; 20 | let socketServer: socketIO.Server; 21 | let webRtcWorker: mediasoup.types.Worker; 22 | let mediasoupRouter: mediasoup.types.Router; 23 | 24 | const consumerTransports = new Map(); 25 | const socketTransports = new Map(); 26 | const consumers = new Map(); 27 | const producerTransports = new Map(); 28 | const producers = new Map(); 29 | const sources: Source[] = []; 30 | 31 | function generateSSRC() { 32 | return Math.trunc(Math.random() * 10000); 33 | } 34 | 35 | (async () => { 36 | await runExpressApp(); 37 | await runSocketServer(); 38 | await runMediasoupWorker(); 39 | })(); 40 | 41 | async function runExpressApp() { 42 | expressApp = express(); 43 | expressApp.use(express.json()); 44 | 45 | httpServer = http.createServer(expressApp); 46 | return new Promise((resolve) => { 47 | httpServer.listen(PORT, () => { 48 | console.log(`server is running at https://localhost:${PORT}`); 49 | resolve(); 50 | }); 51 | }); 52 | } 53 | 54 | async function runSocketServer() { 55 | socketServer = socketIO(httpServer, { 56 | serveClient: false, 57 | path: '/server', 58 | }); 59 | socketServer.on('connection', (socket) => { 60 | console.log('client connected'); 61 | 62 | socket.on('disconnect', () => { 63 | console.log('client disconnected'); 64 | const transport = socketTransports.get(socket.id); 65 | if (transport) { 66 | console.log(`close transport ${transport.id}`); 67 | transport.close(); 68 | } 69 | }); 70 | 71 | socket.on('connect_error', (err) => { 72 | console.error('client connection error', err); 73 | }); 74 | 75 | socket.on('createSource', async (data, callback) => { 76 | console.log(`createSource ${JSON.stringify(data)}`); 77 | const source = data as Source; 78 | if (!sources.find(s => s.name === source.name)) { 79 | await createSource(source) 80 | sources.push(source); 81 | } 82 | callback(); 83 | }); 84 | 85 | socket.on('getRouterRtpCapabilities', (data, callback) => { 86 | console.log(`getRouterRtpCapabilities ${JSON.stringify(data)}`); 87 | callback(mediasoupRouter.rtpCapabilities); 88 | }); 89 | 90 | socket.on('createConsumerTransport', async (data, callback) => { 91 | console.log(`createConsumerTransport ${JSON.stringify(data)}`); 92 | const { transport, params } = await createWebRtcTransport(); 93 | consumerTransports.set(transport.id, transport); 94 | socketTransports.set(socket.id, transport); 95 | callback(params); 96 | }); 97 | 98 | socket.on('connectConsumerTransport', async (data, callback) => { 99 | console.log(`connectConsumerTransport ${JSON.stringify(data)}`); 100 | const { transportId } = data; 101 | const consumerTransport = consumerTransports.get(transportId); 102 | if (!consumerTransport) { 103 | throw new Error(`consumer transport ${transportId} not found`); 104 | } 105 | await consumerTransport.connect({ dtlsParameters: data.dtlsParameters }); 106 | callback(); 107 | }); 108 | 109 | socket.on('consume', async (data, callback) => { 110 | console.log(`consume ${JSON.stringify(data)}`); 111 | const { source, transportId } = data; 112 | const producer = producers.get(source) as mediasoup.types.Producer; 113 | const consumerTransport = consumerTransports.get(transportId); 114 | if (!consumerTransport) { 115 | throw new Error(`consumer transport ${transportId} not found`); 116 | } 117 | const consumer = await createConsumer(producer, consumerTransport, data.rtpCapabilities); 118 | consumers.set(consumer.id, consumer); 119 | callback({ 120 | producerId: producer.id, 121 | id: consumer.id, 122 | kind: consumer.kind, 123 | rtpParameters: consumer.rtpParameters, 124 | type: consumer.type, 125 | producerPaused: consumer.producerPaused 126 | }); 127 | }); 128 | 129 | socket.on('resume', async (data, callback) => { 130 | console.log(`resume ${JSON.stringify(data)}`); 131 | const { consumerId } = data; 132 | const consumer = consumers.get(consumerId); 133 | if (!consumer) { 134 | throw new Error(`consumer ${consumerId} not found`); 135 | } 136 | await consumer.resume(); 137 | callback(); 138 | }); 139 | }); 140 | } 141 | 142 | async function runMediasoupWorker() { 143 | webRtcWorker = await mediasoup.createWorker({ 144 | rtcMinPort: RTC_MIN_PORT, 145 | rtcMaxPort: RTC_MAX_PORT, 146 | }); 147 | mediasoupRouter = await webRtcWorker.createRouter({ 148 | mediaCodecs: [ 149 | { 150 | kind: 'video' as mediasoup.types.MediaKind, 151 | mimeType: 'video/H264', 152 | clockRate: 90000 153 | } 154 | ], 155 | }); 156 | } 157 | 158 | async function createWebRtcTransport() { 159 | const transport = await mediasoupRouter.createWebRtcTransport({ 160 | listenIps: [ { ip: RTC_LISTEN_IP, announcedIp: RTC_ANNOUNCED_IP } ], 161 | enableUdp: true, 162 | enableTcp: true, 163 | preferUdp: true, 164 | }); 165 | return { 166 | transport, 167 | params: { 168 | id: transport.id, 169 | iceParameters: transport.iceParameters, 170 | iceCandidates: transport.iceCandidates, 171 | dtlsParameters: transport.dtlsParameters 172 | }, 173 | }; 174 | } 175 | 176 | async function createConsumer( 177 | producer: mediasoup.types.Producer, 178 | consumerTransport: mediasoup.types.WebRtcTransport, 179 | rtpCapabilities: mediasoup.types.RtpCapabilities 180 | ) { 181 | if (!mediasoupRouter.canConsume( 182 | { 183 | producerId: producer.id, 184 | rtpCapabilities, 185 | }) 186 | ) { 187 | throw new Error('can not consume'); 188 | } 189 | return consumerTransport.consume({ 190 | producerId: producer.id, 191 | rtpCapabilities, 192 | paused: producer.kind === 'video', 193 | }); 194 | } 195 | 196 | async function createSource(source: Source) { 197 | const transport = await mediasoupRouter.createPlainTransport({ 198 | listenIp: '0.0.0.0', 199 | rtcpMux: false, 200 | comedia: true 201 | }); 202 | 203 | const ssrc = generateSSRC(); 204 | const payloadType = 102; 205 | const producer = await transport.produce({ 206 | kind: 'video', 207 | rtpParameters: { 208 | codecs: [ 209 | { 210 | mimeType: 'video/H264', 211 | clockRate: 90000, 212 | payloadType: payloadType, 213 | } 214 | ], 215 | encodings: [ 216 | { 217 | ssrc: ssrc, 218 | } 219 | ] 220 | } 221 | }); 222 | producerTransports.set(source.name, transport); 223 | producers.set(source.name, producer); 224 | 225 | const args = [ 226 | '-analyzeduration', '20M', 227 | '-i', `${source.rtmpUrl}`, 228 | '-map', '0:v:0', 229 | '-pix_fmt', 'yuv420p', 230 | '-c:v', 'libx264', 231 | '-tune', 'zerolatency', 232 | '-preset', 'ultrafast', 233 | '-f', 'tee', 234 | `"[select=v:f=rtp:ssrc=${ssrc}:payload_type=${payloadType}]rtp://127.0.0.1:${transport.tuple.localPort}?rtcpport=${transport.rtcpTuple?.localPort}"`, 235 | ]; 236 | 237 | console.log(`Executing ffmpeg ${args.join(' ')}`); 238 | const process = child_process.spawn('ffmpeg', args, { shell: true }); 239 | 240 | process.stderr.on('data', data => { 241 | console.warn(`[${source.name}] ${data.toString()}`); 242 | }); 243 | 244 | process.on('exit', () => { 245 | console.log(`process exit: ${source}`); 246 | }); 247 | } 248 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ES2019", 4 | "lib": [ 5 | "dom", 6 | "dom.iterable", 7 | "esnext" 8 | ], 9 | "outDir": "dist", 10 | "strict": true, 11 | "module": "commonjs", 12 | "moduleResolution": "node", 13 | "resolveJsonModule": true, 14 | "isolatedModules": true, 15 | "sourceMap": true 16 | }, 17 | "include": [ 18 | "src" 19 | ] 20 | } 21 | --------------------------------------------------------------------------------