diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..2eea525 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +.env \ No newline at end of file diff --git a/KST-ASD-BI-101/.env.example b/KST-ASD-BI-101/.env.example new file mode 100644 index 0000000..3c606ce --- /dev/null +++ b/KST-ASD-BI-101/.env.example @@ -0,0 +1,22 @@ +HOSTNAME=localhost +HOST_PORT=63398 + +DB_HOST=rdbms +DB_NAME=catapult_player +DB_USERNAME=catapult +DB_PASSWORD=quartz + +CONTENT_URL=http://localhost:63398/content + +#API_KEY="some API access key" +#API_SECRET="an API access secret" +#TOKEN_SECRET="some random string" + +#LRS_ENDPOINT="http://host.docker.internal:8081/20.1.x/lrs/default/" +#LRS_USERNAME="dev-tools-xapi" +#LRS_PASSWORD="dev-tools-xapi-password" +#LRS_XAPI_VERSION=1.0.3 + +## Default is empty, add if necessary for nginx config +PLAYER_API_ROOT= +PLAYER_STANDALONE_LAUNCH_URL_BASE= diff --git a/KST-ASD-BI-101/README.md b/KST-ASD-BI-101/README.md new file mode 100644 index 0000000..ee04eb0 --- /dev/null +++ b/KST-ASD-BI-101/README.md @@ -0,0 +1,83 @@ +# Course Outline: Applied Software Development for Buddhist Innovation + +## Course Description + +This course explores the intersection of software development and Buddhist +philosophy, aiming to develop innovative applications that align with +Buddhist principles. Learners will learn how to apply Buddhist concepts to +software design, development, and deployment, promoting ethical, +compassionate, and sustainable technological solutions. + +## Course Objectives + +* **Understand** the core principles and concepts of Buddhism. +* **Apply** Buddhist ethics and values to software development practices. +* **Develop** software applications that promote mindfulness, compassion, +and well-being. + +Explore the potential of technology to serve as a tool for spiritual +growth and social transformation. + +Foster a critical and ethical approach to technology design and use. + +## Course Outline + +### Module 1: Foundations of Buddhist Philosophy + +* Introduction to Buddhism: Historical context, key figures, and major schools +Understanding the differences between the major schools (Theravada, Mahayana, Vijñāna) +* The Four Noble Truths and Eightfold Path +* The concept of Saṃsāra +* Mindfulness and meditation practices + * Explored and taught from the perspective of the Theravada (Satipaṭṭhāna) + * Four Foundations of Mindfulness + +### Module 2: Software Development Fundamentals + +* Introduction to programming concepts and languages +* Software development methodologies (e.g., Agile, Waterfall) +* User experience (UX) design and human-computer interaction +* Ethical considerations in software development + +### Module 3: Integrating Buddhist Principles into Software Design + +* Applying Buddhist ethics to software design decisions +* Promoting mindfulness and compassion in user interfaces +* Designing for well-being and reducing unwholesome thought +* Incorporating Buddhist concepts of interconnectedness and interdependence + +### Module 4: Case Studies of Buddhist-Inspired Technology * (Past Reflection) + +* Examples of successful Buddhist-inspired software applications +* Analysis of their design principles and impact +* Discussion of challenges and opportunities in the field + +### Module 5: Developing a Buddhist-Inspired Application * (Process) + +* Project planning and ideation +* Prototyping and user testing +* Implementation of Buddhist principles in the application +* Ethical considerations and impact assessment + +### Module 6: The Future of Buddhist Innovation * (Looking Forward) + +* Emerging trends and technologies in Buddhist-inspired software +* The potential of technology for social and spiritual transformation +* Ethical considerations and challenges for the future + +## Assessment Methods + +* **Assignments**: Reflective essays, case studies, and programming +projects + +* **Shared Discourse**: Group discussion on Buddhist-inspired technologies + +* **Final Project**: Development of a Buddhist-inspired software application + +## Course Resources + +Majjhima Nikāya - Satipaṭṭhāna Sutta + + + + diff --git a/KST-ASD-BI-101/cmi5.xml b/KST-ASD-BI-101/cmi5.xml new file mode 100644 index 0000000..2c0d11d --- /dev/null +++ b/KST-ASD-BI-101/cmi5.xml @@ -0,0 +1,27 @@ + + + + + <langstring lang="en-US">Introduction to Geology - Responsive Style</langstring> + + + + This course will introduce you into the basics of geology. This includes subjects such as + plate tectonics, geological materials and the history of the Earth. + + + + + + <langstring lang="en-US">Introduction to Geology - Responsive Style</langstring> + + + + This course will introduce you into the basics of geology. This includes subjects such as + plate tectonics, geological materials and the history of the Earth. + + + index.html + + diff --git a/KST-ASD-BI-101/cts/.dockerignore b/KST-ASD-BI-101/cts/.dockerignore new file mode 100644 index 0000000..6d56160 --- /dev/null +++ b/KST-ASD-BI-101/cts/.dockerignore @@ -0,0 +1,2 @@ +**/*.swp +**/node_modules diff --git a/KST-ASD-BI-101/cts/.env.example b/KST-ASD-BI-101/cts/.env.example new file mode 100644 index 0000000..f78403f --- /dev/null +++ b/KST-ASD-BI-101/cts/.env.example @@ -0,0 +1,24 @@ +HOSTNAME=localhost + +DB_HOST=rdbms +DB_NAME=catapult_player +DB_USERNAME=catapult +DB_PASSWORD=quartz + +PLAYER_ROOT_PATH=/player +PLAYER_BASE_URL=http://player:3398/player +PLAYER_CONTENT_URL=http://localhost/player/content +# PLAYER_STANDALONE_LAUNCH_URL_BASE=http://localhost/player +PLAYER_KEY=cts +PLAYER_SECRET=player-secret +PLAYER_TOKEN_SECRET=player-token-secret + +CTS_SESSION_COOKIE_PASSWORD=replace_with_very-long-string_with-Mu1tip13-Specia!s + +LRS_ENDPOINT=http://host.docker.internal:8081/20.1.x/lrs/default/ +LRS_USERNAME=dev-tools-xapi +LRS_PASSWORD=dev-tools-xapi-password +LRS_XAPI_VERSION=1.0.3 + +## Dev Only, set to 0 to allow self-signed certs +NODE_TLS_REJECT_UNAUTHORIZED=1 diff --git a/KST-ASD-BI-101/cts/Dockerfile b/KST-ASD-BI-101/cts/Dockerfile new file mode 100755 index 0000000..db9346f --- /dev/null +++ b/KST-ASD-BI-101/cts/Dockerfile @@ -0,0 +1,34 @@ +# Copyright 2021 Rustici Software +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +FROM node:14.17.3-alpine AS client-build +WORKDIR /usr/src/app +COPY --chown=node:node client /usr/src/app +RUN npm ci +RUN npm run build + +FROM node:14.17.3-alpine +RUN apk add dumb-init +ENV NODE_ENV production +WORKDIR /usr/src/app +COPY --chown=node:node entrypoint.sh /usr/src/app +COPY --chown=node:node service /usr/src/app +COPY --chown=node:node migrations /usr/src/app/migrations +COPY --chown=node:node --from=client-build /usr/src/app/dist /usr/src/app/client +RUN rm package-lock.json && npm install && npm ci --only=production +RUN npm install -g nodemon +USER node +ENTRYPOINT [] +CMD ["dumb-init", "./entrypoint.sh"] +EXPOSE 3399/tcp diff --git a/KST-ASD-BI-101/cts/README.md b/KST-ASD-BI-101/cts/README.md new file mode 100644 index 0000000..a7734ec --- /dev/null +++ b/KST-ASD-BI-101/cts/README.md @@ -0,0 +1,28 @@ +![Architecture Diagram](arch.png) + +## Running via Docker Compose + +After cloning the repository, create a `.env` file in the `cts/` directory. This file needs to include information for the following: + +* How to access the LRS to be used for the player *from inside the container* +* The host ports where the CTS and Player can be accessed + +For example: + +``` +HOST_PORT=63399 +PLAYER_HOST_PORT=63398 +PLAYER_CONTENT_URL=http://localhost:63398/content +PLAYER_KEY=cts +PLAYER_SECRET="an API access secret" +PLAYER_TOKEN_SECRET="some random string" +LRS_ENDPOINT="http://host.docker.internal:8081/20.1.x/lrs/default/" +LRS_USERNAME="dev-tools-xapi" +LRS_PASSWORD="dev-tools-xapi-password" +``` + +Then run, + + docker-compose up --build -d + +To build and run the CTS application. Once run it will be available at the `HOST_PORT` mapped in the `.env` as above. diff --git a/KST-ASD-BI-101/cts/arch.png b/KST-ASD-BI-101/cts/arch.png new file mode 100644 index 0000000..4202fa0 Binary files /dev/null and b/KST-ASD-BI-101/cts/arch.png differ diff --git a/KST-ASD-BI-101/cts/certbot/.gitignore b/KST-ASD-BI-101/cts/certbot/.gitignore new file mode 100644 index 0000000..6439036 --- /dev/null +++ b/KST-ASD-BI-101/cts/certbot/.gitignore @@ -0,0 +1,2 @@ +/log +/etc \ No newline at end of file diff --git a/KST-ASD-BI-101/cts/certbot/check.sh b/KST-ASD-BI-101/cts/certbot/check.sh new file mode 100755 index 0000000..9deaa3d --- /dev/null +++ b/KST-ASD-BI-101/cts/certbot/check.sh @@ -0,0 +1,9 @@ +#!/bin/bash + +docker-compose run certbot \ + certonly --webroot \ + --register-unsafely-without-email --agree-tos \ + --webroot-path=/data/letsencrypt \ + --staging \ + -d $1 + diff --git a/KST-ASD-BI-101/cts/certbot/generate.sh b/KST-ASD-BI-101/cts/certbot/generate.sh new file mode 100755 index 0000000..c964ee9 --- /dev/null +++ b/KST-ASD-BI-101/cts/certbot/generate.sh @@ -0,0 +1,11 @@ +#!/bin/bash + +rm -rf ./certbot/etc + +docker-compose run certbot \ + certonly --webroot \ + --register-unsafely-without-email --agree-tos \ + --webroot-path=/data/letsencrypt \ + -d $1 + +docker-compose restart nginx diff --git a/KST-ASD-BI-101/cts/certbot/local/fullchain.pem b/KST-ASD-BI-101/cts/certbot/local/fullchain.pem new file mode 100644 index 0000000..20e8168 --- /dev/null +++ b/KST-ASD-BI-101/cts/certbot/local/fullchain.pem @@ -0,0 +1,22 @@ +-----BEGIN CERTIFICATE----- +MIIDlDCCAnwCCQCG915XR++czzANBgkqhkiG9w0BAQsFADCBizELMAkGA1UEBhMC +QVUxETAPBgNVBAgMCFZpcmdpbmlhMRMwEQYDVQQHDApBbGV4YW5kcmlhMQwwCgYD +VQQKDANBREwxDDAKBgNVBAsMA1ImRDENMAsGA1UEAwwEVHJleTEpMCcGCSqGSIb3 +DQEJARYadHJleS5oYXlkZW4uY3RyQGFkbG5ldC5nb3YwHhcNMTkxMDE2MTM0NDA1 +WhcNMjkxMDEzMTM0NDA1WjCBizELMAkGA1UEBhMCQVUxETAPBgNVBAgMCFZpcmdp +bmlhMRMwEQYDVQQHDApBbGV4YW5kcmlhMQwwCgYDVQQKDANBREwxDDAKBgNVBAsM +A1ImRDENMAsGA1UEAwwEVHJleTEpMCcGCSqGSIb3DQEJARYadHJleS5oYXlkZW4u +Y3RyQGFkbG5ldC5nb3YwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC3 +GY/ZaqhO1MZ1bywEXldP3fAoHCMPBpEn3t0HO7/FYdn4rEx+BbsZ20SjFc+zRugk +kBuvCdbLEKhwDHzAV4mOXbLurXi+BPOfB93I51zo9V7SoUsyspGEvopknVYcRbkP +BOEuEqtTQc6ad5GqSm44v9VsbrUyczuR7CFvysOp3OAuCmaXYuwFd8Gr29ILdNHV +YU3XU9KKgUeAPxoQLCUZNR0AuVJz5ewGqHKqxPNAwvAg8jfqMjIPRRdSqhYD852q +ad4n18OYPUKKF3jMjYN6DeyUjqXDaUEtLqxVibBM79KubkoIM5/Dg9V20qZM5r4A +K8jhVbNH4Jk4EHB711CpAgMBAAEwDQYJKoZIhvcNAQELBQADggEBAAKqEU1Vt3kj +Tag44hCMCWZDgVpu8zGTYq/2odLETJWH3Er/daUSaAUP1tvKGorLyNd7YONVcOY0 +t6NUrtikVZFRbGeLuupgTJxJOFux9CZCPKzaAgwvrQemBYB9WdEiE34zCAee7FCh +EYkUMqzxzDNriTb46NoMJPZ1u27b2kCdBkpl4LUMjo07YcYzUSbtvrRH2FwmswfL +Abq2uzXcUzbSH2TYUoz343vJjdMrkhS2ERzbEi2drU1fIyxOYn+8aeNO1yvQZkRp +NYZ9AA8pbDXhtSPzX4Nvq6b5lgq81N8Uqd6zrVMgKkz662dRMmnAaMnQt00lJmrl +g68QbIwM8u0= +-----END CERTIFICATE----- diff --git a/KST-ASD-BI-101/cts/certbot/local/privkey.pem b/KST-ASD-BI-101/cts/certbot/local/privkey.pem new file mode 100644 index 0000000..9844b87 --- /dev/null +++ b/KST-ASD-BI-101/cts/certbot/local/privkey.pem @@ -0,0 +1,27 @@ +-----BEGIN RSA PRIVATE KEY----- +MIIEpAIBAAKCAQEAtxmP2WqoTtTGdW8sBF5XT93wKBwjDwaRJ97dBzu/xWHZ+KxM +fgW7GdtEoxXPs0boJJAbrwnWyxCocAx8wFeJjl2y7q14vgTznwfdyOdc6PVe0qFL +MrKRhL6KZJ1WHEW5DwThLhKrU0HOmneRqkpuOL/VbG61MnM7kewhb8rDqdzgLgpm +l2LsBXfBq9vSC3TR1WFN11PSioFHgD8aECwlGTUdALlSc+XsBqhyqsTzQMLwIPI3 +6jIyD0UXUqoWA/OdqmneJ9fDmD1Cihd4zI2Deg3slI6lw2lBLS6sVYmwTO/Srm5K +CDOfw4PVdtKmTOa+ACvI4VWzR+CZOBBwe9dQqQIDAQABAoIBADqoGrg4/fA7I9TN +J5nCq0/vtpby5JxUqz3NnJtLndTa0xxh/iNFLLpMz0E7pI03QvkrnWLG0SO+k2dJ +6NEpeey8wazKr+qX5X/l4jwROmd668SoXVHBePLAo881xDdMcsuH8adz3aTPaSN8 ++JJIQ+U0N2gEU1H1LnlB3zhUCbipeW00/cP8h77lheaYbBiqMxEXE3LWpqfRFo3W +139Np/vCerLIrB0IYjU/ayzPex0FBf+lJZlpeLXxVgRhli6d1ZJPws/AgIR02exm ++gmSmEaZZFcpMctavUHTMcgoSmqtCjtMIqDHfjri8J3+s9ioAuoFFJnxMuCz83RC +HR4Zak0CgYEA7WtWG9vqr4B3InvaKlrY6avij7+p7XYiVccx2YXXVY4UWQNfDVJr ++bFXH/YG5Rr/p/bBEuypqaCsqsmLDgc9BjhOyXI/YoRLHxL4FPDf5va1UdziooVv +2BCcBdlV/5POlDxRo/qadshTZwvh8/Kygd6jatnAi4mKu2jl7qVaY/MCgYEAxW3x +Z801Glk2dUPm8W8zOuDhu+kuaA4eaY9uUcrO2csEAgz+AQWrXQrCfBNLR6hXDaDh +a9O7yttDIbuR70sH98ipm5k0iVpoKnL0JaDsOepABfOVazuT7gl115iGuGGKDBIf +A9uanGlLF5PIvaz2VZcjTQ5gdSkUDo5KU8sFC/MCgYEA6YoV792Jow1JI0CVP+iR +SnnrqN8t9gmoiJwiqwf+44eY+F5al64lzD3np+bIrYC7TqtpDIaD9fm5H16VTD1O +h9nHllytgOkFRBHSujae6IBxp48R2DBN7kmYUCCTeY4ZPLOA0z5lxsYTVF/Z6a8o +bJtmQGrl/dxT/TmYRAGfQoUCgYA+vC3elyWNptWYM6h6BaTYy8bPKEyXwgzF7E7Y +7MIIEOvIHwrDlmKaoSWluZfNQF/RM9MNqW1eC4hseqbnzAbPJNNIX0mDb9fzzS1p +m5YU3SvU+E79kSPzmsv4Yz5D7rKoHUX/utOJaifzaQF7zC9GiU0tWikqcZAvA+X4 +dGW5IwKBgQCCqWCPdKmwcq+2x+C0g5uU6JyWkBHkmZy54crHu4BaKEId00D/g+C5 +IlJ28/C2dLdw3Ikv+3yBKPRVq9LClVxMP14h3iv0UnZ0jU91GhKSsHmF5lArhdnD +1n8+EQReI4ptXwTQ6lvGBg/5e+mHWNe+J4ONs7LIS1HW3o1aaTyfGQ== +-----END RSA PRIVATE KEY----- diff --git a/KST-ASD-BI-101/cts/certbot/renew.sh b/KST-ASD-BI-101/cts/certbot/renew.sh new file mode 100755 index 0000000..5e0fbbc --- /dev/null +++ b/KST-ASD-BI-101/cts/certbot/renew.sh @@ -0,0 +1,8 @@ +#!/bin/bash + +docker-compose run certbot \ + renew --webroot \ + --register-unsafely-without-email \ + --agree-tos \ + --no-random-sleep-on-renew \ + --webroot-path=/data/letsencrypt diff --git a/KST-ASD-BI-101/cts/client/.browserslistrc b/KST-ASD-BI-101/cts/client/.browserslistrc new file mode 100644 index 0000000..214388f --- /dev/null +++ b/KST-ASD-BI-101/cts/client/.browserslistrc @@ -0,0 +1,3 @@ +> 1% +last 2 versions +not dead diff --git a/KST-ASD-BI-101/cts/client/.eslintrc.js b/KST-ASD-BI-101/cts/client/.eslintrc.js new file mode 100644 index 0000000..544c663 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/.eslintrc.js @@ -0,0 +1,54 @@ +module.exports = { + env: { + browser: true, + node: true + }, + "extends": [ + "plugin:vue/essential", + "eslint:recommended" + ], + parserOptions: { + parser: "babel-eslint" + }, + rules: { + "no-console": process.env.NODE_ENV === "production" ? "warn" : "off", + "no-debugger": process.env.NODE_ENV === "production" ? "warn" : "off", + + "vue/max-attributes-per-line": [ + "error", + { + // this is arbitrary, the key is to allow multiple on a single line + // but force multiline attributes to all be on a single line + singleline: 6, + multiline: { + max: 1, + allowFirstLine: false + } + } + ], + "vue/html-self-closing": "off" + }, + overrides: [ + { + files: ["*.vue"], + rules: { + indent: "off", + "vue/html-indent": [ + "error", + 4, + { + baseIndent: 1 + } + ], + "vue/script-indent": [ + "error", + 4, + { + baseIndent: 1 + } + ], + "vue/name-property-casing": "off" + } + } + ] +}; diff --git a/KST-ASD-BI-101/cts/client/.gitignore b/KST-ASD-BI-101/cts/client/.gitignore new file mode 100644 index 0000000..403adbc --- /dev/null +++ b/KST-ASD-BI-101/cts/client/.gitignore @@ -0,0 +1,23 @@ +.DS_Store +node_modules +/dist + + +# local env files +.env.local +.env.*.local + +# Log files +npm-debug.log* +yarn-debug.log* +yarn-error.log* +pnpm-debug.log* + +# Editor directories and files +.idea +.vscode +*.suo +*.ntvs* +*.njsproj +*.sln +*.sw? diff --git a/KST-ASD-BI-101/cts/client/Dockerfile b/KST-ASD-BI-101/cts/client/Dockerfile new file mode 100644 index 0000000..8f80dc4 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/Dockerfile @@ -0,0 +1,25 @@ +# Copyright 2021 Rustici Software +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +FROM node:14.17.3-alpine AS client-build +WORKDIR /usr/src/app +COPY package.json package-lock.json ./ +RUN npm ci +ENV PATH /usr/src/app/node_modules/.bin:$PATH + +WORKDIR /usr/src/app/src +COPY --chown=node:node . /usr/src/app/src +USER node +CMD ["npm", "run", "serve"] +EXPOSE 3396/tcp diff --git a/KST-ASD-BI-101/cts/client/babel.config.js b/KST-ASD-BI-101/cts/client/babel.config.js new file mode 100644 index 0000000..e955840 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/babel.config.js @@ -0,0 +1,5 @@ +module.exports = { + presets: [ + '@vue/cli-plugin-babel/preset' + ] +} diff --git a/KST-ASD-BI-101/cts/client/package-lock.json b/KST-ASD-BI-101/cts/client/package-lock.json new file mode 100644 index 0000000..18b990b --- /dev/null +++ b/KST-ASD-BI-101/cts/client/package-lock.json @@ -0,0 +1,14064 @@ +{ + "name": "catapult-cts-client", + "version": "1.0.0", + "lockfileVersion": 1, + "requires": true, + "dependencies": { + "@babel/code-frame": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.4.tgz", + "integrity": "sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg==", + "dev": true, + "requires": { + "@babel/highlight": "^7.10.4" + } + }, + "@babel/compat-data": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.14.7.tgz", + "integrity": "sha512-nS6dZaISCXJ3+518CWiBfEr//gHyMO02uDxBkXTKZDN5POruCnOZ1N4YBRZDCabwF8nZMWBpRxIicmXtBs+fvw==", + "dev": true + }, + "@babel/core": { + "version": "7.14.6", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.14.6.tgz", + "integrity": "sha512-gJnOEWSqTk96qG5BoIrl5bVtc23DCycmIePPYnamY9RboYdI4nFy5vAQMSl81O5K/W0sLDWfGysnOECC+KUUCA==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/generator": "^7.14.5", + "@babel/helper-compilation-targets": "^7.14.5", + "@babel/helper-module-transforms": "^7.14.5", + "@babel/helpers": "^7.14.6", + "@babel/parser": "^7.14.6", + "@babel/template": "^7.14.5", + "@babel/traverse": "^7.14.5", + "@babel/types": "^7.14.5", + "convert-source-map": "^1.7.0", + "debug": "^4.1.0", + "gensync": "^1.0.0-beta.2", + "json5": "^2.1.2", + "semver": "^6.3.0", + "source-map": "^0.5.0" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.14.5.tgz", + "integrity": "sha512-9pzDqyc6OLDaqe+zbACgFkb6fKMNG6CObKpnYXChRsvYGyEdc7CA2BaqeOM+vOtCS5ndmJicPJhKAwYRI6UfFw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.14.5" + } + }, + "@babel/generator": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.14.5.tgz", + "integrity": "sha512-y3rlP+/G25OIX3mYKKIOlQRcqj7YgrvHxOLbVmyLJ9bPmi5ttvUmpydVjcFjZphOktWuA7ovbx91ECloWTfjIA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5", + "jsesc": "^2.5.1", + "source-map": "^0.5.0" + } + }, + "@babel/helper-function-name": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.14.5.tgz", + "integrity": "sha512-Gjna0AsXWfFvrAuX+VKcN/aNNWonizBj39yGwUzVDVTlMYJMK2Wp6xdpy72mfArFq5uK+NOuexfzZlzI1z9+AQ==", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.14.5.tgz", + "integrity": "sha512-I1Db4Shst5lewOM4V+ZKJzQ0JGGaZ6VY1jYvMghRjqs6DWgxLCIyFt30GlnKkfUeFLpJt2vzbMVEXVSXlIFYUg==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.14.5.tgz", + "integrity": "sha512-hprxVPu6e5Kdp2puZUmvOGjaLv9TCe58E/Fl6hRq4YiVQxIcNvuq6uTM2r1mT/oPskuS9CgR+I94sqAYv0NGKA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/highlight": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.14.5.tgz", + "integrity": "sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.14.7.tgz", + "integrity": "sha512-X67Z5y+VBJuHB/RjwECp8kSl5uYi0BvRbNeWqkaJCVh+LiTPl19WBUfG627psSgp9rSf6ojuXghQM3ha6qHHdA==", + "dev": true + }, + "@babel/template": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.14.5.tgz", + "integrity": "sha512-6Z3Po85sfxRGachLULUhOmvAaOo7xCvqGQtxINai2mEGPFm6pQ4z5QInFnUrRpfoSV60BnjyF5F3c+15fxFV1g==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/parser": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/traverse": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.14.7.tgz", + "integrity": "sha512-9vDr5NzHu27wgwejuKL7kIOm4bwEtaPQ4Z6cpCmjSuaRqpH/7xc4qcGEscwMqlkwgcXl6MvqoAjZkQ24uSdIZQ==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/generator": "^7.14.5", + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-hoist-variables": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5", + "@babel/parser": "^7.14.7", + "@babel/types": "^7.14.5", + "debug": "^4.1.0", + "globals": "^11.1.0" + } + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "@babel/generator": { + "version": "7.12.5", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.12.5.tgz", + "integrity": "sha512-m16TQQJ8hPt7E+OS/XVQg/7U184MLXtvuGbCdA7na61vha+ImkyyNM/9DDA0unYCVZn3ZOhng+qz48/KBOT96A==", + "dev": true, + "requires": { + "@babel/types": "^7.12.5", + "jsesc": "^2.5.1", + "source-map": "^0.5.0" + } + }, + "@babel/helper-annotate-as-pure": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.14.5.tgz", + "integrity": "sha512-EivH9EgBIb+G8ij1B2jAwSH36WnGvkQSEC6CkX/6v6ZFlw5fVOHvsgGF4uiEHO2GzMvunZb6tDLQEQSdrdocrA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-builder-binary-assignment-operator-visitor": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.14.5.tgz", + "integrity": "sha512-YTA/Twn0vBXDVGJuAX6PwW7x5zQei1luDDo2Pl6q1qZ7hVNl0RZrhHCQG/ArGpR29Vl7ETiB8eJyrvpuRp300w==", + "dev": true, + "requires": { + "@babel/helper-explode-assignable-expression": "^7.14.5", + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-compilation-targets": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.14.5.tgz", + "integrity": "sha512-v+QtZqXEiOnpO6EYvlImB6zCD2Lel06RzOPzmkz/D/XgQiUu3C/Jb1LOqSt/AIA34TYi/Q+KlT8vTQrgdxkbLw==", + "dev": true, + "requires": { + "@babel/compat-data": "^7.14.5", + "@babel/helper-validator-option": "^7.14.5", + "browserslist": "^4.16.6", + "semver": "^6.3.0" + }, + "dependencies": { + "browserslist": { + "version": "4.16.6", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.16.6.tgz", + "integrity": "sha512-Wspk/PqO+4W9qp5iUTJsa1B/QrYn1keNCcEP5OvP7WBwT4KaDly0uONYmC6Xa3Z5IqnUgS0KcgLYu1l74x0ZXQ==", + "dev": true, + "requires": { + "caniuse-lite": "^1.0.30001219", + "colorette": "^1.2.2", + "electron-to-chromium": "^1.3.723", + "escalade": "^3.1.1", + "node-releases": "^1.1.71" + } + }, + "caniuse-lite": { + "version": "1.0.30001245", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001245.tgz", + "integrity": "sha512-768fM9j1PKXpOCKws6eTo3RHmvTUsG9UrpT4WoREFeZgJBTi4/X9g565azS/rVUGtqb8nt7FjLeF5u4kukERnA==", + "dev": true + }, + "colorette": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/colorette/-/colorette-1.2.2.tgz", + "integrity": "sha512-MKGMzyfeuutC/ZJ1cba9NqcNpfeqMUcYmyF1ZFY6/Cn7CNSAKx6a+s48sqLqyAiZuaP2TcqMhoo+dlwFnVxT9w==", + "dev": true + }, + "electron-to-chromium": { + "version": "1.3.779", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.779.tgz", + "integrity": "sha512-nreave0y/1Qhmo8XtO6C/LpawNyC6U26+q7d814/e+tIqUK073pM+4xW7WUXyqCRa5K4wdxHmNMBAi8ap9nEew==", + "dev": true + }, + "node-releases": { + "version": "1.1.73", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.73.tgz", + "integrity": "sha512-uW7fodD6pyW2FZNZnp/Z3hvWKeEW1Y8R1+1CnErE8cXFXzl5blBOoVB41CvMer6P6Q0S5FXDwcHgFd1Wj0U9zg==", + "dev": true + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "@babel/helper-create-class-features-plugin": { + "version": "7.14.6", + "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.14.6.tgz", + "integrity": "sha512-Z6gsfGofTxH/+LQXqYEK45kxmcensbzmk/oi8DmaQytlQCgqNZt9XQF8iqlI/SeXWVjaMNxvYvzaYw+kh42mDg==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.14.5", + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-member-expression-to-functions": "^7.14.5", + "@babel/helper-optimise-call-expression": "^7.14.5", + "@babel/helper-replace-supers": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.14.5.tgz", + "integrity": "sha512-9pzDqyc6OLDaqe+zbACgFkb6fKMNG6CObKpnYXChRsvYGyEdc7CA2BaqeOM+vOtCS5ndmJicPJhKAwYRI6UfFw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.14.5" + } + }, + "@babel/helper-function-name": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.14.5.tgz", + "integrity": "sha512-Gjna0AsXWfFvrAuX+VKcN/aNNWonizBj39yGwUzVDVTlMYJMK2Wp6xdpy72mfArFq5uK+NOuexfzZlzI1z9+AQ==", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.14.5.tgz", + "integrity": "sha512-I1Db4Shst5lewOM4V+ZKJzQ0JGGaZ6VY1jYvMghRjqs6DWgxLCIyFt30GlnKkfUeFLpJt2vzbMVEXVSXlIFYUg==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.14.5.tgz", + "integrity": "sha512-hprxVPu6e5Kdp2puZUmvOGjaLv9TCe58E/Fl6hRq4YiVQxIcNvuq6uTM2r1mT/oPskuS9CgR+I94sqAYv0NGKA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/highlight": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.14.5.tgz", + "integrity": "sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.14.7.tgz", + "integrity": "sha512-X67Z5y+VBJuHB/RjwECp8kSl5uYi0BvRbNeWqkaJCVh+LiTPl19WBUfG627psSgp9rSf6ojuXghQM3ha6qHHdA==", + "dev": true + }, + "@babel/template": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.14.5.tgz", + "integrity": "sha512-6Z3Po85sfxRGachLULUhOmvAaOo7xCvqGQtxINai2mEGPFm6pQ4z5QInFnUrRpfoSV60BnjyF5F3c+15fxFV1g==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/parser": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-create-regexp-features-plugin": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.14.5.tgz", + "integrity": "sha512-TLawwqpOErY2HhWbGJ2nZT5wSkR192QpN+nBg1THfBfftrlvOh+WbhrxXCH4q4xJ9Gl16BGPR/48JA+Ryiho/A==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.14.5", + "regexpu-core": "^4.7.1" + } + }, + "@babel/helper-define-polyfill-provider": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.2.3.tgz", + "integrity": "sha512-RH3QDAfRMzj7+0Nqu5oqgO5q9mFtQEVvCRsi8qCEfzLR9p2BHfn5FzhSB2oj1fF7I2+DcTORkYaQ6aTR9Cofew==", + "dev": true, + "requires": { + "@babel/helper-compilation-targets": "^7.13.0", + "@babel/helper-module-imports": "^7.12.13", + "@babel/helper-plugin-utils": "^7.13.0", + "@babel/traverse": "^7.13.0", + "debug": "^4.1.1", + "lodash.debounce": "^4.0.8", + "resolve": "^1.14.2", + "semver": "^6.1.2" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.14.5.tgz", + "integrity": "sha512-9pzDqyc6OLDaqe+zbACgFkb6fKMNG6CObKpnYXChRsvYGyEdc7CA2BaqeOM+vOtCS5ndmJicPJhKAwYRI6UfFw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.14.5" + } + }, + "@babel/generator": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.14.5.tgz", + "integrity": "sha512-y3rlP+/G25OIX3mYKKIOlQRcqj7YgrvHxOLbVmyLJ9bPmi5ttvUmpydVjcFjZphOktWuA7ovbx91ECloWTfjIA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5", + "jsesc": "^2.5.1", + "source-map": "^0.5.0" + } + }, + "@babel/helper-function-name": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.14.5.tgz", + "integrity": "sha512-Gjna0AsXWfFvrAuX+VKcN/aNNWonizBj39yGwUzVDVTlMYJMK2Wp6xdpy72mfArFq5uK+NOuexfzZlzI1z9+AQ==", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.14.5.tgz", + "integrity": "sha512-I1Db4Shst5lewOM4V+ZKJzQ0JGGaZ6VY1jYvMghRjqs6DWgxLCIyFt30GlnKkfUeFLpJt2vzbMVEXVSXlIFYUg==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.14.5.tgz", + "integrity": "sha512-hprxVPu6e5Kdp2puZUmvOGjaLv9TCe58E/Fl6hRq4YiVQxIcNvuq6uTM2r1mT/oPskuS9CgR+I94sqAYv0NGKA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/highlight": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.14.5.tgz", + "integrity": "sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.14.7.tgz", + "integrity": "sha512-X67Z5y+VBJuHB/RjwECp8kSl5uYi0BvRbNeWqkaJCVh+LiTPl19WBUfG627psSgp9rSf6ojuXghQM3ha6qHHdA==", + "dev": true + }, + "@babel/template": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.14.5.tgz", + "integrity": "sha512-6Z3Po85sfxRGachLULUhOmvAaOo7xCvqGQtxINai2mEGPFm6pQ4z5QInFnUrRpfoSV60BnjyF5F3c+15fxFV1g==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/parser": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/traverse": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.14.7.tgz", + "integrity": "sha512-9vDr5NzHu27wgwejuKL7kIOm4bwEtaPQ4Z6cpCmjSuaRqpH/7xc4qcGEscwMqlkwgcXl6MvqoAjZkQ24uSdIZQ==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/generator": "^7.14.5", + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-hoist-variables": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5", + "@babel/parser": "^7.14.7", + "@babel/types": "^7.14.5", + "debug": "^4.1.0", + "globals": "^11.1.0" + } + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "@babel/helper-explode-assignable-expression": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.14.5.tgz", + "integrity": "sha512-Htb24gnGJdIGT4vnRKMdoXiOIlqOLmdiUYpAQ0mYfgVT/GDm8GOYhgi4GL+hMKrkiPRohO4ts34ELFsGAPQLDQ==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-function-name": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.10.4.tgz", + "integrity": "sha512-YdaSyz1n8gY44EmN7x44zBn9zQ1Ry2Y+3GTA+3vH6Mizke1Vw0aWDM66FOYEPw8//qKkmqOckrGgTYa+6sceqQ==", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.10.4", + "@babel/template": "^7.10.4", + "@babel/types": "^7.10.4" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.10.4.tgz", + "integrity": "sha512-EkN3YDB+SRDgiIUnNgcmiD361ti+AVbL3f3Henf6dqqUyr5dMsorno0lJWJuLhDhkI5sYEpgj6y9kB8AOU1I2A==", + "dev": true, + "requires": { + "@babel/types": "^7.10.4" + } + }, + "@babel/helper-hoist-variables": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.14.5.tgz", + "integrity": "sha512-R1PXiz31Uc0Vxy4OEOm07x0oSjKAdPPCh3tPivn/Eo8cvz6gveAeuyUUPB21Hoiif0uoPQSSdhIPS3352nvdyQ==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-member-expression-to-functions": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.14.7.tgz", + "integrity": "sha512-TMUt4xKxJn6ccjcOW7c4hlwyJArizskAhoSTOCkA0uZ+KghIaci0Qg9R043kUMWI9mtQfgny+NQ5QATnZ+paaA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-module-imports": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.14.5.tgz", + "integrity": "sha512-SwrNHu5QWS84XlHwGYPDtCxcA0hrSlL2yhWYLgeOc0w7ccOl2qv4s/nARI0aYZW+bSwAL5CukeXA47B/1NKcnQ==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-module-transforms": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.14.5.tgz", + "integrity": "sha512-iXpX4KW8LVODuAieD7MzhNjmM6dzYY5tfRqT+R9HDXWl0jPn/djKmA+G9s/2C2T9zggw5tK1QNqZ70USfedOwA==", + "dev": true, + "requires": { + "@babel/helper-module-imports": "^7.14.5", + "@babel/helper-replace-supers": "^7.14.5", + "@babel/helper-simple-access": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5", + "@babel/helper-validator-identifier": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/traverse": "^7.14.5", + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.14.5.tgz", + "integrity": "sha512-9pzDqyc6OLDaqe+zbACgFkb6fKMNG6CObKpnYXChRsvYGyEdc7CA2BaqeOM+vOtCS5ndmJicPJhKAwYRI6UfFw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.14.5" + } + }, + "@babel/generator": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.14.5.tgz", + "integrity": "sha512-y3rlP+/G25OIX3mYKKIOlQRcqj7YgrvHxOLbVmyLJ9bPmi5ttvUmpydVjcFjZphOktWuA7ovbx91ECloWTfjIA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5", + "jsesc": "^2.5.1", + "source-map": "^0.5.0" + } + }, + "@babel/helper-function-name": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.14.5.tgz", + "integrity": "sha512-Gjna0AsXWfFvrAuX+VKcN/aNNWonizBj39yGwUzVDVTlMYJMK2Wp6xdpy72mfArFq5uK+NOuexfzZlzI1z9+AQ==", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.14.5.tgz", + "integrity": "sha512-I1Db4Shst5lewOM4V+ZKJzQ0JGGaZ6VY1jYvMghRjqs6DWgxLCIyFt30GlnKkfUeFLpJt2vzbMVEXVSXlIFYUg==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.14.5.tgz", + "integrity": "sha512-hprxVPu6e5Kdp2puZUmvOGjaLv9TCe58E/Fl6hRq4YiVQxIcNvuq6uTM2r1mT/oPskuS9CgR+I94sqAYv0NGKA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/highlight": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.14.5.tgz", + "integrity": "sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.14.7.tgz", + "integrity": "sha512-X67Z5y+VBJuHB/RjwECp8kSl5uYi0BvRbNeWqkaJCVh+LiTPl19WBUfG627psSgp9rSf6ojuXghQM3ha6qHHdA==", + "dev": true + }, + "@babel/template": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.14.5.tgz", + "integrity": "sha512-6Z3Po85sfxRGachLULUhOmvAaOo7xCvqGQtxINai2mEGPFm6pQ4z5QInFnUrRpfoSV60BnjyF5F3c+15fxFV1g==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/parser": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/traverse": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.14.7.tgz", + "integrity": "sha512-9vDr5NzHu27wgwejuKL7kIOm4bwEtaPQ4Z6cpCmjSuaRqpH/7xc4qcGEscwMqlkwgcXl6MvqoAjZkQ24uSdIZQ==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/generator": "^7.14.5", + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-hoist-variables": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5", + "@babel/parser": "^7.14.7", + "@babel/types": "^7.14.5", + "debug": "^4.1.0", + "globals": "^11.1.0" + } + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-optimise-call-expression": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.14.5.tgz", + "integrity": "sha512-IqiLIrODUOdnPU9/F8ib1Fx2ohlgDhxnIDU7OEVi+kAbEZcyiF7BLU8W6PfvPi9LzztjS7kcbzbmL7oG8kD6VA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-plugin-utils": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.14.5.tgz", + "integrity": "sha512-/37qQCE3K0vvZKwoK4XU/irIJQdIfCJuhU5eKnNxpFDsOkgFaUAwbv+RYw6eYgsC0E4hS7r5KqGULUogqui0fQ==", + "dev": true + }, + "@babel/helper-remap-async-to-generator": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.14.5.tgz", + "integrity": "sha512-rLQKdQU+HYlxBwQIj8dk4/0ENOUEhA/Z0l4hN8BexpvmSMN9oA9EagjnhnDpNsRdWCfjwa4mn/HyBXO9yhQP6A==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.14.5", + "@babel/helper-wrap-function": "^7.14.5", + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-replace-supers": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.14.5.tgz", + "integrity": "sha512-3i1Qe9/8x/hCHINujn+iuHy+mMRLoc77b2nI9TB0zjH1hvn9qGlXjWlggdwUcju36PkPCy/lpM7LLUdcTyH4Ow==", + "dev": true, + "requires": { + "@babel/helper-member-expression-to-functions": "^7.14.5", + "@babel/helper-optimise-call-expression": "^7.14.5", + "@babel/traverse": "^7.14.5", + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.14.5.tgz", + "integrity": "sha512-9pzDqyc6OLDaqe+zbACgFkb6fKMNG6CObKpnYXChRsvYGyEdc7CA2BaqeOM+vOtCS5ndmJicPJhKAwYRI6UfFw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.14.5" + } + }, + "@babel/generator": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.14.5.tgz", + "integrity": "sha512-y3rlP+/G25OIX3mYKKIOlQRcqj7YgrvHxOLbVmyLJ9bPmi5ttvUmpydVjcFjZphOktWuA7ovbx91ECloWTfjIA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5", + "jsesc": "^2.5.1", + "source-map": "^0.5.0" + } + }, + "@babel/helper-function-name": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.14.5.tgz", + "integrity": "sha512-Gjna0AsXWfFvrAuX+VKcN/aNNWonizBj39yGwUzVDVTlMYJMK2Wp6xdpy72mfArFq5uK+NOuexfzZlzI1z9+AQ==", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.14.5.tgz", + "integrity": "sha512-I1Db4Shst5lewOM4V+ZKJzQ0JGGaZ6VY1jYvMghRjqs6DWgxLCIyFt30GlnKkfUeFLpJt2vzbMVEXVSXlIFYUg==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.14.5.tgz", + "integrity": "sha512-hprxVPu6e5Kdp2puZUmvOGjaLv9TCe58E/Fl6hRq4YiVQxIcNvuq6uTM2r1mT/oPskuS9CgR+I94sqAYv0NGKA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/highlight": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.14.5.tgz", + "integrity": "sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.14.7.tgz", + "integrity": "sha512-X67Z5y+VBJuHB/RjwECp8kSl5uYi0BvRbNeWqkaJCVh+LiTPl19WBUfG627psSgp9rSf6ojuXghQM3ha6qHHdA==", + "dev": true + }, + "@babel/template": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.14.5.tgz", + "integrity": "sha512-6Z3Po85sfxRGachLULUhOmvAaOo7xCvqGQtxINai2mEGPFm6pQ4z5QInFnUrRpfoSV60BnjyF5F3c+15fxFV1g==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/parser": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/traverse": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.14.7.tgz", + "integrity": "sha512-9vDr5NzHu27wgwejuKL7kIOm4bwEtaPQ4Z6cpCmjSuaRqpH/7xc4qcGEscwMqlkwgcXl6MvqoAjZkQ24uSdIZQ==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/generator": "^7.14.5", + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-hoist-variables": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5", + "@babel/parser": "^7.14.7", + "@babel/types": "^7.14.5", + "debug": "^4.1.0", + "globals": "^11.1.0" + } + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-simple-access": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.14.5.tgz", + "integrity": "sha512-nfBN9xvmCt6nrMZjfhkl7i0oTV3yxR4/FztsbOASyTvVcoYd0TRHh7eMLdlEcCqobydC0LAF3LtC92Iwxo0wyw==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-skip-transparent-expression-wrappers": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.14.5.tgz", + "integrity": "sha512-dmqZB7mrb94PZSAOYtr+ZN5qt5owZIAgqtoTuqiFbHFtxgEcmQlRJVI+bO++fciBunXtB6MK7HrzrfcAzIz2NQ==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.11.0", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.11.0.tgz", + "integrity": "sha512-74Vejvp6mHkGE+m+k5vHY93FX2cAtrw1zXrZXRlG4l410Nm9PxfEiVTn1PjDPV5SnmieiueY4AFg2xqhNFuuZg==", + "dev": true, + "requires": { + "@babel/types": "^7.11.0" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz", + "integrity": "sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==", + "dev": true + }, + "@babel/helper-validator-option": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.14.5.tgz", + "integrity": "sha512-OX8D5eeX4XwcroVW45NMvoYaIuFI+GQpA2a8Gi+X/U/cDUIRsV37qQfF905F0htTRCREQIB4KqPeaveRJUl3Ow==", + "dev": true + }, + "@babel/helper-wrap-function": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.14.5.tgz", + "integrity": "sha512-YEdjTCq+LNuNS1WfxsDCNpgXkJaIyqco6DAelTUjT4f2KIWC1nBcaCaSdHTBqQVLnTBexBcVcFhLSU1KnYuePQ==", + "dev": true, + "requires": { + "@babel/helper-function-name": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/traverse": "^7.14.5", + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.14.5.tgz", + "integrity": "sha512-9pzDqyc6OLDaqe+zbACgFkb6fKMNG6CObKpnYXChRsvYGyEdc7CA2BaqeOM+vOtCS5ndmJicPJhKAwYRI6UfFw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.14.5" + } + }, + "@babel/generator": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.14.5.tgz", + "integrity": "sha512-y3rlP+/G25OIX3mYKKIOlQRcqj7YgrvHxOLbVmyLJ9bPmi5ttvUmpydVjcFjZphOktWuA7ovbx91ECloWTfjIA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5", + "jsesc": "^2.5.1", + "source-map": "^0.5.0" + } + }, + "@babel/helper-function-name": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.14.5.tgz", + "integrity": "sha512-Gjna0AsXWfFvrAuX+VKcN/aNNWonizBj39yGwUzVDVTlMYJMK2Wp6xdpy72mfArFq5uK+NOuexfzZlzI1z9+AQ==", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.14.5.tgz", + "integrity": "sha512-I1Db4Shst5lewOM4V+ZKJzQ0JGGaZ6VY1jYvMghRjqs6DWgxLCIyFt30GlnKkfUeFLpJt2vzbMVEXVSXlIFYUg==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.14.5.tgz", + "integrity": "sha512-hprxVPu6e5Kdp2puZUmvOGjaLv9TCe58E/Fl6hRq4YiVQxIcNvuq6uTM2r1mT/oPskuS9CgR+I94sqAYv0NGKA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/highlight": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.14.5.tgz", + "integrity": "sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.14.7.tgz", + "integrity": "sha512-X67Z5y+VBJuHB/RjwECp8kSl5uYi0BvRbNeWqkaJCVh+LiTPl19WBUfG627psSgp9rSf6ojuXghQM3ha6qHHdA==", + "dev": true + }, + "@babel/template": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.14.5.tgz", + "integrity": "sha512-6Z3Po85sfxRGachLULUhOmvAaOo7xCvqGQtxINai2mEGPFm6pQ4z5QInFnUrRpfoSV60BnjyF5F3c+15fxFV1g==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/parser": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/traverse": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.14.7.tgz", + "integrity": "sha512-9vDr5NzHu27wgwejuKL7kIOm4bwEtaPQ4Z6cpCmjSuaRqpH/7xc4qcGEscwMqlkwgcXl6MvqoAjZkQ24uSdIZQ==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/generator": "^7.14.5", + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-hoist-variables": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5", + "@babel/parser": "^7.14.7", + "@babel/types": "^7.14.5", + "debug": "^4.1.0", + "globals": "^11.1.0" + } + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helpers": { + "version": "7.14.6", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.14.6.tgz", + "integrity": "sha512-yesp1ENQBiLI+iYHSJdoZKUtRpfTlL1grDIX9NRlAVppljLw/4tTyYupIB7uIYmC3stW/imAv8EqaKaS/ibmeA==", + "dev": true, + "requires": { + "@babel/template": "^7.14.5", + "@babel/traverse": "^7.14.5", + "@babel/types": "^7.14.5" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.14.5.tgz", + "integrity": "sha512-9pzDqyc6OLDaqe+zbACgFkb6fKMNG6CObKpnYXChRsvYGyEdc7CA2BaqeOM+vOtCS5ndmJicPJhKAwYRI6UfFw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.14.5" + } + }, + "@babel/generator": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.14.5.tgz", + "integrity": "sha512-y3rlP+/G25OIX3mYKKIOlQRcqj7YgrvHxOLbVmyLJ9bPmi5ttvUmpydVjcFjZphOktWuA7ovbx91ECloWTfjIA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5", + "jsesc": "^2.5.1", + "source-map": "^0.5.0" + } + }, + "@babel/helper-function-name": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.14.5.tgz", + "integrity": "sha512-Gjna0AsXWfFvrAuX+VKcN/aNNWonizBj39yGwUzVDVTlMYJMK2Wp6xdpy72mfArFq5uK+NOuexfzZlzI1z9+AQ==", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.14.5.tgz", + "integrity": "sha512-I1Db4Shst5lewOM4V+ZKJzQ0JGGaZ6VY1jYvMghRjqs6DWgxLCIyFt30GlnKkfUeFLpJt2vzbMVEXVSXlIFYUg==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.14.5.tgz", + "integrity": "sha512-hprxVPu6e5Kdp2puZUmvOGjaLv9TCe58E/Fl6hRq4YiVQxIcNvuq6uTM2r1mT/oPskuS9CgR+I94sqAYv0NGKA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/highlight": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.14.5.tgz", + "integrity": "sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.14.7.tgz", + "integrity": "sha512-X67Z5y+VBJuHB/RjwECp8kSl5uYi0BvRbNeWqkaJCVh+LiTPl19WBUfG627psSgp9rSf6ojuXghQM3ha6qHHdA==", + "dev": true + }, + "@babel/template": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.14.5.tgz", + "integrity": "sha512-6Z3Po85sfxRGachLULUhOmvAaOo7xCvqGQtxINai2mEGPFm6pQ4z5QInFnUrRpfoSV60BnjyF5F3c+15fxFV1g==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/parser": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/traverse": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.14.7.tgz", + "integrity": "sha512-9vDr5NzHu27wgwejuKL7kIOm4bwEtaPQ4Z6cpCmjSuaRqpH/7xc4qcGEscwMqlkwgcXl6MvqoAjZkQ24uSdIZQ==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/generator": "^7.14.5", + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-hoist-variables": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5", + "@babel/parser": "^7.14.7", + "@babel/types": "^7.14.5", + "debug": "^4.1.0", + "globals": "^11.1.0" + } + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/highlight": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", + "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.10.4", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.12.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.12.7.tgz", + "integrity": "sha512-oWR02Ubp4xTLCAqPRiNIuMVgNO5Aif/xpXtabhzW2HWUD47XJsAB4Zd/Rg30+XeQA3juXigV7hlquOTmwqLiwg==", + "dev": true + }, + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.14.5.tgz", + "integrity": "sha512-ZoJS2XCKPBfTmL122iP6NM9dOg+d4lc9fFk3zxc8iDjvt8Pk4+TlsHSKhIPf6X+L5ORCdBzqMZDjL/WHj7WknQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-skip-transparent-expression-wrappers": "^7.14.5", + "@babel/plugin-proposal-optional-chaining": "^7.14.5" + } + }, + "@babel/plugin-proposal-async-generator-functions": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.14.7.tgz", + "integrity": "sha512-RK8Wj7lXLY3bqei69/cc25gwS5puEc3dknoFPFbqfy3XxYQBQFvu4ioWpafMBAB+L9NyptQK4nMOa5Xz16og8Q==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-remap-async-to-generator": "^7.14.5", + "@babel/plugin-syntax-async-generators": "^7.8.4" + } + }, + "@babel/plugin-proposal-class-properties": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.14.5.tgz", + "integrity": "sha512-q/PLpv5Ko4dVc1LYMpCY7RVAAO4uk55qPwrIuJ5QJ8c6cVuAmhu7I/49JOppXL6gXf7ZHzpRVEUZdYoPLM04Gg==", + "dev": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-proposal-class-static-block": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.14.5.tgz", + "integrity": "sha512-KBAH5ksEnYHCegqseI5N9skTdxgJdmDoAOc0uXa+4QMYKeZD0w5IARh4FMlTNtaHhbB8v+KzMdTgxMMzsIy6Yg==", + "dev": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-class-static-block": "^7.14.5" + } + }, + "@babel/plugin-proposal-decorators": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-decorators/-/plugin-proposal-decorators-7.14.5.tgz", + "integrity": "sha512-LYz5nvQcvYeRVjui1Ykn28i+3aUiXwQ/3MGoEy0InTaz1pJo/lAzmIDXX+BQny/oufgHzJ6vnEEiXQ8KZjEVFg==", + "dev": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-decorators": "^7.14.5" + } + }, + "@babel/plugin-proposal-dynamic-import": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.14.5.tgz", + "integrity": "sha512-ExjiNYc3HDN5PXJx+bwC50GIx/KKanX2HiggnIUAYedbARdImiCU4RhhHfdf0Kd7JNXGpsBBBCOm+bBVy3Gb0g==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-dynamic-import": "^7.8.3" + } + }, + "@babel/plugin-proposal-export-namespace-from": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.14.5.tgz", + "integrity": "sha512-g5POA32bXPMmSBu5Dx/iZGLGnKmKPc5AiY7qfZgurzrCYgIztDlHFbznSNCoQuv57YQLnQfaDi7dxCtLDIdXdA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3" + } + }, + "@babel/plugin-proposal-json-strings": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.14.5.tgz", + "integrity": "sha512-NSq2fczJYKVRIsUJyNxrVUMhB27zb7N7pOFGQOhBKJrChbGcgEAqyZrmZswkPk18VMurEeJAaICbfm57vUeTbQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-json-strings": "^7.8.3" + } + }, + "@babel/plugin-proposal-logical-assignment-operators": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.14.5.tgz", + "integrity": "sha512-YGn2AvZAo9TwyhlLvCCWxD90Xq8xJ4aSgaX3G5D/8DW94L8aaT+dS5cSP+Z06+rCJERGSr9GxMBZ601xoc2taw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4" + } + }, + "@babel/plugin-proposal-nullish-coalescing-operator": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.14.5.tgz", + "integrity": "sha512-gun/SOnMqjSb98Nkaq2rTKMwervfdAoz6NphdY0vTfuzMfryj+tDGb2n6UkDKwez+Y8PZDhE3D143v6Gepp4Hg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3" + } + }, + "@babel/plugin-proposal-numeric-separator": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.14.5.tgz", + "integrity": "sha512-yiclALKe0vyZRZE0pS6RXgjUOt87GWv6FYa5zqj15PvhOGFO69R5DusPlgK/1K5dVnCtegTiWu9UaBSrLLJJBg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-numeric-separator": "^7.10.4" + } + }, + "@babel/plugin-proposal-object-rest-spread": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.14.7.tgz", + "integrity": "sha512-082hsZz+sVabfmDWo1Oct1u1AgbKbUAyVgmX4otIc7bdsRgHBXwTwb3DpDmD4Eyyx6DNiuz5UAATT655k+kL5g==", + "dev": true, + "requires": { + "@babel/compat-data": "^7.14.7", + "@babel/helper-compilation-targets": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-transform-parameters": "^7.14.5" + } + }, + "@babel/plugin-proposal-optional-catch-binding": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.14.5.tgz", + "integrity": "sha512-3Oyiixm0ur7bzO5ybNcZFlmVsygSIQgdOa7cTfOYCMY+wEPAYhZAJxi3mixKFCTCKUhQXuCTtQ1MzrpL3WT8ZQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3" + } + }, + "@babel/plugin-proposal-optional-chaining": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.14.5.tgz", + "integrity": "sha512-ycz+VOzo2UbWNI1rQXxIuMOzrDdHGrI23fRiz/Si2R4kv2XZQ1BK8ccdHwehMKBlcH/joGW/tzrUmo67gbJHlQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-skip-transparent-expression-wrappers": "^7.14.5", + "@babel/plugin-syntax-optional-chaining": "^7.8.3" + } + }, + "@babel/plugin-proposal-private-methods": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.14.5.tgz", + "integrity": "sha512-838DkdUA1u+QTCplatfq4B7+1lnDa/+QMI89x5WZHBcnNv+47N8QEj2k9I2MUU9xIv8XJ4XvPCviM/Dj7Uwt9g==", + "dev": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-proposal-private-property-in-object": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.14.5.tgz", + "integrity": "sha512-62EyfyA3WA0mZiF2e2IV9mc9Ghwxcg8YTu8BS4Wss4Y3PY725OmS9M0qLORbJwLqFtGh+jiE4wAmocK2CTUK2Q==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.14.5", + "@babel/helper-create-class-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5" + } + }, + "@babel/plugin-proposal-unicode-property-regex": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.14.5.tgz", + "integrity": "sha512-6axIeOU5LnY471KenAB9vI8I5j7NQ2d652hIYwVyRfgaZT5UpiqFKCuVXCDMSrU+3VFafnu2c5m3lrWIlr6A5Q==", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-async-generators": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", + "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-class-properties": { + "version": "7.12.13", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", + "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.12.13" + } + }, + "@babel/plugin-syntax-class-static-block": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz", + "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-decorators": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-decorators/-/plugin-syntax-decorators-7.14.5.tgz", + "integrity": "sha512-c4sZMRWL4GSvP1EXy0woIP7m4jkVcEuG8R1TOZxPBPtp4FSM/kiPZub9UIs/Jrb5ZAOzvTUSGYrWsrSu1JvoPw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-dynamic-import": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz", + "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-export-namespace-from": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz", + "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-syntax-json-strings": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", + "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-jsx": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.14.5.tgz", + "integrity": "sha512-ohuFIsOMXJnbOMRfX7/w7LocdR6R7whhuRD4ax8IipLcLPlZGJKkBxgHp++U4N/vKyU16/YDQr2f5seajD3jIw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-logical-assignment-operators": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", + "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.10.4" + } + }, + "@babel/plugin-syntax-nullish-coalescing-operator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", + "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-numeric-separator": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", + "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.10.4" + } + }, + "@babel/plugin-syntax-object-rest-spread": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", + "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-optional-catch-binding": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", + "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-optional-chaining": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", + "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-private-property-in-object": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz", + "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-top-level-await": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", + "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-arrow-functions": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.14.5.tgz", + "integrity": "sha512-KOnO0l4+tD5IfOdi4x8C1XmEIRWUjNRV8wc6K2vz/3e8yAOoZZvsRXRRIF/yo/MAOFb4QjtAw9xSxMXbSMRy8A==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-async-to-generator": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.14.5.tgz", + "integrity": "sha512-szkbzQ0mNk0rpu76fzDdqSyPu0MuvpXgC+6rz5rpMb5OIRxdmHfQxrktL8CYolL2d8luMCZTR0DpIMIdL27IjA==", + "dev": true, + "requires": { + "@babel/helper-module-imports": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-remap-async-to-generator": "^7.14.5" + } + }, + "@babel/plugin-transform-block-scoped-functions": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.14.5.tgz", + "integrity": "sha512-dtqWqdWZ5NqBX3KzsVCWfQI3A53Ft5pWFCT2eCVUftWZgjc5DpDponbIF1+c+7cSGk2wN0YK7HGL/ezfRbpKBQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-block-scoping": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.14.5.tgz", + "integrity": "sha512-LBYm4ZocNgoCqyxMLoOnwpsmQ18HWTQvql64t3GvMUzLQrNoV1BDG0lNftC8QKYERkZgCCT/7J5xWGObGAyHDw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-classes": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.14.5.tgz", + "integrity": "sha512-J4VxKAMykM06K/64z9rwiL6xnBHgB1+FVspqvlgCdwD1KUbQNfszeKVVOMh59w3sztHYIZDgnhOC4WbdEfHFDA==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.14.5", + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-optimise-call-expression": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-replace-supers": "^7.14.5", + "@babel/helper-split-export-declaration": "^7.14.5", + "globals": "^11.1.0" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.14.5.tgz", + "integrity": "sha512-9pzDqyc6OLDaqe+zbACgFkb6fKMNG6CObKpnYXChRsvYGyEdc7CA2BaqeOM+vOtCS5ndmJicPJhKAwYRI6UfFw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.14.5" + } + }, + "@babel/helper-function-name": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.14.5.tgz", + "integrity": "sha512-Gjna0AsXWfFvrAuX+VKcN/aNNWonizBj39yGwUzVDVTlMYJMK2Wp6xdpy72mfArFq5uK+NOuexfzZlzI1z9+AQ==", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.14.5.tgz", + "integrity": "sha512-I1Db4Shst5lewOM4V+ZKJzQ0JGGaZ6VY1jYvMghRjqs6DWgxLCIyFt30GlnKkfUeFLpJt2vzbMVEXVSXlIFYUg==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.14.5.tgz", + "integrity": "sha512-hprxVPu6e5Kdp2puZUmvOGjaLv9TCe58E/Fl6hRq4YiVQxIcNvuq6uTM2r1mT/oPskuS9CgR+I94sqAYv0NGKA==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/highlight": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.14.5.tgz", + "integrity": "sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.14.7.tgz", + "integrity": "sha512-X67Z5y+VBJuHB/RjwECp8kSl5uYi0BvRbNeWqkaJCVh+LiTPl19WBUfG627psSgp9rSf6ojuXghQM3ha6qHHdA==", + "dev": true + }, + "@babel/template": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.14.5.tgz", + "integrity": "sha512-6Z3Po85sfxRGachLULUhOmvAaOo7xCvqGQtxINai2mEGPFm6pQ4z5QInFnUrRpfoSV60BnjyF5F3c+15fxFV1g==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/parser": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/plugin-transform-computed-properties": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.14.5.tgz", + "integrity": "sha512-pWM+E4283UxaVzLb8UBXv4EIxMovU4zxT1OPnpHJcmnvyY9QbPPTKZfEj31EUvG3/EQRbYAGaYEUZ4yWOBC2xg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-destructuring": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.14.7.tgz", + "integrity": "sha512-0mDE99nK+kVh3xlc5vKwB6wnP9ecuSj+zQCa/n0voENtP/zymdT4HH6QEb65wjjcbqr1Jb/7z9Qp7TF5FtwYGw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-dotall-regex": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.14.5.tgz", + "integrity": "sha512-loGlnBdj02MDsFaHhAIJzh7euK89lBrGIdM9EAtHFo6xKygCUGuuWe07o1oZVk287amtW1n0808sQM99aZt3gw==", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-duplicate-keys": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.14.5.tgz", + "integrity": "sha512-iJjbI53huKbPDAsJ8EmVmvCKeeq21bAze4fu9GBQtSLqfvzj2oRuHVx4ZkDwEhg1htQ+5OBZh/Ab0XDf5iBZ7A==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-exponentiation-operator": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.14.5.tgz", + "integrity": "sha512-jFazJhMBc9D27o9jDnIE5ZErI0R0m7PbKXVq77FFvqFbzvTMuv8jaAwLZ5PviOLSFttqKIW0/wxNSDbjLk0tYA==", + "dev": true, + "requires": { + "@babel/helper-builder-binary-assignment-operator-visitor": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-for-of": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.14.5.tgz", + "integrity": "sha512-CfmqxSUZzBl0rSjpoQSFoR9UEj3HzbGuGNL21/iFTmjb5gFggJp3ph0xR1YBhexmLoKRHzgxuFvty2xdSt6gTA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-function-name": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.14.5.tgz", + "integrity": "sha512-vbO6kv0fIzZ1GpmGQuvbwwm+O4Cbm2NrPzwlup9+/3fdkuzo1YqOZcXw26+YUJB84Ja7j9yURWposEHLYwxUfQ==", + "dev": true, + "requires": { + "@babel/helper-function-name": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.14.5.tgz", + "integrity": "sha512-9pzDqyc6OLDaqe+zbACgFkb6fKMNG6CObKpnYXChRsvYGyEdc7CA2BaqeOM+vOtCS5ndmJicPJhKAwYRI6UfFw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.14.5" + } + }, + "@babel/helper-function-name": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.14.5.tgz", + "integrity": "sha512-Gjna0AsXWfFvrAuX+VKcN/aNNWonizBj39yGwUzVDVTlMYJMK2Wp6xdpy72mfArFq5uK+NOuexfzZlzI1z9+AQ==", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.14.5", + "@babel/template": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.14.5.tgz", + "integrity": "sha512-I1Db4Shst5lewOM4V+ZKJzQ0JGGaZ6VY1jYvMghRjqs6DWgxLCIyFt30GlnKkfUeFLpJt2vzbMVEXVSXlIFYUg==", + "dev": true, + "requires": { + "@babel/types": "^7.14.5" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/highlight": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.14.5.tgz", + "integrity": "sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.14.7.tgz", + "integrity": "sha512-X67Z5y+VBJuHB/RjwECp8kSl5uYi0BvRbNeWqkaJCVh+LiTPl19WBUfG627psSgp9rSf6ojuXghQM3ha6qHHdA==", + "dev": true + }, + "@babel/template": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.14.5.tgz", + "integrity": "sha512-6Z3Po85sfxRGachLULUhOmvAaOo7xCvqGQtxINai2mEGPFm6pQ4z5QInFnUrRpfoSV60BnjyF5F3c+15fxFV1g==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.14.5", + "@babel/parser": "^7.14.5", + "@babel/types": "^7.14.5" + } + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/plugin-transform-literals": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.14.5.tgz", + "integrity": "sha512-ql33+epql2F49bi8aHXxvLURHkxJbSmMKl9J5yHqg4PLtdE6Uc48CH1GS6TQvZ86eoB/ApZXwm7jlA+B3kra7A==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-member-expression-literals": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.14.5.tgz", + "integrity": "sha512-WkNXxH1VXVTKarWFqmso83xl+2V3Eo28YY5utIkbsmXoItO8Q3aZxN4BTS2k0hz9dGUloHK26mJMyQEYfkn/+Q==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-modules-amd": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.14.5.tgz", + "integrity": "sha512-3lpOU8Vxmp3roC4vzFpSdEpGUWSMsHFreTWOMMLzel2gNGfHE5UWIh/LN6ghHs2xurUp4jRFYMUIZhuFbody1g==", + "dev": true, + "requires": { + "@babel/helper-module-transforms": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "babel-plugin-dynamic-import-node": "^2.3.3" + } + }, + "@babel/plugin-transform-modules-commonjs": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.14.5.tgz", + "integrity": "sha512-en8GfBtgnydoao2PS+87mKyw62k02k7kJ9ltbKe0fXTHrQmG6QZZflYuGI1VVG7sVpx4E1n7KBpNlPb8m78J+A==", + "dev": true, + "requires": { + "@babel/helper-module-transforms": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-simple-access": "^7.14.5", + "babel-plugin-dynamic-import-node": "^2.3.3" + } + }, + "@babel/plugin-transform-modules-systemjs": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.14.5.tgz", + "integrity": "sha512-mNMQdvBEE5DcMQaL5LbzXFMANrQjd2W7FPzg34Y4yEz7dBgdaC+9B84dSO+/1Wba98zoDbInctCDo4JGxz1VYA==", + "dev": true, + "requires": { + "@babel/helper-hoist-variables": "^7.14.5", + "@babel/helper-module-transforms": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-validator-identifier": "^7.14.5", + "babel-plugin-dynamic-import-node": "^2.3.3" + }, + "dependencies": { + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + } + } + }, + "@babel/plugin-transform-modules-umd": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.14.5.tgz", + "integrity": "sha512-RfPGoagSngC06LsGUYyM9QWSXZ8MysEjDJTAea1lqRjNECE3y0qIJF/qbvJxc4oA4s99HumIMdXOrd+TdKaAAA==", + "dev": true, + "requires": { + "@babel/helper-module-transforms": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-named-capturing-groups-regex": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.14.7.tgz", + "integrity": "sha512-DTNOTaS7TkW97xsDMrp7nycUVh6sn/eq22VaxWfEdzuEbRsiaOU0pqU7DlyUGHVsbQbSghvjKRpEl+nUCKGQSg==", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.14.5" + } + }, + "@babel/plugin-transform-new-target": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.14.5.tgz", + "integrity": "sha512-Nx054zovz6IIRWEB49RDRuXGI4Gy0GMgqG0cII9L3MxqgXz/+rgII+RU58qpo4g7tNEx1jG7rRVH4ihZoP4esQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-object-super": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.14.5.tgz", + "integrity": "sha512-MKfOBWzK0pZIrav9z/hkRqIk/2bTv9qvxHzPQc12RcVkMOzpIKnFCNYJip00ssKWYkd8Sf5g0Wr7pqJ+cmtuFg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-replace-supers": "^7.14.5" + } + }, + "@babel/plugin-transform-parameters": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.14.5.tgz", + "integrity": "sha512-Tl7LWdr6HUxTmzQtzuU14SqbgrSKmaR77M0OKyq4njZLQTPfOvzblNKyNkGwOfEFCEx7KeYHQHDI0P3F02IVkA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-property-literals": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.14.5.tgz", + "integrity": "sha512-r1uilDthkgXW8Z1vJz2dKYLV1tuw2xsbrp3MrZmD99Wh9vsfKoob+JTgri5VUb/JqyKRXotlOtwgu4stIYCmnw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-regenerator": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.14.5.tgz", + "integrity": "sha512-NVIY1W3ITDP5xQl50NgTKlZ0GrotKtLna08/uGY6ErQt6VEQZXla86x/CTddm5gZdcr+5GSsvMeTmWA5Ii6pkg==", + "dev": true, + "requires": { + "regenerator-transform": "^0.14.2" + } + }, + "@babel/plugin-transform-reserved-words": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.14.5.tgz", + "integrity": "sha512-cv4F2rv1nD4qdexOGsRQXJrOcyb5CrgjUH9PKrrtyhSDBNWGxd0UIitjyJiWagS+EbUGjG++22mGH1Pub8D6Vg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-runtime": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.14.5.tgz", + "integrity": "sha512-fPMBhh1AV8ZyneiCIA+wYYUH1arzlXR1UMcApjvchDhfKxhy2r2lReJv8uHEyihi4IFIGlr1Pdx7S5fkESDQsg==", + "dev": true, + "requires": { + "@babel/helper-module-imports": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "babel-plugin-polyfill-corejs2": "^0.2.2", + "babel-plugin-polyfill-corejs3": "^0.2.2", + "babel-plugin-polyfill-regenerator": "^0.2.2", + "semver": "^6.3.0" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "@babel/plugin-transform-shorthand-properties": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.14.5.tgz", + "integrity": "sha512-xLucks6T1VmGsTB+GWK5Pl9Jl5+nRXD1uoFdA5TSO6xtiNjtXTjKkmPdFXVLGlK5A2/or/wQMKfmQ2Y0XJfn5g==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-spread": { + "version": "7.14.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.14.6.tgz", + "integrity": "sha512-Zr0x0YroFJku7n7+/HH3A2eIrGMjbmAIbJSVv0IZ+t3U2WUQUA64S/oeied2e+MaGSjmt4alzBCsK9E8gh+fag==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-skip-transparent-expression-wrappers": "^7.14.5" + } + }, + "@babel/plugin-transform-sticky-regex": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.14.5.tgz", + "integrity": "sha512-Z7F7GyvEMzIIbwnziAZmnSNpdijdr4dWt+FJNBnBLz5mwDFkqIXU9wmBcWWad3QeJF5hMTkRe4dAq2sUZiG+8A==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-template-literals": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.14.5.tgz", + "integrity": "sha512-22btZeURqiepOfuy/VkFr+zStqlujWaarpMErvay7goJS6BWwdd6BY9zQyDLDa4x2S3VugxFb162IZ4m/S/+Gg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-typeof-symbol": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.14.5.tgz", + "integrity": "sha512-lXzLD30ffCWseTbMQzrvDWqljvZlHkXU+CnseMhkMNqU1sASnCsz3tSzAaH3vCUXb9PHeUb90ZT1BdFTm1xxJw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-unicode-escapes": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.14.5.tgz", + "integrity": "sha512-crTo4jATEOjxj7bt9lbYXcBAM3LZaUrbP2uUdxb6WIorLmjNKSpHfIybgY4B8SRpbf8tEVIWH3Vtm7ayCrKocA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-transform-unicode-regex": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.14.5.tgz", + "integrity": "sha512-UygduJpC5kHeCiRw/xDVzC+wj8VaYSoKl5JNVmbP7MadpNinAm3SvZCxZ42H37KZBKztz46YC73i9yV34d0Tzw==", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/preset-env": { + "version": "7.14.7", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.14.7.tgz", + "integrity": "sha512-itOGqCKLsSUl0Y+1nSfhbuuOlTs0MJk2Iv7iSH+XT/mR8U1zRLO7NjWlYXB47yhK4J/7j+HYty/EhFZDYKa/VA==", + "dev": true, + "requires": { + "@babel/compat-data": "^7.14.7", + "@babel/helper-compilation-targets": "^7.14.5", + "@babel/helper-plugin-utils": "^7.14.5", + "@babel/helper-validator-option": "^7.14.5", + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.14.5", + "@babel/plugin-proposal-async-generator-functions": "^7.14.7", + "@babel/plugin-proposal-class-properties": "^7.14.5", + "@babel/plugin-proposal-class-static-block": "^7.14.5", + "@babel/plugin-proposal-dynamic-import": "^7.14.5", + "@babel/plugin-proposal-export-namespace-from": "^7.14.5", + "@babel/plugin-proposal-json-strings": "^7.14.5", + "@babel/plugin-proposal-logical-assignment-operators": "^7.14.5", + "@babel/plugin-proposal-nullish-coalescing-operator": "^7.14.5", + "@babel/plugin-proposal-numeric-separator": "^7.14.5", + "@babel/plugin-proposal-object-rest-spread": "^7.14.7", + "@babel/plugin-proposal-optional-catch-binding": "^7.14.5", + "@babel/plugin-proposal-optional-chaining": "^7.14.5", + "@babel/plugin-proposal-private-methods": "^7.14.5", + "@babel/plugin-proposal-private-property-in-object": "^7.14.5", + "@babel/plugin-proposal-unicode-property-regex": "^7.14.5", + "@babel/plugin-syntax-async-generators": "^7.8.4", + "@babel/plugin-syntax-class-properties": "^7.12.13", + "@babel/plugin-syntax-class-static-block": "^7.14.5", + "@babel/plugin-syntax-dynamic-import": "^7.8.3", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3", + "@babel/plugin-syntax-json-strings": "^7.8.3", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.10.4", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", + "@babel/plugin-syntax-optional-chaining": "^7.8.3", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5", + "@babel/plugin-syntax-top-level-await": "^7.14.5", + "@babel/plugin-transform-arrow-functions": "^7.14.5", + "@babel/plugin-transform-async-to-generator": "^7.14.5", + "@babel/plugin-transform-block-scoped-functions": "^7.14.5", + "@babel/plugin-transform-block-scoping": "^7.14.5", + "@babel/plugin-transform-classes": "^7.14.5", + "@babel/plugin-transform-computed-properties": "^7.14.5", + "@babel/plugin-transform-destructuring": "^7.14.7", + "@babel/plugin-transform-dotall-regex": "^7.14.5", + "@babel/plugin-transform-duplicate-keys": "^7.14.5", + "@babel/plugin-transform-exponentiation-operator": "^7.14.5", + "@babel/plugin-transform-for-of": "^7.14.5", + "@babel/plugin-transform-function-name": "^7.14.5", + "@babel/plugin-transform-literals": "^7.14.5", + "@babel/plugin-transform-member-expression-literals": "^7.14.5", + "@babel/plugin-transform-modules-amd": "^7.14.5", + "@babel/plugin-transform-modules-commonjs": "^7.14.5", + "@babel/plugin-transform-modules-systemjs": "^7.14.5", + "@babel/plugin-transform-modules-umd": "^7.14.5", + "@babel/plugin-transform-named-capturing-groups-regex": "^7.14.7", + "@babel/plugin-transform-new-target": "^7.14.5", + "@babel/plugin-transform-object-super": "^7.14.5", + "@babel/plugin-transform-parameters": "^7.14.5", + "@babel/plugin-transform-property-literals": "^7.14.5", + "@babel/plugin-transform-regenerator": "^7.14.5", + "@babel/plugin-transform-reserved-words": "^7.14.5", + "@babel/plugin-transform-shorthand-properties": "^7.14.5", + "@babel/plugin-transform-spread": "^7.14.6", + "@babel/plugin-transform-sticky-regex": "^7.14.5", + "@babel/plugin-transform-template-literals": "^7.14.5", + "@babel/plugin-transform-typeof-symbol": "^7.14.5", + "@babel/plugin-transform-unicode-escapes": "^7.14.5", + "@babel/plugin-transform-unicode-regex": "^7.14.5", + "@babel/preset-modules": "^0.1.4", + "@babel/types": "^7.14.5", + "babel-plugin-polyfill-corejs2": "^0.2.2", + "babel-plugin-polyfill-corejs3": "^0.2.2", + "babel-plugin-polyfill-regenerator": "^0.2.2", + "core-js-compat": "^3.15.0", + "semver": "^6.3.0" + }, + "dependencies": { + "@babel/helper-validator-identifier": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz", + "integrity": "sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==", + "dev": true + }, + "@babel/types": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.14.5.tgz", + "integrity": "sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.14.5", + "to-fast-properties": "^2.0.0" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "@babel/preset-modules": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.4.tgz", + "integrity": "sha512-J36NhwnfdzpmH41M1DrnkkgAqhZaqr/NBdPfQ677mLzlaXo+oDiv1deyCDtgAhz8p328otdob0Du7+xgHGZbKg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-proposal-unicode-property-regex": "^7.4.4", + "@babel/plugin-transform-dotall-regex": "^7.4.4", + "@babel/types": "^7.4.4", + "esutils": "^2.0.2" + } + }, + "@babel/runtime": { + "version": "7.14.6", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.14.6.tgz", + "integrity": "sha512-/PCB2uJ7oM44tz8YhC4Z/6PeOKXp4K588f+5M3clr1M4zbqztlo0XEfJ2LEzj/FgwfgGcIdl8n7YYjTCI0BYwg==", + "dev": true, + "requires": { + "regenerator-runtime": "^0.13.4" + } + }, + "@babel/template": { + "version": "7.12.7", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.12.7.tgz", + "integrity": "sha512-GkDzmHS6GV7ZeXfJZ0tLRBhZcMcY0/Lnb+eEbXDBfCAcZCjrZKe6p3J4we/D24O9Y8enxWAg1cWwof59yLh2ow==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.10.4", + "@babel/parser": "^7.12.7", + "@babel/types": "^7.12.7" + } + }, + "@babel/traverse": { + "version": "7.12.9", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.12.9.tgz", + "integrity": "sha512-iX9ajqnLdoU1s1nHt36JDI9KG4k+vmI8WgjK5d+aDTwQbL2fUnzedNedssA645Ede3PM2ma1n8Q4h2ohwXgMXw==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.10.4", + "@babel/generator": "^7.12.5", + "@babel/helper-function-name": "^7.10.4", + "@babel/helper-split-export-declaration": "^7.11.0", + "@babel/parser": "^7.12.7", + "@babel/types": "^7.12.7", + "debug": "^4.1.0", + "globals": "^11.1.0", + "lodash": "^4.17.19" + } + }, + "@babel/types": { + "version": "7.12.7", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.12.7.tgz", + "integrity": "sha512-MNyI92qZq6jrQkXvtIiykvl4WtoRrVV9MPn+ZfsoEENjiWcBQ3ZSHrkxnJWgWtLX3XXqX5hrSQ+X69wkmesXuQ==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.10.4", + "lodash": "^4.17.19", + "to-fast-properties": "^2.0.0" + } + }, + "@cmi5/requirements": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@cmi5/requirements/-/requirements-1.0.0.tgz", + "integrity": "sha512-zma/xICz33dNVgpDYFeEhVtX9jsPXw8c8GhX4eZdHLMyfqCowyZN16ESYSv/zQp8orOfWHVPdm2bojv4TYUY/w==" + }, + "@eslint/eslintrc": { + "version": "0.4.3", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.3.tgz", + "integrity": "sha512-J6KFFz5QCYUJq3pf0mjEcCJVERbzv71PUIDczuh9JkwGEzced6CO5ADLHB1rbf/+oPBtoPfMYNOpGDzCANlbXw==", + "dev": true, + "requires": { + "ajv": "^6.12.4", + "debug": "^4.1.1", + "espree": "^7.3.0", + "globals": "^13.9.0", + "ignore": "^4.0.6", + "import-fresh": "^3.2.1", + "js-yaml": "^3.13.1", + "minimatch": "^3.0.4", + "strip-json-comments": "^3.1.1" + }, + "dependencies": { + "globals": { + "version": "13.10.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.10.0.tgz", + "integrity": "sha512-piHC3blgLGFjvOuMmWZX60f+na1lXFDhQXBf1UYp2fXPXqvEUbOhNwi6BsQ0bQishwedgnjkwv1d9zKf+MWw3g==", + "dev": true, + "requires": { + "type-fest": "^0.20.2" + } + }, + "import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + } + }, + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true + }, + "type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true + } + } + }, + "@hapi/address": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@hapi/address/-/address-2.1.4.tgz", + "integrity": "sha512-QD1PhQk+s31P1ixsX0H0Suoupp3VMXzIVMSwobR3F3MSUO2YCV0B7xqLcUw/Bh8yuvd3LhpyqLQWTNcRmp6IdQ==", + "dev": true + }, + "@hapi/bourne": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/@hapi/bourne/-/bourne-1.3.2.tgz", + "integrity": "sha512-1dVNHT76Uu5N3eJNTYcvxee+jzX4Z9lfciqRRHCU27ihbUcYi+iSc2iml5Ke1LXe1SyJCLA0+14Jh4tXJgOppA==", + "dev": true + }, + "@hapi/hoek": { + "version": "8.5.1", + "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-8.5.1.tgz", + "integrity": "sha512-yN7kbciD87WzLGc5539Tn0sApjyiGHAJgKvG9W8C7O+6c7qmoQMfVs0W4bX17eqz6C78QJqqFrtgdK5EWf6Qow==", + "dev": true + }, + "@hapi/joi": { + "version": "15.1.1", + "resolved": "https://registry.npmjs.org/@hapi/joi/-/joi-15.1.1.tgz", + "integrity": "sha512-entf8ZMOK8sc+8YfeOlM8pCfg3b5+WZIKBfUaaJT8UsjAAPjartzxIYm3TIbjvA4u+u++KbcXD38k682nVHDAQ==", + "dev": true, + "requires": { + "@hapi/address": "2.x.x", + "@hapi/bourne": "1.x.x", + "@hapi/hoek": "8.x.x", + "@hapi/topo": "3.x.x" + } + }, + "@hapi/topo": { + "version": "3.1.6", + "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-3.1.6.tgz", + "integrity": "sha512-tAag0jEcjwH+P2quUfipd7liWCNX2F8NvYjQp2wtInsZxnMlypdw0FtAOLxtvvkO+GSRRbmNi8m/5y42PQJYCQ==", + "dev": true, + "requires": { + "@hapi/hoek": "^8.3.0" + } + }, + "@humanwhocodes/config-array": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.5.0.tgz", + "integrity": "sha512-FagtKFz74XrTl7y6HCzQpwDfXP0yhxe9lHLD1UZxjvZIcbyRz8zTFF/yYNfSfzU414eDwZ1SrO0Qvtyf+wFMQg==", + "dev": true, + "requires": { + "@humanwhocodes/object-schema": "^1.2.0", + "debug": "^4.1.1", + "minimatch": "^3.0.4" + } + }, + "@humanwhocodes/object-schema": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.0.tgz", + "integrity": "sha512-wdppn25U8z/2yiaT6YGquE6X8sSv7hNMWSXYSSU1jGv/yd6XqjXgTDJ8KP4NgjTXfJ3GbRjeeb8RTV7a/VpM+w==", + "dev": true + }, + "@intervolga/optimize-cssnano-plugin": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/@intervolga/optimize-cssnano-plugin/-/optimize-cssnano-plugin-1.0.6.tgz", + "integrity": "sha512-zN69TnSr0viRSU6cEDIcuPcP67QcpQ6uHACg58FiN9PDrU6SLyGW3MR4tiISbYxy1kDWAVPwD+XwQTWE5cigAA==", + "dev": true, + "requires": { + "cssnano": "^4.0.0", + "cssnano-preset-default": "^4.0.0", + "postcss": "^7.0.0" + } + }, + "@mrmlnc/readdir-enhanced": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz", + "integrity": "sha512-bPHp6Ji8b41szTOcaP63VlnbbO5Ny6dwAATtY6JTjh5N2OLrb5Qk/Th5cRkRQhkWCt+EJsYrNB0MiL+Gpn6e3g==", + "dev": true, + "requires": { + "call-me-maybe": "^1.0.1", + "glob-to-regexp": "^0.3.0" + } + }, + "@nodelib/fs.stat": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-1.1.3.tgz", + "integrity": "sha512-shAmDyaQC4H92APFoIaVDHCx5bStIocgvbwQyxPRrbUY20V1EYTbSDchWbuwlMG3V17cprZhA6+78JfB+3DTPw==", + "dev": true + }, + "@nuxt/opencollective": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@nuxt/opencollective/-/opencollective-0.3.2.tgz", + "integrity": "sha512-XG7rUdXG9fcafu9KTDIYjJSkRO38EwjlKYIb5TQ/0WDbiTUTtUtgncMscKOYzfsY86kGs05pAuMOR+3Fi0aN3A==", + "requires": { + "chalk": "^4.1.0", + "consola": "^2.15.0", + "node-fetch": "^2.6.1" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "requires": { + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz", + "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==", + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, + "@soda/friendly-errors-webpack-plugin": { + "version": "1.8.0", + "resolved": "https://registry.npmjs.org/@soda/friendly-errors-webpack-plugin/-/friendly-errors-webpack-plugin-1.8.0.tgz", + "integrity": "sha512-RLotfx6k1+nfLacwNCenj7VnTMPxVwYKoGOcffMFoJDKM8tXzBiCN0hMHFJNnoAojduYAsxuiMm0EOMixgiRow==", + "dev": true, + "requires": { + "chalk": "^2.4.2", + "error-stack-parser": "^2.0.2", + "string-width": "^2.0.0", + "strip-ansi": "^5" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "dev": true + }, + "string-width": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", + "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", + "dev": true, + "requires": { + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^4.0.0" + }, + "dependencies": { + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", + "dev": true + } + } + } + } + }, + "@soda/get-current-script": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@soda/get-current-script/-/get-current-script-1.0.2.tgz", + "integrity": "sha512-T7VNNlYVM1SgQ+VsMYhnDkcGmWhQdL0bDyGm5TlQ3GBXnJscEClUUOKduWTmm2zCnvNLC1hc3JpuXjs/nFOc5w==", + "dev": true + }, + "@stardazed/streams-polyfill": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/@stardazed/streams-polyfill/-/streams-polyfill-2.4.0.tgz", + "integrity": "sha512-W6Yg9cA8YT1b9qCQsz/2+kmKt7i/Za2Nj4QOLqdiANzpTiGy5mOyCQNyh0CVpbvXkjCBo2QxrwPvbDlP9u9k+Q==" + }, + "@types/body-parser": { + "version": "1.19.1", + "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.1.tgz", + "integrity": "sha512-a6bTJ21vFOGIkwM0kzh9Yr89ziVxq4vYH2fQ6N8AeipEzai/cFK6aGMArIkUeIdRIgpwQa+2bXiLuUJCpSf2Cg==", + "dev": true, + "requires": { + "@types/connect": "*", + "@types/node": "*" + } + }, + "@types/connect": { + "version": "3.4.35", + "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", + "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", + "dev": true, + "requires": { + "@types/node": "*" + } + }, + "@types/connect-history-api-fallback": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/@types/connect-history-api-fallback/-/connect-history-api-fallback-1.3.5.tgz", + "integrity": "sha512-h8QJa8xSb1WD4fpKBDcATDNGXghFj6/3GRWG6dhmRcu0RX1Ubasur2Uvx5aeEwlf0MwblEC2bMzzMQntxnw/Cw==", + "dev": true, + "requires": { + "@types/express-serve-static-core": "*", + "@types/node": "*" + } + }, + "@types/express": { + "version": "4.17.13", + "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz", + "integrity": "sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA==", + "dev": true, + "requires": { + "@types/body-parser": "*", + "@types/express-serve-static-core": "^4.17.18", + "@types/qs": "*", + "@types/serve-static": "*" + } + }, + "@types/express-serve-static-core": { + "version": "4.17.24", + "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.24.tgz", + "integrity": "sha512-3UJuW+Qxhzwjq3xhwXm2onQcFHn76frIYVbTu+kn24LFxI+dEhdfISDFovPB8VpEgW8oQCTpRuCe+0zJxB7NEA==", + "dev": true, + "requires": { + "@types/node": "*", + "@types/qs": "*", + "@types/range-parser": "*" + } + }, + "@types/glob": { + "version": "7.1.3", + "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.1.3.tgz", + "integrity": "sha512-SEYeGAIQIQX8NN6LDKprLjbrd5dARM5EXsd8GI/A5l0apYI1fGMWgPHSe4ZKL4eozlAyI+doUE9XbYS4xCkQ1w==", + "dev": true, + "requires": { + "@types/minimatch": "*", + "@types/node": "*" + } + }, + "@types/http-proxy": { + "version": "1.17.7", + "resolved": "https://registry.npmjs.org/@types/http-proxy/-/http-proxy-1.17.7.tgz", + "integrity": "sha512-9hdj6iXH64tHSLTY+Vt2eYOGzSogC+JQ2H7bdPWkuh7KXP5qLllWx++t+K9Wk556c3dkDdPws/SpMRi0sdCT1w==", + "dev": true, + "requires": { + "@types/node": "*" + } + }, + "@types/json-schema": { + "version": "7.0.6", + "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.6.tgz", + "integrity": "sha512-3c+yGKvVP5Y9TYBEibGNR+kLtijnj7mYrXRg+WpFb2X9xm04g/DXYkfg4hmzJQosc9snFNUPkbYIhu+KAm6jJw==", + "dev": true + }, + "@types/mime": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", + "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==", + "dev": true + }, + "@types/minimatch": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz", + "integrity": "sha512-tHq6qdbT9U1IRSGf14CL0pUlULksvY9OZ+5eEgl1N7t+OA3tGvNpxJCzuKQlsNgCVwbAs670L1vcVQi8j9HjnA==", + "dev": true + }, + "@types/minimist": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/@types/minimist/-/minimist-1.2.2.tgz", + "integrity": "sha512-jhuKLIRrhvCPLqwPcx6INqmKeiA5EWrsCOPhrlFSrbrmU4ZMPjj5Ul/oLCMDO98XRUIwVm78xICz4EPCektzeQ==", + "dev": true + }, + "@types/node": { + "version": "14.14.10", + "resolved": "https://registry.npmjs.org/@types/node/-/node-14.14.10.tgz", + "integrity": "sha512-J32dgx2hw8vXrSbu4ZlVhn1Nm3GbeCFNw2FWL8S5QKucHGY0cyNwjdQdO+KMBZ4wpmC7KhLCiNsdk1RFRIYUQQ==", + "dev": true + }, + "@types/normalize-package-data": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/@types/normalize-package-data/-/normalize-package-data-2.4.0.tgz", + "integrity": "sha512-f5j5b/Gf71L+dbqxIpQ4Z2WlmI/mPJ0fOkGGmFgtb6sAu97EPczzbS3/tJKxmcYDj55OX6ssqwDAWOHIYDRDGA==", + "dev": true + }, + "@types/q": { + "version": "1.5.5", + "resolved": "https://registry.npmjs.org/@types/q/-/q-1.5.5.tgz", + "integrity": "sha512-L28j2FcJfSZOnL1WBjDYp2vUHCeIFlyYI/53EwD/rKUBQ7MtUUfbQWiyKJGpcnv4/WgrhWsFKrcPstcAt/J0tQ==", + "dev": true + }, + "@types/qs": { + "version": "6.9.7", + "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", + "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==", + "dev": true + }, + "@types/range-parser": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", + "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==", + "dev": true + }, + "@types/serve-static": { + "version": "1.13.10", + "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz", + "integrity": "sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ==", + "dev": true, + "requires": { + "@types/mime": "^1", + "@types/node": "*" + } + }, + "@types/source-list-map": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/@types/source-list-map/-/source-list-map-0.1.2.tgz", + "integrity": "sha512-K5K+yml8LTo9bWJI/rECfIPrGgxdpeNbj+d53lwN4QjW1MCwlkhUms+gtdzigTeUyBr09+u8BwOIY3MXvHdcsA==", + "dev": true + }, + "@types/tapable": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/@types/tapable/-/tapable-1.0.8.tgz", + "integrity": "sha512-ipixuVrh2OdNmauvtT51o3d8z12p6LtFW9in7U79der/kwejjdNchQC5UMn5u/KxNoM7VHHOs/l8KS8uHxhODQ==", + "dev": true + }, + "@types/uglify-js": { + "version": "3.13.1", + "resolved": "https://registry.npmjs.org/@types/uglify-js/-/uglify-js-3.13.1.tgz", + "integrity": "sha512-O3MmRAk6ZuAKa9CHgg0Pr0+lUOqoMLpc9AS4R8ano2auvsg7IE8syF3Xh/NPr26TWklxYcqoEEFdzLLs1fV9PQ==", + "dev": true, + "requires": { + "source-map": "^0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "@types/webpack": { + "version": "4.41.30", + "resolved": "https://registry.npmjs.org/@types/webpack/-/webpack-4.41.30.tgz", + "integrity": "sha512-GUHyY+pfuQ6haAfzu4S14F+R5iGRwN6b2FRNJY7U0NilmFAqbsOfK6j1HwuLBAqwRIT+pVdNDJGJ6e8rpp0KHA==", + "dev": true, + "requires": { + "@types/node": "*", + "@types/tapable": "^1", + "@types/uglify-js": "*", + "@types/webpack-sources": "*", + "anymatch": "^3.0.0", + "source-map": "^0.6.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "@types/webpack-dev-server": { + "version": "3.11.5", + "resolved": "https://registry.npmjs.org/@types/webpack-dev-server/-/webpack-dev-server-3.11.5.tgz", + "integrity": "sha512-vjsbQBW3fE5FDICkF3w3ZWFRXNwQdKt7JRPLmRy5W0KXlcuew4wgpKWXhgHS71iLNv7Z2PlY9dSSIaYg+bk+9w==", + "dev": true, + "requires": { + "@types/connect-history-api-fallback": "*", + "@types/express": "*", + "@types/serve-static": "*", + "@types/webpack": "^4", + "http-proxy-middleware": "^1.0.0" + } + }, + "@types/webpack-sources": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/@types/webpack-sources/-/webpack-sources-2.1.1.tgz", + "integrity": "sha512-MjM1R6iuw8XaVbtkCBz0N349cyqBjJHCbQiOeppe3VBeFvxqs74RKHAVt9LkxTnUWc7YLZOEsUfPUnmK6SBPKQ==", + "dev": true, + "requires": { + "@types/node": "*", + "@types/source-list-map": "*", + "source-map": "^0.7.3" + }, + "dependencies": { + "source-map": { + "version": "0.7.3", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz", + "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==", + "dev": true + } + } + }, + "@vue/babel-helper-vue-jsx-merge-props": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@vue/babel-helper-vue-jsx-merge-props/-/babel-helper-vue-jsx-merge-props-1.2.1.tgz", + "integrity": "sha512-QOi5OW45e2R20VygMSNhyQHvpdUwQZqGPc748JLGCYEy+yp8fNFNdbNIGAgZmi9e+2JHPd6i6idRuqivyicIkA==", + "dev": true + }, + "@vue/babel-helper-vue-transform-on": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@vue/babel-helper-vue-transform-on/-/babel-helper-vue-transform-on-1.0.2.tgz", + "integrity": "sha512-hz4R8tS5jMn8lDq6iD+yWL6XNB699pGIVLk7WSJnn1dbpjaazsjZQkieJoRX6gW5zpYSCFqQ7jUquPNY65tQYA==", + "dev": true + }, + "@vue/babel-plugin-jsx": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/@vue/babel-plugin-jsx/-/babel-plugin-jsx-1.0.6.tgz", + "integrity": "sha512-RzYsvBhzKUmY2YG6LoV+W5PnlnkInq0thh1AzCmewwctAgGN6e9UFon6ZrQQV1CO5G5PeME7MqpB+/vvGg0h4g==", + "dev": true, + "requires": { + "@babel/helper-module-imports": "^7.0.0", + "@babel/plugin-syntax-jsx": "^7.0.0", + "@babel/template": "^7.0.0", + "@babel/traverse": "^7.0.0", + "@babel/types": "^7.0.0", + "@vue/babel-helper-vue-transform-on": "^1.0.2", + "camelcase": "^6.0.0", + "html-tags": "^3.1.0", + "svg-tags": "^1.0.0" + } + }, + "@vue/babel-plugin-transform-vue-jsx": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@vue/babel-plugin-transform-vue-jsx/-/babel-plugin-transform-vue-jsx-1.2.1.tgz", + "integrity": "sha512-HJuqwACYehQwh1fNT8f4kyzqlNMpBuUK4rSiSES5D4QsYncv5fxFsLyrxFPG2ksO7t5WP+Vgix6tt6yKClwPzA==", + "dev": true, + "requires": { + "@babel/helper-module-imports": "^7.0.0", + "@babel/plugin-syntax-jsx": "^7.2.0", + "@vue/babel-helper-vue-jsx-merge-props": "^1.2.1", + "html-tags": "^2.0.0", + "lodash.kebabcase": "^4.1.1", + "svg-tags": "^1.0.0" + }, + "dependencies": { + "html-tags": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/html-tags/-/html-tags-2.0.0.tgz", + "integrity": "sha1-ELMKOGCF9Dzt41PMj6fLDe7qZos=", + "dev": true + } + } + }, + "@vue/babel-preset-app": { + "version": "4.5.13", + "resolved": "https://registry.npmjs.org/@vue/babel-preset-app/-/babel-preset-app-4.5.13.tgz", + "integrity": "sha512-pM7CR3yXB6L8Gfn6EmX7FLNE3+V/15I3o33GkSNsWvgsMp6HVGXKkXgojrcfUUauyL1LZOdvTmu4enU2RePGHw==", + "dev": true, + "requires": { + "@babel/core": "^7.11.0", + "@babel/helper-compilation-targets": "^7.9.6", + "@babel/helper-module-imports": "^7.8.3", + "@babel/plugin-proposal-class-properties": "^7.8.3", + "@babel/plugin-proposal-decorators": "^7.8.3", + "@babel/plugin-syntax-dynamic-import": "^7.8.3", + "@babel/plugin-syntax-jsx": "^7.8.3", + "@babel/plugin-transform-runtime": "^7.11.0", + "@babel/preset-env": "^7.11.0", + "@babel/runtime": "^7.11.0", + "@vue/babel-plugin-jsx": "^1.0.3", + "@vue/babel-preset-jsx": "^1.2.4", + "babel-plugin-dynamic-import-node": "^2.3.3", + "core-js": "^3.6.5", + "core-js-compat": "^3.6.5", + "semver": "^6.1.0" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "@vue/babel-preset-jsx": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/@vue/babel-preset-jsx/-/babel-preset-jsx-1.2.4.tgz", + "integrity": "sha512-oRVnmN2a77bYDJzeGSt92AuHXbkIxbf/XXSE3klINnh9AXBmVS1DGa1f0d+dDYpLfsAKElMnqKTQfKn7obcL4w==", + "dev": true, + "requires": { + "@vue/babel-helper-vue-jsx-merge-props": "^1.2.1", + "@vue/babel-plugin-transform-vue-jsx": "^1.2.1", + "@vue/babel-sugar-composition-api-inject-h": "^1.2.1", + "@vue/babel-sugar-composition-api-render-instance": "^1.2.4", + "@vue/babel-sugar-functional-vue": "^1.2.2", + "@vue/babel-sugar-inject-h": "^1.2.2", + "@vue/babel-sugar-v-model": "^1.2.3", + "@vue/babel-sugar-v-on": "^1.2.3" + } + }, + "@vue/babel-sugar-composition-api-inject-h": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@vue/babel-sugar-composition-api-inject-h/-/babel-sugar-composition-api-inject-h-1.2.1.tgz", + "integrity": "sha512-4B3L5Z2G+7s+9Bwbf+zPIifkFNcKth7fQwekVbnOA3cr3Pq71q71goWr97sk4/yyzH8phfe5ODVzEjX7HU7ItQ==", + "dev": true, + "requires": { + "@babel/plugin-syntax-jsx": "^7.2.0" + } + }, + "@vue/babel-sugar-composition-api-render-instance": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/@vue/babel-sugar-composition-api-render-instance/-/babel-sugar-composition-api-render-instance-1.2.4.tgz", + "integrity": "sha512-joha4PZznQMsxQYXtR3MnTgCASC9u3zt9KfBxIeuI5g2gscpTsSKRDzWQt4aqNIpx6cv8On7/m6zmmovlNsG7Q==", + "dev": true, + "requires": { + "@babel/plugin-syntax-jsx": "^7.2.0" + } + }, + "@vue/babel-sugar-functional-vue": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/@vue/babel-sugar-functional-vue/-/babel-sugar-functional-vue-1.2.2.tgz", + "integrity": "sha512-JvbgGn1bjCLByIAU1VOoepHQ1vFsroSA/QkzdiSs657V79q6OwEWLCQtQnEXD/rLTA8rRit4rMOhFpbjRFm82w==", + "dev": true, + "requires": { + "@babel/plugin-syntax-jsx": "^7.2.0" + } + }, + "@vue/babel-sugar-inject-h": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/@vue/babel-sugar-inject-h/-/babel-sugar-inject-h-1.2.2.tgz", + "integrity": "sha512-y8vTo00oRkzQTgufeotjCLPAvlhnpSkcHFEp60+LJUwygGcd5Chrpn5480AQp/thrxVm8m2ifAk0LyFel9oCnw==", + "dev": true, + "requires": { + "@babel/plugin-syntax-jsx": "^7.2.0" + } + }, + "@vue/babel-sugar-v-model": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/@vue/babel-sugar-v-model/-/babel-sugar-v-model-1.2.3.tgz", + "integrity": "sha512-A2jxx87mySr/ulAsSSyYE8un6SIH0NWHiLaCWpodPCVOlQVODCaSpiR4+IMsmBr73haG+oeCuSvMOM+ttWUqRQ==", + "dev": true, + "requires": { + "@babel/plugin-syntax-jsx": "^7.2.0", + "@vue/babel-helper-vue-jsx-merge-props": "^1.2.1", + "@vue/babel-plugin-transform-vue-jsx": "^1.2.1", + "camelcase": "^5.0.0", + "html-tags": "^2.0.0", + "svg-tags": "^1.0.0" + }, + "dependencies": { + "camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "dev": true + }, + "html-tags": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/html-tags/-/html-tags-2.0.0.tgz", + "integrity": "sha1-ELMKOGCF9Dzt41PMj6fLDe7qZos=", + "dev": true + } + } + }, + "@vue/babel-sugar-v-on": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/@vue/babel-sugar-v-on/-/babel-sugar-v-on-1.2.3.tgz", + "integrity": "sha512-kt12VJdz/37D3N3eglBywV8GStKNUhNrsxChXIV+o0MwVXORYuhDTHJRKPgLJRb/EY3vM2aRFQdxJBp9CLikjw==", + "dev": true, + "requires": { + "@babel/plugin-syntax-jsx": "^7.2.0", + "@vue/babel-plugin-transform-vue-jsx": "^1.2.1", + "camelcase": "^5.0.0" + }, + "dependencies": { + "camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "dev": true + } + } + }, + "@vue/cli-overlay": { + "version": "4.5.13", + "resolved": "https://registry.npmjs.org/@vue/cli-overlay/-/cli-overlay-4.5.13.tgz", + "integrity": "sha512-jhUIg3klgi5Cxhs8dnat5hi/W2tQJvsqCxR0u6hgfSob0ORODgUBlN+F/uwq7cKIe/pzedVUk1y07F13GQvPqg==", + "dev": true + }, + "@vue/cli-plugin-babel": { + "version": "4.5.13", + "resolved": "https://registry.npmjs.org/@vue/cli-plugin-babel/-/cli-plugin-babel-4.5.13.tgz", + "integrity": "sha512-ykvEAfD8PgGs+dGMGqr7l/nRmIS39NRzWLhMluPLTvDV1L+IxcoB73HNLGA/aENDpl8CuWrTE+1VgydcOhp+wg==", + "dev": true, + "requires": { + "@babel/core": "^7.11.0", + "@vue/babel-preset-app": "^4.5.13", + "@vue/cli-shared-utils": "^4.5.13", + "babel-loader": "^8.1.0", + "cache-loader": "^4.1.0", + "thread-loader": "^2.1.3", + "webpack": "^4.0.0" + }, + "dependencies": { + "@vue/cli-shared-utils": { + "version": "4.5.13", + "resolved": "https://registry.npmjs.org/@vue/cli-shared-utils/-/cli-shared-utils-4.5.13.tgz", + "integrity": "sha512-HpnOrkLg42RFUsQGMJv26oTG3J3FmKtO2WSRhKIIL+1ok3w9OjGCtA3nMMXN27f9eX14TqO64M36DaiSZ1fSiw==", + "dev": true, + "requires": { + "@hapi/joi": "^15.0.1", + "chalk": "^2.4.2", + "execa": "^1.0.0", + "launch-editor": "^2.2.1", + "lru-cache": "^5.1.1", + "node-ipc": "^9.1.1", + "open": "^6.3.0", + "ora": "^3.4.0", + "read-pkg": "^5.1.1", + "request": "^2.88.2", + "semver": "^6.1.0", + "strip-ansi": "^6.0.0" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "@vue/cli-plugin-eslint": { + "version": "4.5.13", + "resolved": "https://registry.npmjs.org/@vue/cli-plugin-eslint/-/cli-plugin-eslint-4.5.13.tgz", + "integrity": "sha512-yc2uXX6aBiy3vEf5TwaueaDqQbdIXIhk0x0KzEtpPo23jBdLkpOSoU5NCgE06g/ZiGAcettpmBSv73Hfp4wHEw==", + "dev": true, + "requires": { + "@vue/cli-shared-utils": "^4.5.13", + "eslint-loader": "^2.2.1", + "globby": "^9.2.0", + "inquirer": "^7.1.0", + "webpack": "^4.0.0", + "yorkie": "^2.0.0" + } + }, + "@vue/cli-plugin-router": { + "version": "4.5.13", + "resolved": "https://registry.npmjs.org/@vue/cli-plugin-router/-/cli-plugin-router-4.5.13.tgz", + "integrity": "sha512-tgtMDjchB/M1z8BcfV4jSOY9fZSMDTPgF9lsJIiqBWMxvBIsk9uIZHxp62DibYME4CCKb/nNK61XHaikFp+83w==", + "dev": true, + "requires": { + "@vue/cli-shared-utils": "^4.5.13" + }, + "dependencies": { + "@vue/cli-shared-utils": { + "version": "4.5.13", + "resolved": "https://registry.npmjs.org/@vue/cli-shared-utils/-/cli-shared-utils-4.5.13.tgz", + "integrity": "sha512-HpnOrkLg42RFUsQGMJv26oTG3J3FmKtO2WSRhKIIL+1ok3w9OjGCtA3nMMXN27f9eX14TqO64M36DaiSZ1fSiw==", + "dev": true, + "requires": { + "@hapi/joi": "^15.0.1", + "chalk": "^2.4.2", + "execa": "^1.0.0", + "launch-editor": "^2.2.1", + "lru-cache": "^5.1.1", + "node-ipc": "^9.1.1", + "open": "^6.3.0", + "ora": "^3.4.0", + "read-pkg": "^5.1.1", + "request": "^2.88.2", + "semver": "^6.1.0", + "strip-ansi": "^6.0.0" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "@vue/cli-plugin-vuex": { + "version": "4.5.13", + "resolved": "https://registry.npmjs.org/@vue/cli-plugin-vuex/-/cli-plugin-vuex-4.5.13.tgz", + "integrity": "sha512-I1S9wZC7iI0Wn8kw8Zh+A2Qkf6s1M6vTGBkx8boXjuzfwEEyEHRxadsVCecZc8Mkpydo0nykj+MyYF96TKFuVA==", + "dev": true + }, + "@vue/cli-service": { + "version": "4.5.13", + "resolved": "https://registry.npmjs.org/@vue/cli-service/-/cli-service-4.5.13.tgz", + "integrity": "sha512-CKAZN4iokMMsaUyJRU22oUAz3oS/X9sVBSKAF2/shFBV5xh3jqAlKl8OXZYz4cXGFLA6djNuYrniuLAo7Ku97A==", + "dev": true, + "requires": { + "@intervolga/optimize-cssnano-plugin": "^1.0.5", + "@soda/friendly-errors-webpack-plugin": "^1.7.1", + "@soda/get-current-script": "^1.0.0", + "@types/minimist": "^1.2.0", + "@types/webpack": "^4.0.0", + "@types/webpack-dev-server": "^3.11.0", + "@vue/cli-overlay": "^4.5.13", + "@vue/cli-plugin-router": "^4.5.13", + "@vue/cli-plugin-vuex": "^4.5.13", + "@vue/cli-shared-utils": "^4.5.13", + "@vue/component-compiler-utils": "^3.1.2", + "@vue/preload-webpack-plugin": "^1.1.0", + "@vue/web-component-wrapper": "^1.2.0", + "acorn": "^7.4.0", + "acorn-walk": "^7.1.1", + "address": "^1.1.2", + "autoprefixer": "^9.8.6", + "browserslist": "^4.12.0", + "cache-loader": "^4.1.0", + "case-sensitive-paths-webpack-plugin": "^2.3.0", + "cli-highlight": "^2.1.4", + "clipboardy": "^2.3.0", + "cliui": "^6.0.0", + "copy-webpack-plugin": "^5.1.1", + "css-loader": "^3.5.3", + "cssnano": "^4.1.10", + "debug": "^4.1.1", + "default-gateway": "^5.0.5", + "dotenv": "^8.2.0", + "dotenv-expand": "^5.1.0", + "file-loader": "^4.2.0", + "fs-extra": "^7.0.1", + "globby": "^9.2.0", + "hash-sum": "^2.0.0", + "html-webpack-plugin": "^3.2.0", + "launch-editor-middleware": "^2.2.1", + "lodash.defaultsdeep": "^4.6.1", + "lodash.mapvalues": "^4.6.0", + "lodash.transform": "^4.6.0", + "mini-css-extract-plugin": "^0.9.0", + "minimist": "^1.2.5", + "pnp-webpack-plugin": "^1.6.4", + "portfinder": "^1.0.26", + "postcss-loader": "^3.0.0", + "ssri": "^8.0.1", + "terser-webpack-plugin": "^1.4.4", + "thread-loader": "^2.1.3", + "url-loader": "^2.2.0", + "vue-loader": "^15.9.2", + "vue-loader-v16": "npm:vue-loader@^16.1.0", + "vue-style-loader": "^4.1.2", + "webpack": "^4.0.0", + "webpack-bundle-analyzer": "^3.8.0", + "webpack-chain": "^6.4.0", + "webpack-dev-server": "^3.11.0", + "webpack-merge": "^4.2.2" + }, + "dependencies": { + "@vue/cli-shared-utils": { + "version": "4.5.13", + "resolved": "https://registry.npmjs.org/@vue/cli-shared-utils/-/cli-shared-utils-4.5.13.tgz", + "integrity": "sha512-HpnOrkLg42RFUsQGMJv26oTG3J3FmKtO2WSRhKIIL+1ok3w9OjGCtA3nMMXN27f9eX14TqO64M36DaiSZ1fSiw==", + "dev": true, + "requires": { + "@hapi/joi": "^15.0.1", + "chalk": "^2.4.2", + "execa": "^1.0.0", + "launch-editor": "^2.2.1", + "lru-cache": "^5.1.1", + "node-ipc": "^9.1.1", + "open": "^6.3.0", + "ora": "^3.4.0", + "read-pkg": "^5.1.1", + "request": "^2.88.2", + "semver": "^6.1.0", + "strip-ansi": "^6.0.0" + } + }, + "acorn": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", + "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", + "dev": true + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + }, + "ssri": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/ssri/-/ssri-8.0.1.tgz", + "integrity": "sha512-97qShzy1AiyxvPNIkLWoGua7xoQzzPjQ0HAH4B0rWKo7SZ6USuPcrUiAFrws0UH8RrbWmgq3LMTObhPIHbbBeQ==", + "dev": true, + "requires": { + "minipass": "^3.1.1" + } + } + } + }, + "@vue/cli-shared-utils": { + "version": "4.5.13", + "resolved": "https://registry.npmjs.org/@vue/cli-shared-utils/-/cli-shared-utils-4.5.13.tgz", + "integrity": "sha512-HpnOrkLg42RFUsQGMJv26oTG3J3FmKtO2WSRhKIIL+1ok3w9OjGCtA3nMMXN27f9eX14TqO64M36DaiSZ1fSiw==", + "dev": true, + "requires": { + "@hapi/joi": "^15.0.1", + "chalk": "^2.4.2", + "execa": "^1.0.0", + "launch-editor": "^2.2.1", + "lru-cache": "^5.1.1", + "node-ipc": "^9.1.1", + "open": "^6.3.0", + "ora": "^3.4.0", + "read-pkg": "^5.1.1", + "request": "^2.88.2", + "semver": "^6.1.0", + "strip-ansi": "^6.0.0" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "@vue/component-compiler-utils": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/@vue/component-compiler-utils/-/component-compiler-utils-3.2.2.tgz", + "integrity": "sha512-rAYMLmgMuqJFWAOb3Awjqqv5X3Q3hVr4jH/kgrFJpiU0j3a90tnNBplqbj+snzrgZhC9W128z+dtgMifOiMfJg==", + "dev": true, + "requires": { + "consolidate": "^0.15.1", + "hash-sum": "^1.0.2", + "lru-cache": "^4.1.2", + "merge-source-map": "^1.1.0", + "postcss": "^7.0.36", + "postcss-selector-parser": "^6.0.2", + "prettier": "^1.18.2", + "source-map": "~0.6.1", + "vue-template-es2015-compiler": "^1.9.0" + }, + "dependencies": { + "hash-sum": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/hash-sum/-/hash-sum-1.0.2.tgz", + "integrity": "sha1-M7QHd3VMZDJXPBIMw4CLvRDUfwQ=", + "dev": true + }, + "lru-cache": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", + "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", + "dev": true, + "requires": { + "pseudomap": "^1.0.2", + "yallist": "^2.1.2" + } + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + }, + "yallist": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", + "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", + "dev": true + } + } + }, + "@vue/preload-webpack-plugin": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@vue/preload-webpack-plugin/-/preload-webpack-plugin-1.1.2.tgz", + "integrity": "sha512-LIZMuJk38pk9U9Ur4YzHjlIyMuxPlACdBIHH9/nGYVTsaGKOSnSuELiE8vS9wa+dJpIYspYUOqk+L1Q4pgHQHQ==", + "dev": true + }, + "@vue/web-component-wrapper": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/@vue/web-component-wrapper/-/web-component-wrapper-1.3.0.tgz", + "integrity": "sha512-Iu8Tbg3f+emIIMmI2ycSI8QcEuAUgPTgHwesDU1eKMLE4YC/c/sFbGc70QgMq31ijRftV0R7vCm9co6rldCeOA==", + "dev": true + }, + "@webassemblyjs/ast": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.9.0.tgz", + "integrity": "sha512-C6wW5L+b7ogSDVqymbkkvuW9kruN//YisMED04xzeBBqjHa2FYnmvOlS6Xj68xWQRgWvI9cIglsjFowH/RJyEA==", + "dev": true, + "requires": { + "@webassemblyjs/helper-module-context": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/wast-parser": "1.9.0" + } + }, + "@webassemblyjs/floating-point-hex-parser": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.9.0.tgz", + "integrity": "sha512-TG5qcFsS8QB4g4MhrxK5TqfdNe7Ey/7YL/xN+36rRjl/BlGE/NcBvJcqsRgCP6Z92mRE+7N50pRIi8SmKUbcQA==", + "dev": true + }, + "@webassemblyjs/helper-api-error": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.9.0.tgz", + "integrity": "sha512-NcMLjoFMXpsASZFxJ5h2HZRcEhDkvnNFOAKneP5RbKRzaWJN36NC4jqQHKwStIhGXu5mUWlUUk7ygdtrO8lbmw==", + "dev": true + }, + "@webassemblyjs/helper-buffer": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.9.0.tgz", + "integrity": "sha512-qZol43oqhq6yBPx7YM3m9Bv7WMV9Eevj6kMi6InKOuZxhw+q9hOkvq5e/PpKSiLfyetpaBnogSbNCfBwyB00CA==", + "dev": true + }, + "@webassemblyjs/helper-code-frame": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-code-frame/-/helper-code-frame-1.9.0.tgz", + "integrity": "sha512-ERCYdJBkD9Vu4vtjUYe8LZruWuNIToYq/ME22igL+2vj2dQ2OOujIZr3MEFvfEaqKoVqpsFKAGsRdBSBjrIvZA==", + "dev": true, + "requires": { + "@webassemblyjs/wast-printer": "1.9.0" + } + }, + "@webassemblyjs/helper-fsm": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-fsm/-/helper-fsm-1.9.0.tgz", + "integrity": "sha512-OPRowhGbshCb5PxJ8LocpdX9Kl0uB4XsAjl6jH/dWKlk/mzsANvhwbiULsaiqT5GZGT9qinTICdj6PLuM5gslw==", + "dev": true + }, + "@webassemblyjs/helper-module-context": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-module-context/-/helper-module-context-1.9.0.tgz", + "integrity": "sha512-MJCW8iGC08tMk2enck1aPW+BE5Cw8/7ph/VGZxwyvGbJwjktKkDK7vy7gAmMDx88D7mhDTCNKAW5tED+gZ0W8g==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0" + } + }, + "@webassemblyjs/helper-wasm-bytecode": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.9.0.tgz", + "integrity": "sha512-R7FStIzyNcd7xKxCZH5lE0Bqy+hGTwS3LJjuv1ZVxd9O7eHCedSdrId/hMOd20I+v8wDXEn+bjfKDLzTepoaUw==", + "dev": true + }, + "@webassemblyjs/helper-wasm-section": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.9.0.tgz", + "integrity": "sha512-XnMB8l3ek4tvrKUUku+IVaXNHz2YsJyOOmz+MMkZvh8h1uSJpSen6vYnw3IoQ7WwEuAhL8Efjms1ZWjqh2agvw==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-buffer": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/wasm-gen": "1.9.0" + } + }, + "@webassemblyjs/ieee754": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.9.0.tgz", + "integrity": "sha512-dcX8JuYU/gvymzIHc9DgxTzUUTLexWwt8uCTWP3otys596io0L5aW02Gb1RjYpx2+0Jus1h4ZFqjla7umFniTg==", + "dev": true, + "requires": { + "@xtuc/ieee754": "^1.2.0" + } + }, + "@webassemblyjs/leb128": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.9.0.tgz", + "integrity": "sha512-ENVzM5VwV1ojs9jam6vPys97B/S65YQtv/aanqnU7D8aSoHFX8GyhGg0CMfyKNIHBuAVjy3tlzd5QMMINa7wpw==", + "dev": true, + "requires": { + "@xtuc/long": "4.2.2" + } + }, + "@webassemblyjs/utf8": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.9.0.tgz", + "integrity": "sha512-GZbQlWtopBTP0u7cHrEx+73yZKrQoBMpwkGEIqlacljhXCkVM1kMQge/Mf+csMJAjEdSwhOyLAS0AoR3AG5P8w==", + "dev": true + }, + "@webassemblyjs/wasm-edit": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.9.0.tgz", + "integrity": "sha512-FgHzBm80uwz5M8WKnMTn6j/sVbqilPdQXTWraSjBwFXSYGirpkSWE2R9Qvz9tNiTKQvoKILpCuTjBKzOIm0nxw==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-buffer": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/helper-wasm-section": "1.9.0", + "@webassemblyjs/wasm-gen": "1.9.0", + "@webassemblyjs/wasm-opt": "1.9.0", + "@webassemblyjs/wasm-parser": "1.9.0", + "@webassemblyjs/wast-printer": "1.9.0" + } + }, + "@webassemblyjs/wasm-gen": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.9.0.tgz", + "integrity": "sha512-cPE3o44YzOOHvlsb4+E9qSqjc9Qf9Na1OO/BHFy4OI91XDE14MjFN4lTMezzaIWdPqHnsTodGGNP+iRSYfGkjA==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/ieee754": "1.9.0", + "@webassemblyjs/leb128": "1.9.0", + "@webassemblyjs/utf8": "1.9.0" + } + }, + "@webassemblyjs/wasm-opt": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.9.0.tgz", + "integrity": "sha512-Qkjgm6Anhm+OMbIL0iokO7meajkzQD71ioelnfPEj6r4eOFuqm4YC3VBPqXjFyyNwowzbMD+hizmprP/Fwkl2A==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-buffer": "1.9.0", + "@webassemblyjs/wasm-gen": "1.9.0", + "@webassemblyjs/wasm-parser": "1.9.0" + } + }, + "@webassemblyjs/wasm-parser": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.9.0.tgz", + "integrity": "sha512-9+wkMowR2AmdSWQzsPEjFU7njh8HTO5MqO8vjwEHuM+AMHioNqSBONRdr0NQQ3dVQrzp0s8lTcYqzUdb7YgELA==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-api-error": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/ieee754": "1.9.0", + "@webassemblyjs/leb128": "1.9.0", + "@webassemblyjs/utf8": "1.9.0" + } + }, + "@webassemblyjs/wast-parser": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-parser/-/wast-parser-1.9.0.tgz", + "integrity": "sha512-qsqSAP3QQ3LyZjNC/0jBJ/ToSxfYJ8kYyuiGvtn/8MK89VrNEfwj7BPQzJVHi0jGTRK2dGdJ5PRqhtjzoww+bw==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/floating-point-hex-parser": "1.9.0", + "@webassemblyjs/helper-api-error": "1.9.0", + "@webassemblyjs/helper-code-frame": "1.9.0", + "@webassemblyjs/helper-fsm": "1.9.0", + "@xtuc/long": "4.2.2" + } + }, + "@webassemblyjs/wast-printer": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.9.0.tgz", + "integrity": "sha512-2J0nE95rHXHyQ24cWjMKJ1tqB/ds8z/cyeOZxJhcb+rW+SQASVjuznUSmdz5GpVJTzU8JkhYut0D3siFDD6wsA==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/wast-parser": "1.9.0", + "@xtuc/long": "4.2.2" + } + }, + "@xtuc/ieee754": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@xtuc/ieee754/-/ieee754-1.2.0.tgz", + "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==", + "dev": true + }, + "@xtuc/long": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", + "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==", + "dev": true + }, + "accepts": { + "version": "1.3.7", + "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", + "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", + "dev": true, + "requires": { + "mime-types": "~2.1.24", + "negotiator": "0.6.2" + } + }, + "acorn": { + "version": "6.4.2", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.2.tgz", + "integrity": "sha512-XtGIhXwF8YM8bJhGxG5kXgjkEuNGLTkoYqVE+KMR+aspr4KGYmKYg7yUe3KghyQ9yheNwLnjmzh/7+gfDBmHCQ==", + "dev": true + }, + "acorn-jsx": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", + "dev": true + }, + "acorn-walk": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz", + "integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==", + "dev": true + }, + "address": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/address/-/address-1.1.2.tgz", + "integrity": "sha512-aT6camzM4xEA54YVJYSqxz1kv4IHnQZRtThJJHhUMRExaU5spC7jX5ugSwTaTgJliIgs4VhZOk7htClvQ/LmRA==", + "dev": true + }, + "ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "requires": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + } + }, + "ajv-errors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/ajv-errors/-/ajv-errors-1.0.1.tgz", + "integrity": "sha512-DCRfO/4nQ+89p/RK43i8Ezd41EqdGIU4ld7nGF8OQ14oc/we5rEntLCUa7+jrn3nn83BosfwZA0wb4pon2o8iQ==", + "dev": true + }, + "ajv-keywords": { + "version": "3.5.2", + "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz", + "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==", + "dev": true + }, + "alphanum-sort": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/alphanum-sort/-/alphanum-sort-1.0.2.tgz", + "integrity": "sha1-l6ERlkmyEa0zaR2fn0hqjsn74KM=", + "dev": true + }, + "ansi-colors": { + "version": "3.2.4", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.4.tgz", + "integrity": "sha512-hHUXGagefjN2iRrID63xckIvotOXOojhQKWIPUZ4mNUZ9nLZW+7FMNoE1lOkEhNWYsx/7ysGIuJYCiMAA9FnrA==", + "dev": true + }, + "ansi-escapes": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", + "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", + "dev": true, + "requires": { + "type-fest": "^0.21.3" + }, + "dependencies": { + "type-fest": { + "version": "0.21.3", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", + "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", + "dev": true + } + } + }, + "ansi-html": { + "version": "0.0.7", + "resolved": "https://registry.npmjs.org/ansi-html/-/ansi-html-0.0.7.tgz", + "integrity": "sha1-gTWEAhliqenm/QOflA0S9WynhZ4=", + "dev": true + }, + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", + "dev": true + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "any-promise": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz", + "integrity": "sha1-q8av7tzqUugJzcA3au0845Y10X8=", + "dev": true + }, + "anymatch": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", + "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", + "dev": true, + "requires": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + } + }, + "aproba": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", + "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==", + "dev": true + }, + "arch": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/arch/-/arch-2.2.0.tgz", + "integrity": "sha512-Of/R0wqp83cgHozfIYLbBMnej79U/SVGOOyuB3VVFv1NRM/PSFMK12x9KVtiYzJqmnU5WR2qp0Z5rHb7sWGnFQ==", + "dev": true + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dev": true, + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "arr-diff": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", + "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", + "dev": true + }, + "arr-flatten": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", + "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", + "dev": true + }, + "arr-union": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", + "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", + "dev": true + }, + "array-flatten": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", + "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=", + "dev": true + }, + "array-union": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", + "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", + "dev": true, + "requires": { + "array-uniq": "^1.0.1" + } + }, + "array-uniq": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", + "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", + "dev": true + }, + "array-unique": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", + "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", + "dev": true + }, + "asn1": { + "version": "0.2.4", + "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", + "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", + "dev": true, + "requires": { + "safer-buffer": "~2.1.0" + } + }, + "asn1.js": { + "version": "5.4.1", + "resolved": "https://registry.npmjs.org/asn1.js/-/asn1.js-5.4.1.tgz", + "integrity": "sha512-+I//4cYPccV8LdmBLiX8CYvf9Sp3vQsrqu2QNXRcrbiWvcx/UdlFiqUJJzxRQxgsZmvhXhn4cSKeSmoFjVdupA==", + "dev": true, + "requires": { + "bn.js": "^4.0.0", + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0", + "safer-buffer": "^2.1.0" + }, + "dependencies": { + "bn.js": { + "version": "4.11.9", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.9.tgz", + "integrity": "sha512-E6QoYqCKZfgatHTdHzs1RRKP7ip4vvm+EyRUeE2RF0NblwVvb0p6jSVeNTOFxPn26QXN2o6SMfNxKp6kU8zQaw==", + "dev": true + } + } + }, + "assert": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/assert/-/assert-1.5.0.tgz", + "integrity": "sha512-EDsgawzwoun2CZkCgtxJbv392v4nbk9XDD06zI+kQYoBM/3RBWLlEyJARDOmhAAosBjWACEkKL6S+lIZtcAubA==", + "dev": true, + "requires": { + "object-assign": "^4.1.1", + "util": "0.10.3" + }, + "dependencies": { + "inherits": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.1.tgz", + "integrity": "sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE=", + "dev": true + }, + "util": { + "version": "0.10.3", + "resolved": "https://registry.npmjs.org/util/-/util-0.10.3.tgz", + "integrity": "sha1-evsa/lCAUkZInj23/g7TeTNqwPk=", + "dev": true, + "requires": { + "inherits": "2.0.1" + } + } + } + }, + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true + }, + "assign-symbols": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", + "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=", + "dev": true + }, + "astral-regex": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", + "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", + "dev": true + }, + "async": { + "version": "2.6.3", + "resolved": "https://registry.npmjs.org/async/-/async-2.6.3.tgz", + "integrity": "sha512-zflvls11DCy+dQWzTW2dzuilv8Z5X/pjfmZOWba6TNIVDm+2UDaJmXSOXlasHKfNBs8oo3M0aT50fDEWfKZjXg==", + "dev": true, + "requires": { + "lodash": "^4.17.14" + } + }, + "async-each": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz", + "integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==", + "dev": true + }, + "async-limiter": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", + "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==", + "dev": true + }, + "asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", + "dev": true + }, + "atob": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", + "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==", + "dev": true + }, + "autoprefixer": { + "version": "9.8.6", + "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-9.8.6.tgz", + "integrity": "sha512-XrvP4VVHdRBCdX1S3WXVD8+RyG9qeb1D5Sn1DeLiG2xfSpzellk5k54xbUERJ3M5DggQxes39UGOTP8CFrEGbg==", + "dev": true, + "requires": { + "browserslist": "^4.12.0", + "caniuse-lite": "^1.0.30001109", + "colorette": "^1.2.1", + "normalize-range": "^0.1.2", + "num2fraction": "^1.2.2", + "postcss": "^7.0.32", + "postcss-value-parser": "^4.1.0" + } + }, + "aws-sign2": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", + "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", + "dev": true + }, + "aws4": { + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.11.0.tgz", + "integrity": "sha512-xh1Rl34h6Fi1DC2WWKfxUTVqRsNnr6LsKz2+hfwDxQJWmrx8+c7ylaqBMcHfl1U1r2dsifOvKX3LQuLNZ+XSvA==", + "dev": true + }, + "babel-eslint": { + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/babel-eslint/-/babel-eslint-10.1.0.tgz", + "integrity": "sha512-ifWaTHQ0ce+448CYop8AdrQiBsGrnC+bMgfyKFdi6EsPLTAWG+QfyDeM6OH+FmWnKvEq5NnBMLvlBUPKQZoDSg==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.0.0", + "@babel/parser": "^7.7.0", + "@babel/traverse": "^7.7.0", + "@babel/types": "^7.7.0", + "eslint-visitor-keys": "^1.0.0", + "resolve": "^1.12.0" + } + }, + "babel-loader": { + "version": "8.2.2", + "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-8.2.2.tgz", + "integrity": "sha512-JvTd0/D889PQBtUXJ2PXaKU/pjZDMtHA9V2ecm+eNRmmBCMR09a+fmpGTNwnJtFmFl5Ei7Vy47LjBb+L0wQ99g==", + "dev": true, + "requires": { + "find-cache-dir": "^3.3.1", + "loader-utils": "^1.4.0", + "make-dir": "^3.1.0", + "schema-utils": "^2.6.5" + } + }, + "babel-plugin-dynamic-import-node": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.3.tgz", + "integrity": "sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ==", + "dev": true, + "requires": { + "object.assign": "^4.1.0" + } + }, + "babel-plugin-polyfill-corejs2": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.2.2.tgz", + "integrity": "sha512-kISrENsJ0z5dNPq5eRvcctITNHYXWOA4DUZRFYCz3jYCcvTb/A546LIddmoGNMVYg2U38OyFeNosQwI9ENTqIQ==", + "dev": true, + "requires": { + "@babel/compat-data": "^7.13.11", + "@babel/helper-define-polyfill-provider": "^0.2.2", + "semver": "^6.1.1" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "babel-plugin-polyfill-corejs3": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.2.3.tgz", + "integrity": "sha512-rCOFzEIJpJEAU14XCcV/erIf/wZQMmMT5l5vXOpL5uoznyOGfDIjPj6FVytMvtzaKSTSVKouOCTPJ5OMUZH30g==", + "dev": true, + "requires": { + "@babel/helper-define-polyfill-provider": "^0.2.2", + "core-js-compat": "^3.14.0" + } + }, + "babel-plugin-polyfill-regenerator": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.2.2.tgz", + "integrity": "sha512-Goy5ghsc21HgPDFtzRkSirpZVW35meGoTmTOb2bxqdl60ghub4xOidgNTHaZfQ2FaxQsKmwvXtOAkcIS4SMBWg==", + "dev": true, + "requires": { + "@babel/helper-define-polyfill-provider": "^0.2.2" + } + }, + "balanced-match": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", + "dev": true + }, + "base": { + "version": "0.11.2", + "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", + "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", + "dev": true, + "requires": { + "cache-base": "^1.0.1", + "class-utils": "^0.3.5", + "component-emitter": "^1.2.1", + "define-property": "^1.0.0", + "isobject": "^3.0.1", + "mixin-deep": "^1.2.0", + "pascalcase": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "base64-js": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", + "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", + "dev": true + }, + "batch": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/batch/-/batch-0.6.1.tgz", + "integrity": "sha1-3DQxT05nkxgJP8dgJyUl+UvyXBY=", + "dev": true + }, + "bcrypt-pbkdf": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", + "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", + "dev": true, + "requires": { + "tweetnacl": "^0.14.3" + } + }, + "bfj": { + "version": "6.1.2", + "resolved": "https://registry.npmjs.org/bfj/-/bfj-6.1.2.tgz", + "integrity": "sha512-BmBJa4Lip6BPRINSZ0BPEIfB1wUY/9rwbwvIHQA1KjX9om29B6id0wnWXq7m3bn5JrUVjeOTnVuhPT1FiHwPGw==", + "dev": true, + "requires": { + "bluebird": "^3.5.5", + "check-types": "^8.0.3", + "hoopy": "^0.1.4", + "tryer": "^1.0.1" + } + }, + "big.js": { + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz", + "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==", + "dev": true + }, + "binary-extensions": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.1.0.tgz", + "integrity": "sha512-1Yj8h9Q+QDF5FzhMs/c9+6UntbD5MkRfRwac8DoEm9ZfUBZ7tZ55YcGVAzEe4bXsdQHEk+s9S5wsOKVdZrw0tQ==", + "dev": true + }, + "bindings": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", + "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", + "dev": true, + "optional": true, + "requires": { + "file-uri-to-path": "1.0.0" + } + }, + "bluebird": { + "version": "3.7.2", + "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", + "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==", + "dev": true + }, + "bn.js": { + "version": "5.1.3", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-5.1.3.tgz", + "integrity": "sha512-GkTiFpjFtUzU9CbMeJ5iazkCzGL3jrhzerzZIuqLABjbwRaFt33I9tUdSNryIptM+RxDet6OKm2WnLXzW51KsQ==", + "dev": true + }, + "body-parser": { + "version": "1.19.0", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", + "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", + "dev": true, + "requires": { + "bytes": "3.1.0", + "content-type": "~1.0.4", + "debug": "2.6.9", + "depd": "~1.1.2", + "http-errors": "1.7.2", + "iconv-lite": "0.4.24", + "on-finished": "~2.3.0", + "qs": "6.7.0", + "raw-body": "2.4.0", + "type-is": "~1.6.17" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + }, + "qs": { + "version": "6.7.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", + "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==", + "dev": true + } + } + }, + "bonjour": { + "version": "3.5.0", + "resolved": "https://registry.npmjs.org/bonjour/-/bonjour-3.5.0.tgz", + "integrity": "sha1-jokKGD2O6aI5OzhExpGkK897yfU=", + "dev": true, + "requires": { + "array-flatten": "^2.1.0", + "deep-equal": "^1.0.1", + "dns-equal": "^1.0.0", + "dns-txt": "^2.0.2", + "multicast-dns": "^6.0.1", + "multicast-dns-service-types": "^1.1.0" + }, + "dependencies": { + "array-flatten": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-2.1.2.tgz", + "integrity": "sha512-hNfzcOV8W4NdualtqBFPyVO+54DSJuZGY9qT4pRroB6S9e3iiido2ISIC5h9R2sPJ8H3FHCIiEnsv1lPXO3KtQ==", + "dev": true + } + } + }, + "boolbase": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", + "integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=", + "dev": true + }, + "bootstrap": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/bootstrap/-/bootstrap-4.6.0.tgz", + "integrity": "sha512-Io55IuQY3kydzHtbGvQya3H+KorS/M9rSNyfCGCg9WZ4pyT/lCxIlpJgG1GXW/PswzC84Tr2fBYi+7+jFVQQBw==" + }, + "bootstrap-vue": { + "version": "2.21.2", + "resolved": "https://registry.npmjs.org/bootstrap-vue/-/bootstrap-vue-2.21.2.tgz", + "integrity": "sha512-0Exe+4MZysqhZNXIKf4TzkvXaupxh9EHsoCRez0o5Dc0J7rlafayOEwql63qXv74CgZO8E4U8ugRNJko1vMvNw==", + "requires": { + "@nuxt/opencollective": "^0.3.2", + "bootstrap": ">=4.5.3 <5.0.0", + "popper.js": "^1.16.1", + "portal-vue": "^2.1.7", + "vue-functional-data-merge": "^3.1.0" + } + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "braces": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", + "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", + "dev": true, + "requires": { + "arr-flatten": "^1.1.0", + "array-unique": "^0.3.2", + "extend-shallow": "^2.0.1", + "fill-range": "^4.0.0", + "isobject": "^3.0.1", + "repeat-element": "^1.1.2", + "snapdragon": "^0.8.1", + "snapdragon-node": "^2.0.1", + "split-string": "^3.0.2", + "to-regex": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "brorand": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz", + "integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8=", + "dev": true + }, + "browserify-aes": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-1.2.0.tgz", + "integrity": "sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA==", + "dev": true, + "requires": { + "buffer-xor": "^1.0.3", + "cipher-base": "^1.0.0", + "create-hash": "^1.1.0", + "evp_bytestokey": "^1.0.3", + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "browserify-cipher": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/browserify-cipher/-/browserify-cipher-1.0.1.tgz", + "integrity": "sha512-sPhkz0ARKbf4rRQt2hTpAHqn47X3llLkUGn+xEJzLjwY8LRs2p0v7ljvI5EyoRO/mexrNunNECisZs+gw2zz1w==", + "dev": true, + "requires": { + "browserify-aes": "^1.0.4", + "browserify-des": "^1.0.0", + "evp_bytestokey": "^1.0.0" + } + }, + "browserify-des": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/browserify-des/-/browserify-des-1.0.2.tgz", + "integrity": "sha512-BioO1xf3hFwz4kc6iBhI3ieDFompMhrMlnDFC4/0/vd5MokpuAc3R+LYbwTA9A5Yc9pq9UYPqffKpW2ObuwX5A==", + "dev": true, + "requires": { + "cipher-base": "^1.0.1", + "des.js": "^1.0.0", + "inherits": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "browserify-rsa": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/browserify-rsa/-/browserify-rsa-4.1.0.tgz", + "integrity": "sha512-AdEER0Hkspgno2aR97SAf6vi0y0k8NuOpGnVH3O99rcA5Q6sh8QxcngtHuJ6uXwnfAXNM4Gn1Gb7/MV1+Ymbog==", + "dev": true, + "requires": { + "bn.js": "^5.0.0", + "randombytes": "^2.0.1" + } + }, + "browserify-sign": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/browserify-sign/-/browserify-sign-4.2.1.tgz", + "integrity": "sha512-/vrA5fguVAKKAVTNJjgSm1tRQDHUU6DbwO9IROu/0WAzC8PKhucDSh18J0RMvVeHAn5puMd+QHC2erPRNf8lmg==", + "dev": true, + "requires": { + "bn.js": "^5.1.1", + "browserify-rsa": "^4.0.1", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "elliptic": "^6.5.3", + "inherits": "^2.0.4", + "parse-asn1": "^5.1.5", + "readable-stream": "^3.6.0", + "safe-buffer": "^5.2.0" + }, + "dependencies": { + "readable-stream": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", + "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + } + }, + "safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "dev": true + } + } + }, + "browserify-zlib": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/browserify-zlib/-/browserify-zlib-0.2.0.tgz", + "integrity": "sha512-Z942RysHXmJrhqk88FmKBVq/v5tqmSkDz7p54G/MGyjMnCFFnC79XWNbg+Vta8W6Wb2qtSZTSxIGkJrRpCFEiA==", + "dev": true, + "requires": { + "pako": "~1.0.5" + } + }, + "browserslist": { + "version": "4.15.0", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.15.0.tgz", + "integrity": "sha512-IJ1iysdMkGmjjYeRlDU8PQejVwxvVO5QOfXH7ylW31GO6LwNRSmm/SgRXtNsEXqMLl2e+2H5eEJ7sfynF8TCaQ==", + "dev": true, + "requires": { + "caniuse-lite": "^1.0.30001164", + "colorette": "^1.2.1", + "electron-to-chromium": "^1.3.612", + "escalade": "^3.1.1", + "node-releases": "^1.1.67" + } + }, + "buffer": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.2.tgz", + "integrity": "sha512-xq+q3SRMOxGivLhBNaUdC64hDTQwejJ+H0T/NB1XMtTVEwNTrfFF3gAxiyW0Bu/xWEGhjVKgUcMhCrUy2+uCWg==", + "dev": true, + "requires": { + "base64-js": "^1.0.2", + "ieee754": "^1.1.4", + "isarray": "^1.0.0" + } + }, + "buffer-from": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", + "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", + "dev": true + }, + "buffer-indexof": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/buffer-indexof/-/buffer-indexof-1.1.1.tgz", + "integrity": "sha512-4/rOEg86jivtPTeOUUT61jJO1Ya1TrR/OkqCSZDyq84WJh3LuuiphBYJN+fm5xufIk4XAFcEwte/8WzC8If/1g==", + "dev": true + }, + "buffer-json": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/buffer-json/-/buffer-json-2.0.0.tgz", + "integrity": "sha512-+jjPFVqyfF1esi9fvfUs3NqM0pH1ziZ36VP4hmA/y/Ssfo/5w5xHKfTw9BwQjoJ1w/oVtpLomqwUHKdefGyuHw==", + "dev": true + }, + "buffer-xor": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz", + "integrity": "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk=", + "dev": true + }, + "builtin-status-codes": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz", + "integrity": "sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug=", + "dev": true + }, + "bytes": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", + "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==", + "dev": true + }, + "cacache": { + "version": "12.0.4", + "resolved": "https://registry.npmjs.org/cacache/-/cacache-12.0.4.tgz", + "integrity": "sha512-a0tMB40oefvuInr4Cwb3GerbL9xTj1D5yg0T5xrjGCGyfvbxseIXX7BAO/u/hIXdafzOI5JC3wDwHyf24buOAQ==", + "dev": true, + "requires": { + "bluebird": "^3.5.5", + "chownr": "^1.1.1", + "figgy-pudding": "^3.5.1", + "glob": "^7.1.4", + "graceful-fs": "^4.1.15", + "infer-owner": "^1.0.3", + "lru-cache": "^5.1.1", + "mississippi": "^3.0.0", + "mkdirp": "^0.5.1", + "move-concurrently": "^1.0.1", + "promise-inflight": "^1.0.1", + "rimraf": "^2.6.3", + "ssri": "^6.0.1", + "unique-filename": "^1.1.1", + "y18n": "^4.0.0" + } + }, + "cache-base": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", + "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", + "dev": true, + "requires": { + "collection-visit": "^1.0.0", + "component-emitter": "^1.2.1", + "get-value": "^2.0.6", + "has-value": "^1.0.0", + "isobject": "^3.0.1", + "set-value": "^2.0.0", + "to-object-path": "^0.3.0", + "union-value": "^1.0.0", + "unset-value": "^1.0.0" + } + }, + "cache-loader": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/cache-loader/-/cache-loader-4.1.0.tgz", + "integrity": "sha512-ftOayxve0PwKzBF/GLsZNC9fJBXl8lkZE3TOsjkboHfVHVkL39iUEs1FO07A33mizmci5Dudt38UZrrYXDtbhw==", + "dev": true, + "requires": { + "buffer-json": "^2.0.0", + "find-cache-dir": "^3.0.0", + "loader-utils": "^1.2.3", + "mkdirp": "^0.5.1", + "neo-async": "^2.6.1", + "schema-utils": "^2.0.0" + } + }, + "call-bind": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.0.tgz", + "integrity": "sha512-AEXsYIyyDY3MCzbwdhzG3Jx1R0J2wetQyUynn6dYHAO+bg8l1k7jwZtRv4ryryFs7EP+NDlikJlVe59jr0cM2w==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.0" + } + }, + "call-me-maybe": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/call-me-maybe/-/call-me-maybe-1.0.1.tgz", + "integrity": "sha1-JtII6onje1y95gJQoV8DHBak1ms=", + "dev": true + }, + "caller-callsite": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/caller-callsite/-/caller-callsite-2.0.0.tgz", + "integrity": "sha1-hH4PzgoiN1CpoCfFSzNzGtMVQTQ=", + "dev": true, + "requires": { + "callsites": "^2.0.0" + } + }, + "caller-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-2.0.0.tgz", + "integrity": "sha1-Ro+DBE42mrIBD6xfBs7uFbsssfQ=", + "dev": true, + "requires": { + "caller-callsite": "^2.0.0" + } + }, + "callsites": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-2.0.0.tgz", + "integrity": "sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA=", + "dev": true + }, + "camel-case": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-3.0.0.tgz", + "integrity": "sha1-yjw2iKTpzzpM2nd9xNy8cTJJz3M=", + "dev": true, + "requires": { + "no-case": "^2.2.0", + "upper-case": "^1.1.1" + } + }, + "camelcase": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.0.tgz", + "integrity": "sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==", + "dev": true + }, + "caniuse-api": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/caniuse-api/-/caniuse-api-3.0.0.tgz", + "integrity": "sha512-bsTwuIg/BZZK/vreVTYYbSWoe2F+71P7K5QGEX+pT250DZbfU1MQ5prOKpPR+LL6uWKK3KMwMCAS74QB3Um1uw==", + "dev": true, + "requires": { + "browserslist": "^4.0.0", + "caniuse-lite": "^1.0.0", + "lodash.memoize": "^4.1.2", + "lodash.uniq": "^4.5.0" + } + }, + "caniuse-lite": { + "version": "1.0.30001165", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001165.tgz", + "integrity": "sha512-8cEsSMwXfx7lWSUMA2s08z9dIgsnR5NAqjXP23stdsU3AUWkCr/rr4s4OFtHXn5XXr6+7kam3QFVoYyXNPdJPA==", + "dev": true + }, + "case-sensitive-paths-webpack-plugin": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/case-sensitive-paths-webpack-plugin/-/case-sensitive-paths-webpack-plugin-2.4.0.tgz", + "integrity": "sha512-roIFONhcxog0JSSWbvVAh3OocukmSgpqOH6YpMkCvav/ySIV3JKg4Dc8vYtQjYi/UxpNE36r/9v+VqTQqgkYmw==", + "dev": true + }, + "caseless": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", + "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", + "dev": true + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "chardet": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", + "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", + "dev": true + }, + "check-types": { + "version": "8.0.3", + "resolved": "https://registry.npmjs.org/check-types/-/check-types-8.0.3.tgz", + "integrity": "sha512-YpeKZngUmG65rLudJ4taU7VLkOCTMhNl/u4ctNC56LQS/zJTyNH0Lrtwm1tfTsbLlwvlfsA2d1c8vCf/Kh2KwQ==", + "dev": true + }, + "chokidar": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.4.3.tgz", + "integrity": "sha512-DtM3g7juCXQxFVSNPNByEC2+NImtBuxQQvWlHunpJIS5Ocr0lG306cC7FCi7cEA0fzmybPUIl4txBIobk1gGOQ==", + "dev": true, + "requires": { + "anymatch": "~3.1.1", + "braces": "~3.0.2", + "fsevents": "~2.1.2", + "glob-parent": "~5.1.0", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.5.0" + }, + "dependencies": { + "braces": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", + "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "dev": true, + "requires": { + "fill-range": "^7.0.1" + } + }, + "fill-range": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", + "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "dev": true, + "requires": { + "to-regex-range": "^5.0.1" + } + }, + "is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true + }, + "to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "requires": { + "is-number": "^7.0.0" + } + } + } + }, + "chownr": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", + "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", + "dev": true + }, + "chrome-trace-event": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.2.tgz", + "integrity": "sha512-9e/zx1jw7B4CO+c/RXoCsfg/x1AfUBioy4owYH0bJprEYAx5hRFLRhWBqHAG57D0ZM4H7vxbP7bPe0VwhQRYDQ==", + "dev": true, + "requires": { + "tslib": "^1.9.0" + } + }, + "ci-info": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-1.6.0.tgz", + "integrity": "sha512-vsGdkwSCDpWmP80ncATX7iea5DWQemg1UgCW5J8tqjU3lYw4FBYuj89J0CTVomA7BEfvSZd84GmHko+MxFQU2A==", + "dev": true + }, + "cipher-base": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/cipher-base/-/cipher-base-1.0.4.tgz", + "integrity": "sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q==", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "class-utils": { + "version": "0.3.6", + "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", + "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", + "dev": true, + "requires": { + "arr-union": "^3.1.0", + "define-property": "^0.2.5", + "isobject": "^3.0.0", + "static-extend": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "clean-css": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-4.2.3.tgz", + "integrity": "sha512-VcMWDN54ZN/DS+g58HYL5/n4Zrqe8vHJpGA8KdgUXFU4fuP/aHNw8eld9SyEIyabIMJX/0RaY/fplOo5hYLSFA==", + "dev": true, + "requires": { + "source-map": "~0.6.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "cli-cursor": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", + "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", + "dev": true, + "requires": { + "restore-cursor": "^2.0.0" + } + }, + "cli-highlight": { + "version": "2.1.11", + "resolved": "https://registry.npmjs.org/cli-highlight/-/cli-highlight-2.1.11.tgz", + "integrity": "sha512-9KDcoEVwyUXrjcJNvHD0NFc/hiwe/WPVYIleQh2O1N2Zro5gWJZ/K+3DGn8w8P/F6FxOgzyC5bxDyHIgCSPhGg==", + "dev": true, + "requires": { + "chalk": "^4.0.0", + "highlight.js": "^10.7.1", + "mz": "^2.4.0", + "parse5": "^5.1.1", + "parse5-htmlparser2-tree-adapter": "^6.0.0", + "yargs": "^16.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz", + "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, + "cli-spinners": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-2.5.0.tgz", + "integrity": "sha512-PC+AmIuK04E6aeSs/pUccSujsTzBhu4HzC2dL+CfJB/Jcc2qTRbEwZQDfIUpt2Xl8BodYBEq8w4fc0kU2I9DjQ==", + "dev": true + }, + "cli-width": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-3.0.0.tgz", + "integrity": "sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==", + "dev": true + }, + "clipboardy": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/clipboardy/-/clipboardy-2.3.0.tgz", + "integrity": "sha512-mKhiIL2DrQIsuXMgBgnfEHOZOryC7kY7YO//TN6c63wlEm3NG5tz+YgY5rVi29KCmq/QQjKYvM7a19+MDOTHOQ==", + "dev": true, + "requires": { + "arch": "^2.1.1", + "execa": "^1.0.0", + "is-wsl": "^2.1.1" + }, + "dependencies": { + "is-wsl": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz", + "integrity": "sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==", + "dev": true, + "requires": { + "is-docker": "^2.0.0" + } + } + } + }, + "cliui": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz", + "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", + "dev": true, + "requires": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.0", + "wrap-ansi": "^6.2.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "wrap-ansi": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", + "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", + "dev": true, + "requires": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + } + } + } + }, + "clone": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", + "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", + "dev": true + }, + "coa": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/coa/-/coa-2.0.2.tgz", + "integrity": "sha512-q5/jG+YQnSy4nRTV4F7lPepBJZ8qBNJJDBuJdoejDyLXgmL7IEo+Le2JDZudFTFt7mrCqIRaSjws4ygRCTCAXA==", + "dev": true, + "requires": { + "@types/q": "^1.5.1", + "chalk": "^2.4.1", + "q": "^1.1.2" + } + }, + "collection-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", + "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", + "dev": true, + "requires": { + "map-visit": "^1.0.0", + "object-visit": "^1.0.0" + } + }, + "color": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/color/-/color-3.2.1.tgz", + "integrity": "sha512-aBl7dZI9ENN6fUGC7mWpMTPNHmWUSNan9tuWN6ahh5ZLNk9baLJOnSMlrQkHcrfFgz2/RigjUVAjdx36VcemKA==", + "dev": true, + "requires": { + "color-convert": "^1.9.3", + "color-string": "^1.6.0" + } + }, + "color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", + "dev": true + }, + "color-string": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/color-string/-/color-string-1.6.0.tgz", + "integrity": "sha512-c/hGS+kRWJutUBEngKKmk4iH3sD59MBkoxVapS/0wgpCz2u7XsNloxknyvBhzwEs1IbV36D9PwqLPJ2DTu3vMA==", + "dev": true, + "requires": { + "color-name": "^1.0.0", + "simple-swizzle": "^0.2.2" + } + }, + "colorette": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/colorette/-/colorette-1.2.1.tgz", + "integrity": "sha512-puCDz0CzydiSYOrnXpz/PKd69zRrribezjtE9yd4zvytoRc8+RY/KJPvtPFKZS3E3wP6neGyMe0vOTlHO5L3Pw==", + "dev": true + }, + "combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "dev": true, + "requires": { + "delayed-stream": "~1.0.0" + } + }, + "commander": { + "version": "2.20.3", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", + "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", + "dev": true + }, + "commondir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", + "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", + "dev": true + }, + "component-emitter": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", + "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==", + "dev": true + }, + "compressible": { + "version": "2.0.18", + "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz", + "integrity": "sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==", + "dev": true, + "requires": { + "mime-db": ">= 1.43.0 < 2" + } + }, + "compression": { + "version": "1.7.4", + "resolved": "https://registry.npmjs.org/compression/-/compression-1.7.4.tgz", + "integrity": "sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ==", + "dev": true, + "requires": { + "accepts": "~1.3.5", + "bytes": "3.0.0", + "compressible": "~2.0.16", + "debug": "2.6.9", + "on-headers": "~1.0.2", + "safe-buffer": "5.1.2", + "vary": "~1.1.2" + }, + "dependencies": { + "bytes": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", + "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=", + "dev": true + }, + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + } + } + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", + "dev": true + }, + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + } + }, + "connect-history-api-fallback": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/connect-history-api-fallback/-/connect-history-api-fallback-1.6.0.tgz", + "integrity": "sha512-e54B99q/OUoH64zYYRf3HBP5z24G38h5D3qXu23JGRoigpX5Ss4r9ZnDk3g0Z8uQC2x2lPaJ+UlWBc1ZWBWdLg==", + "dev": true + }, + "consola": { + "version": "2.15.3", + "resolved": "https://registry.npmjs.org/consola/-/consola-2.15.3.tgz", + "integrity": "sha512-9vAdYbHj6x2fLKC4+oPH0kFzY/orMZyG2Aj+kNylHxKGJ/Ed4dpNyAQYwJOdqO4zdM7XpVHmyejQDcQHrnuXbw==" + }, + "console-browserify": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.2.0.tgz", + "integrity": "sha512-ZMkYO/LkF17QvCPqM0gxw8yUzigAOZOSWSHg91FH6orS7vcEj5dVZTidN2fQ14yBSdg97RqhSNwLUXInd52OTA==", + "dev": true + }, + "consolidate": { + "version": "0.15.1", + "resolved": "https://registry.npmjs.org/consolidate/-/consolidate-0.15.1.tgz", + "integrity": "sha512-DW46nrsMJgy9kqAbPt5rKaCr7uFtpo4mSUvLHIUbJEjm0vo+aY5QLwBUq3FK4tRnJr/X0Psc0C4jf/h+HtXSMw==", + "dev": true, + "requires": { + "bluebird": "^3.1.1" + } + }, + "constants-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/constants-browserify/-/constants-browserify-1.0.0.tgz", + "integrity": "sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U=", + "dev": true + }, + "content-disposition": { + "version": "0.5.3", + "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", + "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", + "dev": true, + "requires": { + "safe-buffer": "5.1.2" + } + }, + "content-type": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", + "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", + "dev": true + }, + "convert-source-map": { + "version": "1.8.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.8.0.tgz", + "integrity": "sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA==", + "dev": true, + "requires": { + "safe-buffer": "~5.1.1" + } + }, + "cookie": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", + "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==", + "dev": true + }, + "cookie-signature": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", + "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=", + "dev": true + }, + "copy-concurrently": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/copy-concurrently/-/copy-concurrently-1.0.5.tgz", + "integrity": "sha512-f2domd9fsVDFtaFcbaRZuYXwtdmnzqbADSwhSWYxYB/Q8zsdUUFMXVRwXGDMWmbEzAn1kdRrtI1T/KTFOL4X2A==", + "dev": true, + "requires": { + "aproba": "^1.1.1", + "fs-write-stream-atomic": "^1.0.8", + "iferr": "^0.1.5", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.4", + "run-queue": "^1.0.0" + } + }, + "copy-descriptor": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", + "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", + "dev": true + }, + "copy-webpack-plugin": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/copy-webpack-plugin/-/copy-webpack-plugin-5.1.2.tgz", + "integrity": "sha512-Uh7crJAco3AjBvgAy9Z75CjK8IG+gxaErro71THQ+vv/bl4HaQcpkexAY8KVW/T6D2W2IRr+couF/knIRkZMIQ==", + "dev": true, + "requires": { + "cacache": "^12.0.3", + "find-cache-dir": "^2.1.0", + "glob-parent": "^3.1.0", + "globby": "^7.1.1", + "is-glob": "^4.0.1", + "loader-utils": "^1.2.3", + "minimatch": "^3.0.4", + "normalize-path": "^3.0.0", + "p-limit": "^2.2.1", + "schema-utils": "^1.0.0", + "serialize-javascript": "^4.0.0", + "webpack-log": "^2.0.0" + }, + "dependencies": { + "find-cache-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", + "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", + "dev": true, + "requires": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + } + }, + "find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "requires": { + "locate-path": "^3.0.0" + } + }, + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "dev": true, + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "dev": true, + "requires": { + "is-extglob": "^2.1.0" + } + } + } + }, + "globby": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/globby/-/globby-7.1.1.tgz", + "integrity": "sha1-+yzP+UAfhgCUXfral0QMypcrhoA=", + "dev": true, + "requires": { + "array-union": "^1.0.1", + "dir-glob": "^2.0.0", + "glob": "^7.1.2", + "ignore": "^3.3.5", + "pify": "^3.0.0", + "slash": "^1.0.0" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + } + } + }, + "ignore": { + "version": "3.3.10", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.10.tgz", + "integrity": "sha512-Pgs951kaMm5GXP7MOvxERINe3gsaVjUWFm+UZPSq9xYriQAksyhg0csnS0KXSNRD5NmNdapXEpjxG49+AKh/ug==", + "dev": true + }, + "locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "dev": true, + "requires": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + } + }, + "make-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", + "dev": true, + "requires": { + "pify": "^4.0.1", + "semver": "^5.6.0" + } + }, + "p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "dev": true, + "requires": { + "p-limit": "^2.0.0" + } + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + }, + "pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", + "dev": true, + "requires": { + "find-up": "^3.0.0" + } + }, + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + }, + "slash": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", + "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=", + "dev": true + } + } + }, + "core-js": { + "version": "3.15.2", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.15.2.tgz", + "integrity": "sha512-tKs41J7NJVuaya8DxIOCnl8QuPHx5/ZVbFo1oKgVl1qHFBBrDctzQGtuLjPpRdNTWmKPH6oEvgN/MUID+l485Q==" + }, + "core-js-compat": { + "version": "3.15.2", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.15.2.tgz", + "integrity": "sha512-Wp+BJVvwopjI+A1EFqm2dwUmWYXrvucmtIB2LgXn/Rb+gWPKYxtmb4GKHGKG/KGF1eK9jfjzT38DITbTOCX/SQ==", + "dev": true, + "requires": { + "browserslist": "^4.16.6", + "semver": "7.0.0" + }, + "dependencies": { + "browserslist": { + "version": "4.16.6", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.16.6.tgz", + "integrity": "sha512-Wspk/PqO+4W9qp5iUTJsa1B/QrYn1keNCcEP5OvP7WBwT4KaDly0uONYmC6Xa3Z5IqnUgS0KcgLYu1l74x0ZXQ==", + "dev": true, + "requires": { + "caniuse-lite": "^1.0.30001219", + "colorette": "^1.2.2", + "electron-to-chromium": "^1.3.723", + "escalade": "^3.1.1", + "node-releases": "^1.1.71" + } + }, + "caniuse-lite": { + "version": "1.0.30001245", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001245.tgz", + "integrity": "sha512-768fM9j1PKXpOCKws6eTo3RHmvTUsG9UrpT4WoREFeZgJBTi4/X9g565azS/rVUGtqb8nt7FjLeF5u4kukERnA==", + "dev": true + }, + "colorette": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/colorette/-/colorette-1.2.2.tgz", + "integrity": "sha512-MKGMzyfeuutC/ZJ1cba9NqcNpfeqMUcYmyF1ZFY6/Cn7CNSAKx6a+s48sqLqyAiZuaP2TcqMhoo+dlwFnVxT9w==", + "dev": true + }, + "electron-to-chromium": { + "version": "1.3.779", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.779.tgz", + "integrity": "sha512-nreave0y/1Qhmo8XtO6C/LpawNyC6U26+q7d814/e+tIqUK073pM+4xW7WUXyqCRa5K4wdxHmNMBAi8ap9nEew==", + "dev": true + }, + "node-releases": { + "version": "1.1.73", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.73.tgz", + "integrity": "sha512-uW7fodD6pyW2FZNZnp/Z3hvWKeEW1Y8R1+1CnErE8cXFXzl5blBOoVB41CvMer6P6Q0S5FXDwcHgFd1Wj0U9zg==", + "dev": true + }, + "semver": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz", + "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==", + "dev": true + } + } + }, + "core-util-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", + "dev": true + }, + "cosmiconfig": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-5.2.1.tgz", + "integrity": "sha512-H65gsXo1SKjf8zmrJ67eJk8aIRKV5ff2D4uKZIBZShbhGSpEmsQOPW/SKMKYhSTrqR7ufy6RP69rPogdaPh/kA==", + "dev": true, + "requires": { + "import-fresh": "^2.0.0", + "is-directory": "^0.3.1", + "js-yaml": "^3.13.1", + "parse-json": "^4.0.0" + }, + "dependencies": { + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + } + } + }, + "create-ecdh": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/create-ecdh/-/create-ecdh-4.0.4.tgz", + "integrity": "sha512-mf+TCx8wWc9VpuxfP2ht0iSISLZnt0JgWlrOKZiNqyUZWnjIaCIVNQArMHnCZKfEYRg6IM7A+NeJoN8gf/Ws0A==", + "dev": true, + "requires": { + "bn.js": "^4.1.0", + "elliptic": "^6.5.3" + }, + "dependencies": { + "bn.js": { + "version": "4.11.9", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.9.tgz", + "integrity": "sha512-E6QoYqCKZfgatHTdHzs1RRKP7ip4vvm+EyRUeE2RF0NblwVvb0p6jSVeNTOFxPn26QXN2o6SMfNxKp6kU8zQaw==", + "dev": true + } + } + }, + "create-hash": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/create-hash/-/create-hash-1.2.0.tgz", + "integrity": "sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg==", + "dev": true, + "requires": { + "cipher-base": "^1.0.1", + "inherits": "^2.0.1", + "md5.js": "^1.3.4", + "ripemd160": "^2.0.1", + "sha.js": "^2.4.0" + } + }, + "create-hmac": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/create-hmac/-/create-hmac-1.1.7.tgz", + "integrity": "sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg==", + "dev": true, + "requires": { + "cipher-base": "^1.0.3", + "create-hash": "^1.1.0", + "inherits": "^2.0.1", + "ripemd160": "^2.0.0", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + } + }, + "cross-spawn": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", + "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "dev": true, + "requires": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "crypto-browserify": { + "version": "3.12.0", + "resolved": "https://registry.npmjs.org/crypto-browserify/-/crypto-browserify-3.12.0.tgz", + "integrity": "sha512-fz4spIh+znjO2VjL+IdhEpRJ3YN6sMzITSBijk6FK2UvTqruSQW+/cCZTSNsMiZNvUeq0CqurF+dAbyiGOY6Wg==", + "dev": true, + "requires": { + "browserify-cipher": "^1.0.0", + "browserify-sign": "^4.0.0", + "create-ecdh": "^4.0.0", + "create-hash": "^1.1.0", + "create-hmac": "^1.1.0", + "diffie-hellman": "^5.0.0", + "inherits": "^2.0.1", + "pbkdf2": "^3.0.3", + "public-encrypt": "^4.0.0", + "randombytes": "^2.0.0", + "randomfill": "^1.0.3" + } + }, + "css-color-names": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/css-color-names/-/css-color-names-0.0.4.tgz", + "integrity": "sha1-gIrcLnnPhHOAabZGyyDsJ762KeA=", + "dev": true + }, + "css-declaration-sorter": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/css-declaration-sorter/-/css-declaration-sorter-4.0.1.tgz", + "integrity": "sha512-BcxQSKTSEEQUftYpBVnsH4SF05NTuBokb19/sBt6asXGKZ/6VP7PLG1CBCkFDYOnhXhPh0jMhO6xZ71oYHXHBA==", + "dev": true, + "requires": { + "postcss": "^7.0.1", + "timsort": "^0.3.0" + } + }, + "css-loader": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-3.6.0.tgz", + "integrity": "sha512-M5lSukoWi1If8dhQAUCvj4H8vUt3vOnwbQBH9DdTm/s4Ym2B/3dPMtYZeJmq7Q3S3Pa+I94DcZ7pc9bP14cWIQ==", + "dev": true, + "requires": { + "camelcase": "^5.3.1", + "cssesc": "^3.0.0", + "icss-utils": "^4.1.1", + "loader-utils": "^1.2.3", + "normalize-path": "^3.0.0", + "postcss": "^7.0.32", + "postcss-modules-extract-imports": "^2.0.0", + "postcss-modules-local-by-default": "^3.0.2", + "postcss-modules-scope": "^2.2.0", + "postcss-modules-values": "^3.0.0", + "postcss-value-parser": "^4.1.0", + "schema-utils": "^2.7.0", + "semver": "^6.3.0" + }, + "dependencies": { + "camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "dev": true + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "css-select": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/css-select/-/css-select-2.1.0.tgz", + "integrity": "sha512-Dqk7LQKpwLoH3VovzZnkzegqNSuAziQyNZUcrdDM401iY+R5NkGBXGmtO05/yaXQziALuPogeG0b7UAgjnTJTQ==", + "dev": true, + "requires": { + "boolbase": "^1.0.0", + "css-what": "^3.2.1", + "domutils": "^1.7.0", + "nth-check": "^1.0.2" + } + }, + "css-select-base-adapter": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/css-select-base-adapter/-/css-select-base-adapter-0.1.1.tgz", + "integrity": "sha512-jQVeeRG70QI08vSTwf1jHxp74JoZsr2XSgETae8/xC8ovSnL2WF87GTLO86Sbwdt2lK4Umg4HnnwMO4YF3Ce7w==", + "dev": true + }, + "css-tree": { + "version": "1.0.0-alpha.37", + "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-1.0.0-alpha.37.tgz", + "integrity": "sha512-DMxWJg0rnz7UgxKT0Q1HU/L9BeJI0M6ksor0OgqOnF+aRCDWg/N2641HmVyU9KVIu0OVVWOb2IpC9A+BJRnejg==", + "dev": true, + "requires": { + "mdn-data": "2.0.4", + "source-map": "^0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "css-what": { + "version": "3.4.2", + "resolved": "https://registry.npmjs.org/css-what/-/css-what-3.4.2.tgz", + "integrity": "sha512-ACUm3L0/jiZTqfzRM3Hi9Q8eZqd6IK37mMWPLz9PJxkLWllYeRf+EHUSHYEtFop2Eqytaq1FizFVh7XfBnXCDQ==", + "dev": true + }, + "cssesc": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", + "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", + "dev": true + }, + "cssnano": { + "version": "4.1.11", + "resolved": "https://registry.npmjs.org/cssnano/-/cssnano-4.1.11.tgz", + "integrity": "sha512-6gZm2htn7xIPJOHY824ERgj8cNPgPxyCSnkXc4v7YvNW+TdVfzgngHcEhy/8D11kUWRUMbke+tC+AUcUsnMz2g==", + "dev": true, + "requires": { + "cosmiconfig": "^5.0.0", + "cssnano-preset-default": "^4.0.8", + "is-resolvable": "^1.0.0", + "postcss": "^7.0.0" + } + }, + "cssnano-preset-default": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/cssnano-preset-default/-/cssnano-preset-default-4.0.8.tgz", + "integrity": "sha512-LdAyHuq+VRyeVREFmuxUZR1TXjQm8QQU/ktoo/x7bz+SdOge1YKc5eMN6pRW7YWBmyq59CqYba1dJ5cUukEjLQ==", + "dev": true, + "requires": { + "css-declaration-sorter": "^4.0.1", + "cssnano-util-raw-cache": "^4.0.1", + "postcss": "^7.0.0", + "postcss-calc": "^7.0.1", + "postcss-colormin": "^4.0.3", + "postcss-convert-values": "^4.0.1", + "postcss-discard-comments": "^4.0.2", + "postcss-discard-duplicates": "^4.0.2", + "postcss-discard-empty": "^4.0.1", + "postcss-discard-overridden": "^4.0.1", + "postcss-merge-longhand": "^4.0.11", + "postcss-merge-rules": "^4.0.3", + "postcss-minify-font-values": "^4.0.2", + "postcss-minify-gradients": "^4.0.2", + "postcss-minify-params": "^4.0.2", + "postcss-minify-selectors": "^4.0.2", + "postcss-normalize-charset": "^4.0.1", + "postcss-normalize-display-values": "^4.0.2", + "postcss-normalize-positions": "^4.0.2", + "postcss-normalize-repeat-style": "^4.0.2", + "postcss-normalize-string": "^4.0.2", + "postcss-normalize-timing-functions": "^4.0.2", + "postcss-normalize-unicode": "^4.0.1", + "postcss-normalize-url": "^4.0.1", + "postcss-normalize-whitespace": "^4.0.2", + "postcss-ordered-values": "^4.1.2", + "postcss-reduce-initial": "^4.0.3", + "postcss-reduce-transforms": "^4.0.2", + "postcss-svgo": "^4.0.3", + "postcss-unique-selectors": "^4.0.1" + } + }, + "cssnano-util-get-arguments": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/cssnano-util-get-arguments/-/cssnano-util-get-arguments-4.0.0.tgz", + "integrity": "sha1-7ToIKZ8h11dBsg87gfGU7UnMFQ8=", + "dev": true + }, + "cssnano-util-get-match": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/cssnano-util-get-match/-/cssnano-util-get-match-4.0.0.tgz", + "integrity": "sha1-wOTKB/U4a7F+xeUiULT1lhNlFW0=", + "dev": true + }, + "cssnano-util-raw-cache": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/cssnano-util-raw-cache/-/cssnano-util-raw-cache-4.0.1.tgz", + "integrity": "sha512-qLuYtWK2b2Dy55I8ZX3ky1Z16WYsx544Q0UWViebptpwn/xDBmog2TLg4f+DBMg1rJ6JDWtn96WHbOKDWt1WQA==", + "dev": true, + "requires": { + "postcss": "^7.0.0" + } + }, + "cssnano-util-same-parent": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/cssnano-util-same-parent/-/cssnano-util-same-parent-4.0.1.tgz", + "integrity": "sha512-WcKx5OY+KoSIAxBW6UBBRay1U6vkYheCdjyVNDm85zt5K9mHoGOfsOsqIszfAqrQQFIIKgjh2+FDgIj/zsl21Q==", + "dev": true + }, + "csso": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/csso/-/csso-4.2.0.tgz", + "integrity": "sha512-wvlcdIbf6pwKEk7vHj8/Bkc0B4ylXZruLvOgs9doS5eOsOpuodOV2zJChSpkp+pRpYQLQMeF04nr3Z68Sta9jA==", + "dev": true, + "requires": { + "css-tree": "^1.1.2" + }, + "dependencies": { + "css-tree": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-1.1.3.tgz", + "integrity": "sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q==", + "dev": true, + "requires": { + "mdn-data": "2.0.14", + "source-map": "^0.6.1" + } + }, + "mdn-data": { + "version": "2.0.14", + "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.14.tgz", + "integrity": "sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow==", + "dev": true + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "cyclist": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cyclist/-/cyclist-1.0.1.tgz", + "integrity": "sha1-WW6WmP0MgOEgOMK4LW6xs1tiJNk=", + "dev": true + }, + "dashdash": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", + "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", + "dev": true, + "requires": { + "assert-plus": "^1.0.0" + } + }, + "de-indent": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/de-indent/-/de-indent-1.0.2.tgz", + "integrity": "sha1-sgOOhG3DO6pXlhKNCAS0VbjB4h0=", + "dev": true + }, + "debug": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", + "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", + "dev": true, + "requires": { + "ms": "2.1.2" + } + }, + "decamelize": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", + "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", + "dev": true + }, + "decode-uri-component": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", + "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", + "dev": true + }, + "deep-equal": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.1.1.tgz", + "integrity": "sha512-yd9c5AdiqVcR+JjcwUQb9DkhJc8ngNr0MahEBGvDiJw8puWab2yZlh+nkasOnZP+EGTAP6rRp2JzJhJZzvNF8g==", + "dev": true, + "requires": { + "is-arguments": "^1.0.4", + "is-date-object": "^1.0.1", + "is-regex": "^1.0.4", + "object-is": "^1.0.1", + "object-keys": "^1.1.1", + "regexp.prototype.flags": "^1.2.0" + } + }, + "deep-is": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", + "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", + "dev": true + }, + "deepmerge": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-1.5.2.tgz", + "integrity": "sha512-95k0GDqvBjZavkuvzx/YqVLv/6YYa17fz6ILMSf7neqQITCPbnfEnQvEgMPNjH4kgobe7+WIL0yJEHku+H3qtQ==", + "dev": true + }, + "default-gateway": { + "version": "5.0.5", + "resolved": "https://registry.npmjs.org/default-gateway/-/default-gateway-5.0.5.tgz", + "integrity": "sha512-z2RnruVmj8hVMmAnEJMTIJNijhKCDiGjbLP+BHJFOT7ld3Bo5qcIBpVYDniqhbMIIf+jZDlkP2MkPXiQy/DBLA==", + "dev": true, + "requires": { + "execa": "^3.3.0" + }, + "dependencies": { + "cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "requires": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + } + }, + "execa": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-3.4.0.tgz", + "integrity": "sha512-r9vdGQk4bmCuK1yKQu1KTwcT2zwfWdbdaXfCtAh+5nU/4fSX+JAb7vZGvI5naJrQlvONrEB20jeruESI69530g==", + "dev": true, + "requires": { + "cross-spawn": "^7.0.0", + "get-stream": "^5.0.0", + "human-signals": "^1.1.1", + "is-stream": "^2.0.0", + "merge-stream": "^2.0.0", + "npm-run-path": "^4.0.0", + "onetime": "^5.1.0", + "p-finally": "^2.0.0", + "signal-exit": "^3.0.2", + "strip-final-newline": "^2.0.0" + } + }, + "get-stream": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", + "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", + "dev": true, + "requires": { + "pump": "^3.0.0" + } + }, + "is-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", + "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==", + "dev": true + }, + "mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", + "dev": true + }, + "npm-run-path": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", + "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", + "dev": true, + "requires": { + "path-key": "^3.0.0" + } + }, + "onetime": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", + "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", + "dev": true, + "requires": { + "mimic-fn": "^2.1.0" + } + }, + "p-finally": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-2.0.1.tgz", + "integrity": "sha512-vpm09aKwq6H9phqRQzecoDpD8TmVyGw70qmWlyq5onxY7tqyTTFVvxMykxQSQKILBSFlbXpypIw2T1Ml7+DDtw==", + "dev": true + }, + "path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true + }, + "shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "requires": { + "shebang-regex": "^3.0.0" + } + }, + "shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true + }, + "which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + } + } + }, + "defaults": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/defaults/-/defaults-1.0.3.tgz", + "integrity": "sha1-xlYFHpgX2f8I7YgUd/P+QBnz730=", + "dev": true, + "requires": { + "clone": "^1.0.2" + } + }, + "define-properties": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", + "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", + "dev": true, + "requires": { + "object-keys": "^1.0.12" + } + }, + "define-property": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", + "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", + "dev": true, + "requires": { + "is-descriptor": "^1.0.2", + "isobject": "^3.0.1" + }, + "dependencies": { + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "del": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/del/-/del-4.1.1.tgz", + "integrity": "sha512-QwGuEUouP2kVwQenAsOof5Fv8K9t3D8Ca8NxcXKrIpEHjTXK5J2nXLdP+ALI1cgv8wj7KuwBhTwBkOZSJKM5XQ==", + "dev": true, + "requires": { + "@types/glob": "^7.1.1", + "globby": "^6.1.0", + "is-path-cwd": "^2.0.0", + "is-path-in-cwd": "^2.0.0", + "p-map": "^2.0.0", + "pify": "^4.0.1", + "rimraf": "^2.6.3" + }, + "dependencies": { + "globby": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-6.1.0.tgz", + "integrity": "sha1-9abXDoOV4hyFj7BInWTfAkJNUGw=", + "dev": true, + "requires": { + "array-union": "^1.0.1", + "glob": "^7.0.3", + "object-assign": "^4.0.1", + "pify": "^2.0.0", + "pinkie-promise": "^2.0.0" + }, + "dependencies": { + "pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", + "dev": true + } + } + } + } + }, + "delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", + "dev": true + }, + "depd": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", + "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", + "dev": true + }, + "des.js": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/des.js/-/des.js-1.0.1.tgz", + "integrity": "sha512-Q0I4pfFrv2VPd34/vfLrFOoRmlYj3OV50i7fskps1jZWK1kApMWWT9G6RRUeYedLcBDIhnSDaUvJMb3AhUlaEA==", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0" + } + }, + "destroy": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", + "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=", + "dev": true + }, + "detect-node": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/detect-node/-/detect-node-2.1.0.tgz", + "integrity": "sha512-T0NIuQpnTvFDATNuHN5roPwSBG83rFsuO+MXXH9/3N1eFbn4wcPjttvjMLEPWJ0RGUYgQE7cGgS3tNxbqCGM7g==", + "dev": true + }, + "diffie-hellman": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/diffie-hellman/-/diffie-hellman-5.0.3.tgz", + "integrity": "sha512-kqag/Nl+f3GwyK25fhUMYj81BUOrZ9IuJsjIcDE5icNM9FJHAVm3VcUDxdLPoQtTuUylWm6ZIknYJwwaPxsUzg==", + "dev": true, + "requires": { + "bn.js": "^4.1.0", + "miller-rabin": "^4.0.0", + "randombytes": "^2.0.0" + }, + "dependencies": { + "bn.js": { + "version": "4.11.9", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.9.tgz", + "integrity": "sha512-E6QoYqCKZfgatHTdHzs1RRKP7ip4vvm+EyRUeE2RF0NblwVvb0p6jSVeNTOFxPn26QXN2o6SMfNxKp6kU8zQaw==", + "dev": true + } + } + }, + "dir-glob": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-2.2.2.tgz", + "integrity": "sha512-f9LBi5QWzIW3I6e//uxZoLBlUt9kcp66qo0sSCxL6YZKc75R1c4MFCoe/LaZiBGmgujvQdxc5Bn3QhfyvK5Hsw==", + "dev": true, + "requires": { + "path-type": "^3.0.0" + } + }, + "dns-equal": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/dns-equal/-/dns-equal-1.0.0.tgz", + "integrity": "sha1-s55/HabrCnW6nBcySzR1PEfgZU0=", + "dev": true + }, + "dns-packet": { + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/dns-packet/-/dns-packet-1.3.4.tgz", + "integrity": "sha512-BQ6F4vycLXBvdrJZ6S3gZewt6rcrks9KBgM9vrhW+knGRqc8uEdT7fuCwloc7nny5xNoMJ17HGH0R/6fpo8ECA==", + "dev": true, + "requires": { + "ip": "^1.1.0", + "safe-buffer": "^5.0.1" + } + }, + "dns-txt": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/dns-txt/-/dns-txt-2.0.2.tgz", + "integrity": "sha1-uR2Ab10nGI5Ks+fRB9iBocxGQrY=", + "dev": true, + "requires": { + "buffer-indexof": "^1.0.0" + } + }, + "doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "requires": { + "esutils": "^2.0.2" + } + }, + "dom-converter": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/dom-converter/-/dom-converter-0.2.0.tgz", + "integrity": "sha512-gd3ypIPfOMr9h5jIKq8E3sHOTCjeirnl0WK5ZdS1AW0Odt0b1PaWaHdJ4Qk4klv+YB9aJBS7mESXjFoDQPu6DA==", + "dev": true, + "requires": { + "utila": "~0.4" + } + }, + "dom-serializer": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.2.2.tgz", + "integrity": "sha512-2/xPb3ORsQ42nHYiSunXkDjPLBaEj/xTwUO4B7XCZQTRk7EBtTOPaygh10YAAh2OI1Qrp6NWfpAhzswj0ydt9g==", + "dev": true, + "requires": { + "domelementtype": "^2.0.1", + "entities": "^2.0.0" + }, + "dependencies": { + "domelementtype": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.2.0.tgz", + "integrity": "sha512-DtBMo82pv1dFtUmHyr48beiuq792Sxohr+8Hm9zoxklYPfa6n0Z3Byjj2IV7bmr2IyqClnqEQhfgHJJ5QF0R5A==", + "dev": true + } + } + }, + "domain-browser": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/domain-browser/-/domain-browser-1.2.0.tgz", + "integrity": "sha512-jnjyiM6eRyZl2H+W8Q/zLMA481hzi0eszAaBUzIVnmYVDBbnLxVNnfu1HgEBvCbL+71FrxMl3E6lpKH7Ge3OXA==", + "dev": true + }, + "domelementtype": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz", + "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==", + "dev": true + }, + "domhandler": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.2.0.tgz", + "integrity": "sha512-zk7sgt970kzPks2Bf+dwT/PLzghLnsivb9CcxkvR8Mzr66Olr0Ofd8neSbglHJHaHa2MadfoSdNlKYAaafmWfA==", + "dev": true, + "requires": { + "domelementtype": "^2.2.0" + }, + "dependencies": { + "domelementtype": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.2.0.tgz", + "integrity": "sha512-DtBMo82pv1dFtUmHyr48beiuq792Sxohr+8Hm9zoxklYPfa6n0Z3Byjj2IV7bmr2IyqClnqEQhfgHJJ5QF0R5A==", + "dev": true + } + } + }, + "domutils": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.7.0.tgz", + "integrity": "sha512-Lgd2XcJ/NjEw+7tFvfKxOzCYKZsdct5lczQ2ZaQY8Djz7pfAD3Gbp8ySJWtreII/vDlMVmxwa6pHmdxIYgttDg==", + "dev": true, + "requires": { + "dom-serializer": "0", + "domelementtype": "1" + } + }, + "dot-prop": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz", + "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==", + "dev": true, + "requires": { + "is-obj": "^2.0.0" + } + }, + "dotenv": { + "version": "8.6.0", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.6.0.tgz", + "integrity": "sha512-IrPdXQsk2BbzvCBGBOTmmSH5SodmqZNt4ERAZDmW4CT+tL8VtvinqywuANaFu4bOMWki16nqf0e4oC0QIaDr/g==", + "dev": true + }, + "dotenv-expand": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/dotenv-expand/-/dotenv-expand-5.1.0.tgz", + "integrity": "sha512-YXQl1DSa4/PQyRfgrv6aoNjhasp/p4qs9FjJ4q4cQk+8m4r6k4ZSiEyytKG8f8W9gi8WsQtIObNmKd+tMzNTmA==", + "dev": true + }, + "duplexer": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.2.tgz", + "integrity": "sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg==", + "dev": true + }, + "duplexify": { + "version": "3.7.1", + "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.7.1.tgz", + "integrity": "sha512-07z8uv2wMyS51kKhD1KsdXJg5WQ6t93RneqRxUHnskXVtlYYkLqM0gqStQZ3pj073g687jPCHrqNfCzawLYh5g==", + "dev": true, + "requires": { + "end-of-stream": "^1.0.0", + "inherits": "^2.0.1", + "readable-stream": "^2.0.0", + "stream-shift": "^1.0.0" + } + }, + "easy-stack": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/easy-stack/-/easy-stack-1.0.1.tgz", + "integrity": "sha512-wK2sCs4feiiJeFXn3zvY0p41mdU5VUgbgs1rNsc/y5ngFUijdWd+iIN8eoyuZHKB8xN6BL4PdWmzqFmxNg6V2w==", + "dev": true + }, + "ecc-jsbn": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", + "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", + "dev": true, + "requires": { + "jsbn": "~0.1.0", + "safer-buffer": "^2.1.0" + } + }, + "ee-first": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", + "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=", + "dev": true + }, + "ejs": { + "version": "2.7.4", + "resolved": "https://registry.npmjs.org/ejs/-/ejs-2.7.4.tgz", + "integrity": "sha512-7vmuyh5+kuUyJKePhQfRQBhXV5Ce+RnaeeQArKu1EAMpL3WbgMt5WG6uQZpEVvYSSsxMXRKOewtDk9RaTKXRlA==", + "dev": true + }, + "electron-to-chromium": { + "version": "1.3.619", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.619.tgz", + "integrity": "sha512-WFGatwtk7Fw0QcKCZzfGD72hvbcXV8kLY8aFuj0Ip0QRnOtyLYMsc+wXbSjb2w4lk1gcAeNU1/lQ20A+tvuypQ==", + "dev": true + }, + "elliptic": { + "version": "6.5.3", + "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.5.3.tgz", + "integrity": "sha512-IMqzv5wNQf+E6aHeIqATs0tOLeOTwj1QKbRcS3jBbYkl5oLAserA8yJTT7/VyHUYG91PRmPyeQDObKLPpeS4dw==", + "dev": true, + "requires": { + "bn.js": "^4.4.0", + "brorand": "^1.0.1", + "hash.js": "^1.0.0", + "hmac-drbg": "^1.0.0", + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0", + "minimalistic-crypto-utils": "^1.0.0" + }, + "dependencies": { + "bn.js": { + "version": "4.11.9", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.9.tgz", + "integrity": "sha512-E6QoYqCKZfgatHTdHzs1RRKP7ip4vvm+EyRUeE2RF0NblwVvb0p6jSVeNTOFxPn26QXN2o6SMfNxKp6kU8zQaw==", + "dev": true + } + } + }, + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "emojis-list": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-3.0.0.tgz", + "integrity": "sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q==", + "dev": true + }, + "encodeurl": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", + "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", + "dev": true + }, + "end-of-stream": { + "version": "1.4.4", + "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", + "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", + "dev": true, + "requires": { + "once": "^1.4.0" + } + }, + "enhanced-resolve": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-4.3.0.tgz", + "integrity": "sha512-3e87LvavsdxyoCfGusJnrZ5G8SLPOFeHSNpZI/ATL9a5leXo2k0w6MKnbqhdBad9qTobSfB20Ld7UmgoNbAZkQ==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "memory-fs": "^0.5.0", + "tapable": "^1.0.0" + }, + "dependencies": { + "memory-fs": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.5.0.tgz", + "integrity": "sha512-jA0rdU5KoQMC0e6ppoNRtpp6vjFq6+NY7r8hywnC7V+1Xj/MtHwGIbB1QaK/dunyjWteJzmkpd7ooeWg10T7GA==", + "dev": true, + "requires": { + "errno": "^0.1.3", + "readable-stream": "^2.0.1" + } + } + } + }, + "enquirer": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", + "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", + "dev": true, + "requires": { + "ansi-colors": "^4.1.1" + }, + "dependencies": { + "ansi-colors": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", + "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", + "dev": true + } + } + }, + "entities": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", + "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", + "dev": true + }, + "errno": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.7.tgz", + "integrity": "sha512-MfrRBDWzIWifgq6tJj60gkAwtLNb6sQPlcFrSOflcP1aFmmruKQ2wRnze/8V6kgyz7H3FF8Npzv78mZ7XLLflg==", + "dev": true, + "requires": { + "prr": "~1.0.1" + } + }, + "error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "requires": { + "is-arrayish": "^0.2.1" + } + }, + "error-stack-parser": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/error-stack-parser/-/error-stack-parser-2.0.6.tgz", + "integrity": "sha512-d51brTeqC+BHlwF0BhPtcYgF5nlzf9ZZ0ZIUQNZpc9ZB9qw5IJ2diTrBY9jlCJkTLITYPjmiX6OWCwH+fuyNgQ==", + "dev": true, + "requires": { + "stackframe": "^1.1.1" + } + }, + "es-abstract": { + "version": "1.18.3", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.18.3.tgz", + "integrity": "sha512-nQIr12dxV7SSxE6r6f1l3DtAeEYdsGpps13dR0TwJg1S8gyp4ZPgy3FZcHBgbiQqnoqSTb+oC+kO4UQ0C/J8vw==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "es-to-primitive": "^1.2.1", + "function-bind": "^1.1.1", + "get-intrinsic": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.2", + "is-callable": "^1.2.3", + "is-negative-zero": "^2.0.1", + "is-regex": "^1.1.3", + "is-string": "^1.0.6", + "object-inspect": "^1.10.3", + "object-keys": "^1.1.1", + "object.assign": "^4.1.2", + "string.prototype.trimend": "^1.0.4", + "string.prototype.trimstart": "^1.0.4", + "unbox-primitive": "^1.0.1" + }, + "dependencies": { + "call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + } + }, + "get-intrinsic": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", + "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + } + }, + "has-symbols": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", + "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", + "dev": true + } + } + }, + "es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", + "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", + "dev": true, + "requires": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + } + }, + "escalade": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", + "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "dev": true + }, + "escape-html": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", + "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=", + "dev": true + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", + "dev": true + }, + "eslint": { + "version": "7.31.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.31.0.tgz", + "integrity": "sha512-vafgJpSh2ia8tnTkNUkwxGmnumgckLh5aAbLa1xRmIn9+owi8qBNGKL+B881kNKNTy7FFqTEkpNkUvmw0n6PkA==", + "dev": true, + "requires": { + "@babel/code-frame": "7.12.11", + "@eslint/eslintrc": "^0.4.3", + "@humanwhocodes/config-array": "^0.5.0", + "ajv": "^6.10.0", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.0.1", + "doctrine": "^3.0.0", + "enquirer": "^2.3.5", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^5.1.1", + "eslint-utils": "^2.1.0", + "eslint-visitor-keys": "^2.0.0", + "espree": "^7.3.1", + "esquery": "^1.4.0", + "esutils": "^2.0.2", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^6.0.1", + "functional-red-black-tree": "^1.0.1", + "glob-parent": "^5.1.2", + "globals": "^13.6.0", + "ignore": "^4.0.6", + "import-fresh": "^3.0.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "js-yaml": "^3.13.1", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.4.1", + "lodash.merge": "^4.6.2", + "minimatch": "^3.0.4", + "natural-compare": "^1.4.0", + "optionator": "^0.9.1", + "progress": "^2.0.0", + "regexpp": "^3.1.0", + "semver": "^7.2.1", + "strip-ansi": "^6.0.0", + "strip-json-comments": "^3.1.0", + "table": "^6.0.9", + "text-table": "^0.2.0", + "v8-compile-cache": "^2.0.3" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", + "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.10.4" + } + }, + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz", + "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "requires": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + } + }, + "escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true + }, + "eslint-scope": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", + "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", + "dev": true, + "requires": { + "esrecurse": "^4.3.0", + "estraverse": "^4.1.1" + } + }, + "eslint-visitor-keys": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", + "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", + "dev": true + }, + "glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "requires": { + "is-glob": "^4.0.1" + } + }, + "globals": { + "version": "13.10.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.10.0.tgz", + "integrity": "sha512-piHC3blgLGFjvOuMmWZX60f+na1lXFDhQXBf1UYp2fXPXqvEUbOhNwi6BsQ0bQishwedgnjkwv1d9zKf+MWw3g==", + "dev": true, + "requires": { + "type-fest": "^0.20.2" + } + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true + }, + "import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + } + }, + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + } + }, + "path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true + }, + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true + }, + "semver": { + "version": "7.3.5", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", + "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + }, + "shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "requires": { + "shebang-regex": "^3.0.0" + } + }, + "shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + }, + "type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true + }, + "which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + } + } + }, + "eslint-loader": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/eslint-loader/-/eslint-loader-2.2.1.tgz", + "integrity": "sha512-RLgV9hoCVsMLvOxCuNjdqOrUqIj9oJg8hF44vzJaYqsAHuY9G2YAeN3joQ9nxP0p5Th9iFSIpKo+SD8KISxXRg==", + "dev": true, + "requires": { + "loader-fs-cache": "^1.0.0", + "loader-utils": "^1.0.2", + "object-assign": "^4.0.1", + "object-hash": "^1.1.4", + "rimraf": "^2.6.1" + } + }, + "eslint-plugin-vue": { + "version": "7.14.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-vue/-/eslint-plugin-vue-7.14.0.tgz", + "integrity": "sha512-IW5A2Td0wEWjFGaGVEO24JNXa8cVFzAQTXrYv/Vu3zyDVS9sjwOpZY0iqub7FOkT2AK3Imtw4U4wg48pP9oWww==", + "dev": true, + "requires": { + "eslint-utils": "^2.1.0", + "natural-compare": "^1.4.0", + "semver": "^6.3.0", + "vue-eslint-parser": "^7.9.0" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "eslint-scope": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", + "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", + "dev": true, + "requires": { + "esrecurse": "^4.1.0", + "estraverse": "^4.1.1" + } + }, + "eslint-utils": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", + "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", + "dev": true, + "requires": { + "eslint-visitor-keys": "^1.1.0" + } + }, + "eslint-visitor-keys": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", + "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", + "dev": true + }, + "espree": { + "version": "7.3.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", + "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", + "dev": true, + "requires": { + "acorn": "^7.4.0", + "acorn-jsx": "^5.3.1", + "eslint-visitor-keys": "^1.3.0" + }, + "dependencies": { + "acorn": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", + "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", + "dev": true + } + } + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true + }, + "esquery": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", + "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", + "dev": true, + "requires": { + "estraverse": "^5.1.0" + }, + "dependencies": { + "estraverse": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", + "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", + "dev": true + } + } + }, + "esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "requires": { + "estraverse": "^5.2.0" + }, + "dependencies": { + "estraverse": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", + "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", + "dev": true + } + } + }, + "estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", + "dev": true + }, + "esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true + }, + "etag": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", + "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", + "dev": true + }, + "event-pubsub": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/event-pubsub/-/event-pubsub-4.3.0.tgz", + "integrity": "sha512-z7IyloorXvKbFx9Bpie2+vMJKKx1fH1EN5yiTfp8CiLOTptSYy1g8H4yDpGlEdshL1PBiFtBHepF2cNsqeEeFQ==", + "dev": true + }, + "eventemitter3": { + "version": "4.0.7", + "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", + "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==", + "dev": true + }, + "events": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/events/-/events-3.2.0.tgz", + "integrity": "sha512-/46HWwbfCX2xTawVfkKLGxMifJYQBWMwY1mjywRtb4c9x8l5NP3KoJtnIOiL1hfdRkIuYhETxQlo62IF8tcnlg==", + "dev": true + }, + "eventsource": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/eventsource/-/eventsource-1.1.0.tgz", + "integrity": "sha512-VSJjT5oCNrFvCS6igjzPAt5hBzQ2qPBFIbJ03zLI9SE0mxwZpMw6BfJrbFHm1a141AavMEB8JHmBhWAd66PfCg==", + "dev": true, + "requires": { + "original": "^1.0.0" + } + }, + "evp_bytestokey": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", + "integrity": "sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA==", + "dev": true, + "requires": { + "md5.js": "^1.3.4", + "safe-buffer": "^5.1.1" + } + }, + "execa": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", + "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", + "dev": true, + "requires": { + "cross-spawn": "^6.0.0", + "get-stream": "^4.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + } + }, + "expand-brackets": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", + "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", + "dev": true, + "requires": { + "debug": "^2.3.3", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "posix-character-classes": "^0.1.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + } + } + }, + "express": { + "version": "4.17.1", + "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", + "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", + "dev": true, + "requires": { + "accepts": "~1.3.7", + "array-flatten": "1.1.1", + "body-parser": "1.19.0", + "content-disposition": "0.5.3", + "content-type": "~1.0.4", + "cookie": "0.4.0", + "cookie-signature": "1.0.6", + "debug": "2.6.9", + "depd": "~1.1.2", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "finalhandler": "~1.1.2", + "fresh": "0.5.2", + "merge-descriptors": "1.0.1", + "methods": "~1.1.2", + "on-finished": "~2.3.0", + "parseurl": "~1.3.3", + "path-to-regexp": "0.1.7", + "proxy-addr": "~2.0.5", + "qs": "6.7.0", + "range-parser": "~1.2.1", + "safe-buffer": "5.1.2", + "send": "0.17.1", + "serve-static": "1.14.1", + "setprototypeof": "1.1.1", + "statuses": "~1.5.0", + "type-is": "~1.6.18", + "utils-merge": "1.0.1", + "vary": "~1.1.2" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + }, + "qs": { + "version": "6.7.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", + "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==", + "dev": true + } + } + }, + "extend": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", + "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", + "dev": true + }, + "extend-shallow": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", + "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", + "dev": true, + "requires": { + "assign-symbols": "^1.0.0", + "is-extendable": "^1.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "dev": true, + "requires": { + "is-plain-object": "^2.0.4" + } + } + } + }, + "external-editor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", + "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", + "dev": true, + "requires": { + "chardet": "^0.7.0", + "iconv-lite": "^0.4.24", + "tmp": "^0.0.33" + } + }, + "extglob": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", + "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", + "dev": true, + "requires": { + "array-unique": "^0.3.2", + "define-property": "^1.0.0", + "expand-brackets": "^2.1.4", + "extend-shallow": "^2.0.1", + "fragment-cache": "^0.2.1", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "extsprintf": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", + "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", + "dev": true + }, + "faker": { + "version": "5.5.3", + "resolved": "https://registry.npmjs.org/faker/-/faker-5.5.3.tgz", + "integrity": "sha512-wLTv2a28wjUyWkbnX7u/ABZBkUkIF2fCd73V6P2oFqEGEktDfzWx4UxrSqtPRw0xPRAcjeAOIiJWqZm3pP4u3g==" + }, + "fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "dev": true + }, + "fast-glob": { + "version": "2.2.7", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-2.2.7.tgz", + "integrity": "sha512-g1KuQwHOZAmOZMuBtHdxDtju+T2RT8jgCC9aANsbpdiDDTSnjgfuVsIBNKbUeJI3oKMRExcfNDtJl4OhbffMsw==", + "dev": true, + "requires": { + "@mrmlnc/readdir-enhanced": "^2.2.1", + "@nodelib/fs.stat": "^1.1.2", + "glob-parent": "^3.1.0", + "is-glob": "^4.0.0", + "merge2": "^1.2.3", + "micromatch": "^3.1.10" + }, + "dependencies": { + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "dev": true, + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "dev": true, + "requires": { + "is-extglob": "^2.1.0" + } + } + } + } + } + }, + "fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "dev": true + }, + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", + "dev": true + }, + "faye-websocket": { + "version": "0.11.4", + "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.4.tgz", + "integrity": "sha512-CzbClwlXAuiRQAlUyfqPgvPoNKTckTPGfwZV4ZdAhVcP2lh9KUxJg2b5GkE7XbjKQ3YJnQ9z6D9ntLAlB+tP8g==", + "dev": true, + "requires": { + "websocket-driver": ">=0.5.1" + } + }, + "figgy-pudding": { + "version": "3.5.2", + "resolved": "https://registry.npmjs.org/figgy-pudding/-/figgy-pudding-3.5.2.tgz", + "integrity": "sha512-0btnI/H8f2pavGMN8w40mlSKOfTK2SVJmBfBeVIj3kNw0swwgzyRq0d5TJVOwodFmtvpPeWPN/MCcfuWF0Ezbw==", + "dev": true + }, + "figures": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", + "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", + "dev": true, + "requires": { + "escape-string-regexp": "^1.0.5" + } + }, + "file-entry-cache": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", + "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", + "dev": true, + "requires": { + "flat-cache": "^3.0.4" + } + }, + "file-loader": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/file-loader/-/file-loader-4.3.0.tgz", + "integrity": "sha512-aKrYPYjF1yG3oX0kWRrqrSMfgftm7oJW5M+m4owoldH5C51C0RkIwB++JbRvEW3IU6/ZG5n8UvEcdgwOt2UOWA==", + "dev": true, + "requires": { + "loader-utils": "^1.2.3", + "schema-utils": "^2.5.0" + } + }, + "file-uri-to-path": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", + "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", + "dev": true, + "optional": true + }, + "filesize": { + "version": "3.6.1", + "resolved": "https://registry.npmjs.org/filesize/-/filesize-3.6.1.tgz", + "integrity": "sha512-7KjR1vv6qnicaPMi1iiTcI85CyYwRO/PSFCu6SvqL8jN2Wjt/NIYQTFtFs7fSDCYOstUkEWIQGFUg5YZQfjlcg==", + "dev": true + }, + "fill-range": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", + "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-number": "^3.0.0", + "repeat-string": "^1.6.1", + "to-regex-range": "^2.1.0" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "finalhandler": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", + "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", + "dev": true, + "requires": { + "debug": "2.6.9", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "on-finished": "~2.3.0", + "parseurl": "~1.3.3", + "statuses": "~1.5.0", + "unpipe": "~1.0.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + } + } + }, + "find-cache-dir": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.1.tgz", + "integrity": "sha512-t2GDMt3oGC/v+BMwzmllWDuJF/xcDtE5j/fCGbqDD7OLuJkj0cfh1YSA5VKPvwMeLFLNDBkwOKZ2X85jGLVftQ==", + "dev": true, + "requires": { + "commondir": "^1.0.1", + "make-dir": "^3.0.2", + "pkg-dir": "^4.1.0" + } + }, + "find-up": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "dev": true, + "requires": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + } + }, + "flat-cache": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", + "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", + "dev": true, + "requires": { + "flatted": "^3.1.0", + "rimraf": "^3.0.2" + }, + "dependencies": { + "rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "dev": true, + "requires": { + "glob": "^7.1.3" + } + } + } + }, + "flatted": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.1.tgz", + "integrity": "sha512-OMQjaErSFHmHqZe+PSidH5n8j3O0F2DdnVh8JB4j4eUQ2k6KvB0qGfrKIhapvez5JerBbmWkaLYUYWISaESoXg==", + "dev": true + }, + "flush-write-stream": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/flush-write-stream/-/flush-write-stream-1.1.1.tgz", + "integrity": "sha512-3Z4XhFZ3992uIq0XOqb9AreonueSYphE6oYbpt5+3u06JWklbsPkNv3ZKkP9Bz/r+1MWCaMoSQ28P85+1Yc77w==", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "readable-stream": "^2.3.6" + } + }, + "follow-redirects": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.1.tgz", + "integrity": "sha512-HWqDgT7ZEkqRzBvc2s64vSZ/hfOceEol3ac/7tKwzuvEyWx3/4UegXh5oBOIotkGsObyk3xznnSRVADBgWSQVg==", + "dev": true + }, + "for-in": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", + "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", + "dev": true + }, + "forever-agent": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", + "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", + "dev": true + }, + "form-data": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", + "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", + "dev": true, + "requires": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.6", + "mime-types": "^2.1.12" + } + }, + "forwarded": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", + "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", + "dev": true + }, + "fragment-cache": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", + "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", + "dev": true, + "requires": { + "map-cache": "^0.2.2" + } + }, + "fresh": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", + "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", + "dev": true + }, + "from2": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/from2/-/from2-2.3.0.tgz", + "integrity": "sha1-i/tVAr3kpNNs/e6gB/zKIdfjgq8=", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "readable-stream": "^2.0.0" + } + }, + "fs-extra": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz", + "integrity": "sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + }, + "fs-write-stream-atomic": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/fs-write-stream-atomic/-/fs-write-stream-atomic-1.0.10.tgz", + "integrity": "sha1-tH31NJPvkR33VzHnCp3tAYnbQMk=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "iferr": "^0.1.5", + "imurmurhash": "^0.1.4", + "readable-stream": "1 || 2" + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", + "dev": true + }, + "fsevents": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz", + "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==", + "dev": true, + "optional": true + }, + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", + "dev": true + }, + "functional-red-black-tree": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", + "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", + "dev": true + }, + "gensync": { + "version": "1.0.0-beta.2", + "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", + "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", + "dev": true + }, + "get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", + "dev": true + }, + "get-intrinsic": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.0.1.tgz", + "integrity": "sha512-ZnWP+AmS1VUaLgTRy47+zKtjTxz+0xMpx3I52i+aalBK1QP19ggLF3Db89KJX7kjfOfP2eoa01qc++GwPgufPg==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + } + }, + "get-stream": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", + "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", + "dev": true, + "requires": { + "pump": "^3.0.0" + } + }, + "get-value": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", + "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=", + "dev": true + }, + "getpass": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", + "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", + "dev": true, + "requires": { + "assert-plus": "^1.0.0" + } + }, + "glob": { + "version": "7.1.6", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", + "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "glob-parent": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", + "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", + "dev": true, + "requires": { + "is-glob": "^4.0.1" + } + }, + "glob-to-regexp": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.3.0.tgz", + "integrity": "sha1-jFoUlNIGbFcMw7/kSWF1rMTVAqs=", + "dev": true + }, + "globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", + "dev": true + }, + "globby": { + "version": "9.2.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-9.2.0.tgz", + "integrity": "sha512-ollPHROa5mcxDEkwg6bPt3QbEf4pDQSNtd6JPL1YvOvAo/7/0VAm9TccUeoTmarjPw4pfUthSCqcyfNB1I3ZSg==", + "dev": true, + "requires": { + "@types/glob": "^7.1.1", + "array-union": "^1.0.2", + "dir-glob": "^2.2.2", + "fast-glob": "^2.2.6", + "glob": "^7.1.3", + "ignore": "^4.0.3", + "pify": "^4.0.1", + "slash": "^2.0.0" + } + }, + "graceful-fs": { + "version": "4.2.4", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", + "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==", + "dev": true + }, + "gzip-size": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/gzip-size/-/gzip-size-5.1.1.tgz", + "integrity": "sha512-FNHi6mmoHvs1mxZAds4PpdCS6QG8B4C1krxJsMutgxl5t3+GlRTzzI3NEkifXx2pVsOvJdOGSmIgDhQ55FwdPA==", + "dev": true, + "requires": { + "duplexer": "^0.1.1", + "pify": "^4.0.1" + } + }, + "handle-thing": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/handle-thing/-/handle-thing-2.0.1.tgz", + "integrity": "sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg==", + "dev": true + }, + "har-schema": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", + "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", + "dev": true + }, + "har-validator": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.5.tgz", + "integrity": "sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w==", + "dev": true, + "requires": { + "ajv": "^6.12.3", + "har-schema": "^2.0.0" + } + }, + "has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "dev": true, + "requires": { + "function-bind": "^1.1.1" + } + }, + "has-bigints": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.1.tgz", + "integrity": "sha512-LSBS2LjbNBTf6287JEbEzvJgftkF5qFkmCo9hDRpAzKhUOlJ+hx8dd4USs00SgsUNwc4617J9ki5YtEClM2ffA==", + "dev": true + }, + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", + "dev": true + }, + "has-symbols": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", + "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", + "dev": true + }, + "has-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", + "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", + "dev": true, + "requires": { + "get-value": "^2.0.6", + "has-values": "^1.0.0", + "isobject": "^3.0.0" + } + }, + "has-values": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", + "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", + "dev": true, + "requires": { + "is-number": "^3.0.0", + "kind-of": "^4.0.0" + }, + "dependencies": { + "kind-of": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", + "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "hash-base": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.1.0.tgz", + "integrity": "sha512-1nmYp/rhMDiE7AYkDw+lLwlAzz0AntGIe51F3RfFfEqyQ3feY2eI/NcwC6umIQVOASPMsWJLJScWKSSvzL9IVA==", + "dev": true, + "requires": { + "inherits": "^2.0.4", + "readable-stream": "^3.6.0", + "safe-buffer": "^5.2.0" + }, + "dependencies": { + "readable-stream": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", + "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + } + }, + "safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "dev": true + } + } + }, + "hash-sum": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/hash-sum/-/hash-sum-2.0.0.tgz", + "integrity": "sha512-WdZTbAByD+pHfl/g9QSsBIIwy8IT+EsPiKDs0KNX+zSHhdDLFKdZu0BQHljvO+0QI/BasbMSUa8wYNCZTvhslg==", + "dev": true + }, + "hash.js": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.7.tgz", + "integrity": "sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "minimalistic-assert": "^1.0.1" + } + }, + "he": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", + "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", + "dev": true + }, + "hex-color-regex": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/hex-color-regex/-/hex-color-regex-1.1.0.tgz", + "integrity": "sha512-l9sfDFsuqtOqKDsQdqrMRk0U85RZc0RtOR9yPI7mRVOa4FsR/BVnZ0shmQRM96Ji99kYZP/7hn1cedc1+ApsTQ==", + "dev": true + }, + "highlight.js": { + "version": "10.7.3", + "resolved": "https://registry.npmjs.org/highlight.js/-/highlight.js-10.7.3.tgz", + "integrity": "sha512-tzcUFauisWKNHaRkN4Wjl/ZA07gENAjFl3J/c480dprkGTg5EQstgaNFqBfUqCq54kZRIEcreTsAgF/m2quD7A==", + "dev": true + }, + "hmac-drbg": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz", + "integrity": "sha1-0nRXAQJabHdabFRXk+1QL8DGSaE=", + "dev": true, + "requires": { + "hash.js": "^1.0.3", + "minimalistic-assert": "^1.0.0", + "minimalistic-crypto-utils": "^1.0.1" + } + }, + "hoopy": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/hoopy/-/hoopy-0.1.4.tgz", + "integrity": "sha512-HRcs+2mr52W0K+x8RzcLzuPPmVIKMSv97RGHy0Ea9y/mpcaK+xTrjICA04KAHi4GRzxliNqNJEFYWHghy3rSfQ==", + "dev": true + }, + "hosted-git-info": { + "version": "2.8.8", + "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.8.tgz", + "integrity": "sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg==", + "dev": true + }, + "hpack.js": { + "version": "2.1.6", + "resolved": "https://registry.npmjs.org/hpack.js/-/hpack.js-2.1.6.tgz", + "integrity": "sha1-h3dMCUnlE/QuhFdbPEVoH63ioLI=", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "obuf": "^1.0.0", + "readable-stream": "^2.0.1", + "wbuf": "^1.1.0" + } + }, + "hsl-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/hsl-regex/-/hsl-regex-1.0.0.tgz", + "integrity": "sha1-1JMwx4ntgZ4nakwNJy3/owsY/m4=", + "dev": true + }, + "hsla-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/hsla-regex/-/hsla-regex-1.0.0.tgz", + "integrity": "sha1-wc56MWjIxmFAM6S194d/OyJfnDg=", + "dev": true + }, + "html-entities": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/html-entities/-/html-entities-1.4.0.tgz", + "integrity": "sha512-8nxjcBcd8wovbeKx7h3wTji4e6+rhaVuPNpMqwWgnHh+N9ToqsCs6XztWRBPQ+UtzsoMAdKZtUENoVzU/EMtZA==", + "dev": true + }, + "html-minifier": { + "version": "3.5.21", + "resolved": "https://registry.npmjs.org/html-minifier/-/html-minifier-3.5.21.tgz", + "integrity": "sha512-LKUKwuJDhxNa3uf/LPR/KVjm/l3rBqtYeCOAekvG8F1vItxMUpueGd94i/asDDr8/1u7InxzFA5EeGjhhG5mMA==", + "dev": true, + "requires": { + "camel-case": "3.0.x", + "clean-css": "4.2.x", + "commander": "2.17.x", + "he": "1.2.x", + "param-case": "2.1.x", + "relateurl": "0.2.x", + "uglify-js": "3.4.x" + }, + "dependencies": { + "commander": { + "version": "2.17.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.17.1.tgz", + "integrity": "sha512-wPMUt6FnH2yzG95SA6mzjQOEKUU3aLaDEmzs1ti+1E9h+CsrZghRlqEM/EJ4KscsQVG8uNN4uVreUeT8+drlgg==", + "dev": true + } + } + }, + "html-tags": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/html-tags/-/html-tags-3.1.0.tgz", + "integrity": "sha512-1qYz89hW3lFDEazhjW0yVAV87lw8lVkrJocr72XmBkMKsoSVJCQx3W8BXsC7hO2qAt8BoVjYjtAcZ9perqGnNg==", + "dev": true + }, + "html-webpack-plugin": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/html-webpack-plugin/-/html-webpack-plugin-3.2.0.tgz", + "integrity": "sha1-sBq71yOsqqeze2r0SS69oD2d03s=", + "dev": true, + "requires": { + "html-minifier": "^3.2.3", + "loader-utils": "^0.2.16", + "lodash": "^4.17.3", + "pretty-error": "^2.0.2", + "tapable": "^1.0.0", + "toposort": "^1.0.0", + "util.promisify": "1.0.0" + }, + "dependencies": { + "big.js": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/big.js/-/big.js-3.2.0.tgz", + "integrity": "sha512-+hN/Zh2D08Mx65pZ/4g5bsmNiZUuChDiQfTUQ7qJr4/kuopCr88xZsAXv6mBoZEsUI4OuGHlX59qE94K2mMW8Q==", + "dev": true + }, + "emojis-list": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-2.1.0.tgz", + "integrity": "sha1-TapNnbAPmBmIDHn6RXrlsJof04k=", + "dev": true + }, + "json5": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/json5/-/json5-0.5.1.tgz", + "integrity": "sha1-Hq3nrMASA0rYTiOWdn6tn6VJWCE=", + "dev": true + }, + "loader-utils": { + "version": "0.2.17", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-0.2.17.tgz", + "integrity": "sha1-+G5jdNQyBabmxg6RlvF8Apm/s0g=", + "dev": true, + "requires": { + "big.js": "^3.1.3", + "emojis-list": "^2.0.0", + "json5": "^0.5.0", + "object-assign": "^4.0.1" + } + }, + "util.promisify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/util.promisify/-/util.promisify-1.0.0.tgz", + "integrity": "sha512-i+6qA2MPhvoKLuxnJNpXAGhg7HphQOSUq2LKMZD0m15EiskXUkMvKdF4Uui0WYeCUGea+o2cw/ZuwehtfsrNkA==", + "dev": true, + "requires": { + "define-properties": "^1.1.2", + "object.getownpropertydescriptors": "^2.0.3" + } + } + } + }, + "htmlparser2": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-6.1.0.tgz", + "integrity": "sha512-gyyPk6rgonLFEDGoeRgQNaEUvdJ4ktTmmUh/h2t7s+M8oPpIPxgNACWa+6ESR57kXstwqPiCut0V8NRpcwgU7A==", + "dev": true, + "requires": { + "domelementtype": "^2.0.1", + "domhandler": "^4.0.0", + "domutils": "^2.5.2", + "entities": "^2.0.0" + }, + "dependencies": { + "dom-serializer": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.3.2.tgz", + "integrity": "sha512-5c54Bk5Dw4qAxNOI1pFEizPSjVsx5+bpJKmL2kPn8JhBUq2q09tTCa3mjijun2NfK78NMouDYNMBkOrPZiS+ig==", + "dev": true, + "requires": { + "domelementtype": "^2.0.1", + "domhandler": "^4.2.0", + "entities": "^2.0.0" + } + }, + "domelementtype": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.2.0.tgz", + "integrity": "sha512-DtBMo82pv1dFtUmHyr48beiuq792Sxohr+8Hm9zoxklYPfa6n0Z3Byjj2IV7bmr2IyqClnqEQhfgHJJ5QF0R5A==", + "dev": true + }, + "domutils": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.7.0.tgz", + "integrity": "sha512-8eaHa17IwJUPAiB+SoTYBo5mCdeMgdcAoXJ59m6DT1vw+5iLS3gNoqYaRowaBKtGVrOF1Jz4yDTgYKLK2kvfJg==", + "dev": true, + "requires": { + "dom-serializer": "^1.0.1", + "domelementtype": "^2.2.0", + "domhandler": "^4.2.0" + } + } + } + }, + "http-deceiver": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/http-deceiver/-/http-deceiver-1.2.7.tgz", + "integrity": "sha1-+nFolEq5pRnTN8sL7HKE3D5yPYc=", + "dev": true + }, + "http-errors": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", + "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", + "dev": true, + "requires": { + "depd": "~1.1.2", + "inherits": "2.0.3", + "setprototypeof": "1.1.1", + "statuses": ">= 1.5.0 < 2", + "toidentifier": "1.0.0" + }, + "dependencies": { + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", + "dev": true + } + } + }, + "http-parser-js": { + "version": "0.5.3", + "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.3.tgz", + "integrity": "sha512-t7hjvef/5HEK7RWTdUzVUhl8zkEu+LlaE0IYzdMuvbSDipxBRpOn4Uhw8ZyECEa808iVT8XCjzo6xmYt4CiLZg==", + "dev": true + }, + "http-proxy": { + "version": "1.18.1", + "resolved": "https://registry.npmjs.org/http-proxy/-/http-proxy-1.18.1.tgz", + "integrity": "sha512-7mz/721AbnJwIVbnaSv1Cz3Am0ZLT/UBwkC92VlxhXv/k/BBQfM2fXElQNC27BVGr0uwUpplYPQM9LnaBMR5NQ==", + "dev": true, + "requires": { + "eventemitter3": "^4.0.0", + "follow-redirects": "^1.0.0", + "requires-port": "^1.0.0" + } + }, + "http-proxy-middleware": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-1.3.1.tgz", + "integrity": "sha512-13eVVDYS4z79w7f1+NPllJtOQFx/FdUW4btIvVRMaRlUY9VGstAbo5MOhLEuUgZFRHn3x50ufn25zkj/boZnEg==", + "dev": true, + "requires": { + "@types/http-proxy": "^1.17.5", + "http-proxy": "^1.18.1", + "is-glob": "^4.0.1", + "is-plain-obj": "^3.0.0", + "micromatch": "^4.0.2" + }, + "dependencies": { + "braces": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", + "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "dev": true, + "requires": { + "fill-range": "^7.0.1" + } + }, + "fill-range": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", + "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "dev": true, + "requires": { + "to-regex-range": "^5.0.1" + } + }, + "is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true + }, + "micromatch": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", + "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", + "dev": true, + "requires": { + "braces": "^3.0.1", + "picomatch": "^2.2.3" + } + }, + "picomatch": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", + "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", + "dev": true + }, + "to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "requires": { + "is-number": "^7.0.0" + } + } + } + }, + "http-signature": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", + "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", + "dev": true, + "requires": { + "assert-plus": "^1.0.0", + "jsprim": "^1.2.2", + "sshpk": "^1.7.0" + } + }, + "https-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/https-browserify/-/https-browserify-1.0.0.tgz", + "integrity": "sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM=", + "dev": true + }, + "human-signals": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-1.1.1.tgz", + "integrity": "sha512-SEQu7vl8KjNL2eoGBLF3+wAjpsNfA9XMlXAYj/3EdaNfAlxKthD1xjEQfGOUhllCGGJVNY34bRr6lPINhNjyZw==", + "dev": true + }, + "iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "dev": true, + "requires": { + "safer-buffer": ">= 2.1.2 < 3" + } + }, + "icss-utils": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-4.1.1.tgz", + "integrity": "sha512-4aFq7wvWyMHKgxsH8QQtGpvbASCf+eM3wPRLI6R+MgAnTCZ6STYsRvttLvRWK0Nfif5piF394St3HeJDaljGPA==", + "dev": true, + "requires": { + "postcss": "^7.0.14" + } + }, + "ieee754": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", + "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", + "dev": true + }, + "iferr": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/iferr/-/iferr-0.1.5.tgz", + "integrity": "sha1-xg7taebY/bazEEofy8ocGS3FtQE=", + "dev": true + }, + "ignore": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", + "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", + "dev": true + }, + "import-cwd": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/import-cwd/-/import-cwd-2.1.0.tgz", + "integrity": "sha1-qmzzbnInYShcs3HsZRn1PiQ1sKk=", + "dev": true, + "requires": { + "import-from": "^2.1.0" + } + }, + "import-fresh": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-2.0.0.tgz", + "integrity": "sha1-2BNVwVYS04bGH53dOSLUMEgipUY=", + "dev": true, + "requires": { + "caller-path": "^2.0.0", + "resolve-from": "^3.0.0" + } + }, + "import-from": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/import-from/-/import-from-2.1.0.tgz", + "integrity": "sha1-M1238qev/VOqpHHUuAId7ja387E=", + "dev": true, + "requires": { + "resolve-from": "^3.0.0" + } + }, + "import-local": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/import-local/-/import-local-2.0.0.tgz", + "integrity": "sha512-b6s04m3O+s3CGSbqDIyP4R6aAwAeYlVq9+WUWep6iHa8ETRf9yei1U48C5MmfJmV9AiLYYBKPMq/W+/WRpQmCQ==", + "dev": true, + "requires": { + "pkg-dir": "^3.0.0", + "resolve-cwd": "^2.0.0" + }, + "dependencies": { + "find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "requires": { + "locate-path": "^3.0.0" + } + }, + "locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "dev": true, + "requires": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + } + }, + "p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "dev": true, + "requires": { + "p-limit": "^2.0.0" + } + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + }, + "pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", + "dev": true, + "requires": { + "find-up": "^3.0.0" + } + } + } + }, + "imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", + "dev": true + }, + "indexes-of": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/indexes-of/-/indexes-of-1.0.1.tgz", + "integrity": "sha1-8w9xbI4r00bHtn0985FVZqfAVgc=", + "dev": true + }, + "infer-owner": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/infer-owner/-/infer-owner-1.0.4.tgz", + "integrity": "sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A==", + "dev": true + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "dev": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "inquirer": { + "version": "7.3.3", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.3.3.tgz", + "integrity": "sha512-JG3eIAj5V9CwcGvuOmoo6LB9kbAYT8HXffUl6memuszlwDC/qvFAJw49XJ5NROSFNPxp3iQg1GqkFhaY/CR0IA==", + "dev": true, + "requires": { + "ansi-escapes": "^4.2.1", + "chalk": "^4.1.0", + "cli-cursor": "^3.1.0", + "cli-width": "^3.0.0", + "external-editor": "^3.0.3", + "figures": "^3.0.0", + "lodash": "^4.17.19", + "mute-stream": "0.0.8", + "run-async": "^2.4.0", + "rxjs": "^6.6.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0", + "through": "^2.3.6" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz", + "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "cli-cursor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", + "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", + "dev": true, + "requires": { + "restore-cursor": "^3.1.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true + }, + "mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", + "dev": true + }, + "onetime": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", + "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", + "dev": true, + "requires": { + "mimic-fn": "^2.1.0" + } + }, + "restore-cursor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", + "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", + "dev": true, + "requires": { + "onetime": "^5.1.0", + "signal-exit": "^3.0.2" + } + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, + "internal-ip": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/internal-ip/-/internal-ip-4.3.0.tgz", + "integrity": "sha512-S1zBo1D6zcsyuC6PMmY5+55YMILQ9av8lotMx447Bq6SAgo/sDK6y6uUKmuYhW7eacnIhFfsPmCNYdDzsnnDCg==", + "dev": true, + "requires": { + "default-gateway": "^4.2.0", + "ipaddr.js": "^1.9.0" + }, + "dependencies": { + "default-gateway": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/default-gateway/-/default-gateway-4.2.0.tgz", + "integrity": "sha512-h6sMrVB1VMWVrW13mSc6ia/DwYYw5MN6+exNu1OaJeFac5aSAvwM7lZ0NVfTABuSkQelr4h5oebg3KB1XPdjgA==", + "dev": true, + "requires": { + "execa": "^1.0.0", + "ip-regex": "^2.1.0" + } + } + } + }, + "ip": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.5.tgz", + "integrity": "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=", + "dev": true + }, + "ip-regex": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/ip-regex/-/ip-regex-2.1.0.tgz", + "integrity": "sha1-+ni/XS5pE8kRzp+BnuUUa7bYROk=", + "dev": true + }, + "ipaddr.js": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", + "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", + "dev": true + }, + "is-absolute-url": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-absolute-url/-/is-absolute-url-2.1.0.tgz", + "integrity": "sha1-UFMN+4T8yap9vnhS6Do3uTufKqY=", + "dev": true + }, + "is-accessor-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", + "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-arguments": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-arguments/-/is-arguments-1.1.0.tgz", + "integrity": "sha512-1Ij4lOMPl/xB5kBDn7I+b2ttPMKa8szhEIrXDuXQD/oe3HJLTLhqhgGspwgyGd6MOywBUqVvYicF72lkgDnIHg==", + "dev": true, + "requires": { + "call-bind": "^1.0.0" + } + }, + "is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", + "dev": true + }, + "is-bigint": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.2.tgz", + "integrity": "sha512-0JV5+SOCQkIdzjBK9buARcV804Ddu7A0Qet6sHi3FimE9ne6m4BGQZfRn+NZiXbBk4F4XmHfDZIipLj9pX8dSA==", + "dev": true + }, + "is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "dev": true, + "requires": { + "binary-extensions": "^2.0.0" + } + }, + "is-boolean-object": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.1.tgz", + "integrity": "sha512-bXdQWkECBUIAcCkeH1unwJLIpZYaa5VvuygSyS/c2lf719mTKZDU5UdDRlpd01UjADgmW8RfqaP+mRaVPdr/Ng==", + "dev": true, + "requires": { + "call-bind": "^1.0.2" + }, + "dependencies": { + "call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + } + }, + "get-intrinsic": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", + "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + } + } + } + }, + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", + "dev": true + }, + "is-callable": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.3.tgz", + "integrity": "sha512-J1DcMe8UYTBSrKezuIUTUwjXsho29693unXM2YhJUTR2txK/eG47bvNa/wipPFmZFgr/N6f1GA66dv0mEyTIyQ==", + "dev": true + }, + "is-ci": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-1.2.1.tgz", + "integrity": "sha512-s6tfsaQaQi3JNciBH6shVqEDvhGut0SUXr31ag8Pd8BBbVVlcGfWhpPmEOoM6RJ5TFhbypvf5yyRw/VXW1IiWg==", + "dev": true, + "requires": { + "ci-info": "^1.5.0" + } + }, + "is-color-stop": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-color-stop/-/is-color-stop-1.1.0.tgz", + "integrity": "sha1-z/9HGu5N1cnhWFmPvhKWe1za00U=", + "dev": true, + "requires": { + "css-color-names": "^0.0.4", + "hex-color-regex": "^1.1.0", + "hsl-regex": "^1.0.0", + "hsla-regex": "^1.0.0", + "rgb-regex": "^1.0.1", + "rgba-regex": "^1.0.0" + } + }, + "is-core-module": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.2.0.tgz", + "integrity": "sha512-XRAfAdyyY5F5cOXn7hYQDqh2Xmii+DEfIcQGxK/uNwMHhIkPWO0g8msXcbzLe+MpGoR951MlqM/2iIlU4vKDdQ==", + "dev": true, + "requires": { + "has": "^1.0.3" + } + }, + "is-data-descriptor": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", + "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-date-object": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.4.tgz", + "integrity": "sha512-/b4ZVsG7Z5XVtIxs/h9W8nvfLgSAyKYdtGWQLbqy6jA1icmgjf8WCoTKgeS4wy5tYaPePouzFMANbnj94c2Z+A==", + "dev": true + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", + "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^0.1.6", + "is-data-descriptor": "^0.1.4", + "kind-of": "^5.0.0" + }, + "dependencies": { + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", + "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", + "dev": true + } + } + }, + "is-directory": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/is-directory/-/is-directory-0.3.1.tgz", + "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=", + "dev": true + }, + "is-docker": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-2.2.1.tgz", + "integrity": "sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==", + "dev": true + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true + }, + "is-glob": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", + "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-negative-zero": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.1.tgz", + "integrity": "sha512-2z6JzQvZRa9A2Y7xC6dQQm4FSTSTNWjKIYYTt4246eMTJmIo0Q+ZyOsU66X8lxK1AbB92dFeglPLrhwpeRKO6w==", + "dev": true + }, + "is-number": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", + "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-number-object": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.5.tgz", + "integrity": "sha512-RU0lI/n95pMoUKu9v1BZP5MBcZuNSVJkMkAG2dJqC4z2GlkGUNeH68SuHuBKBD/XFe+LHZ+f9BKkLET60Niedw==", + "dev": true + }, + "is-obj": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", + "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==", + "dev": true + }, + "is-path-cwd": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-2.2.0.tgz", + "integrity": "sha512-w942bTcih8fdJPJmQHFzkS76NEP8Kzzvmw92cXsazb8intwLqPibPPdXf4ANdKV3rYMuuQYGIWtvz9JilB3NFQ==", + "dev": true + }, + "is-path-in-cwd": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-2.1.0.tgz", + "integrity": "sha512-rNocXHgipO+rvnP6dk3zI20RpOtrAM/kzbB258Uw5BWr3TpXi861yzjo16Dn4hUox07iw5AyeMLHWsujkjzvRQ==", + "dev": true, + "requires": { + "is-path-inside": "^2.1.0" + } + }, + "is-path-inside": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-2.1.0.tgz", + "integrity": "sha512-wiyhTzfDWsvwAW53OBWF5zuvaOGlZ6PwYxAbPVDhpm+gM09xKQGjBq/8uYN12aDvMxnAnq3dxTyoSoRNmg5YFg==", + "dev": true, + "requires": { + "path-is-inside": "^1.0.2" + } + }, + "is-plain-obj": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-3.0.0.tgz", + "integrity": "sha512-gwsOE28k+23GP1B6vFl1oVh/WOzmawBrKwo5Ev6wMKzPkaXaCDIQKzLnvsA42DRlbVTWorkgTKIviAKCWkfUwA==", + "dev": true + }, + "is-plain-object": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", + "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", + "dev": true, + "requires": { + "isobject": "^3.0.1" + } + }, + "is-regex": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.3.tgz", + "integrity": "sha512-qSVXFz28HM7y+IWX6vLCsexdlvzT1PJNFSBuaQLQ5o0IEw8UDYW6/2+eCMVyIsbM8CNLX2a/QWmSpyxYEHY7CQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "has-symbols": "^1.0.2" + }, + "dependencies": { + "call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + } + }, + "get-intrinsic": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", + "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + } + }, + "has-symbols": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", + "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", + "dev": true + } + } + }, + "is-resolvable": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.1.0.tgz", + "integrity": "sha512-qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg==", + "dev": true + }, + "is-stream": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", + "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", + "dev": true + }, + "is-string": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.6.tgz", + "integrity": "sha512-2gdzbKUuqtQ3lYNrUTQYoClPhm7oQu4UdpSZMp1/DGgkHBT8E2Z1l0yMdb6D4zNAxwDiMv8MdulKROJGNl0Q0w==", + "dev": true + }, + "is-symbol": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", + "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", + "dev": true, + "requires": { + "has-symbols": "^1.0.2" + }, + "dependencies": { + "has-symbols": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", + "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", + "dev": true + } + } + }, + "is-typedarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", + "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", + "dev": true + }, + "is-windows": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", + "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", + "dev": true + }, + "is-wsl": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-1.1.0.tgz", + "integrity": "sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0=", + "dev": true + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", + "dev": true + }, + "isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", + "dev": true + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", + "dev": true + }, + "isstream": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", + "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", + "dev": true + }, + "javascript-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/javascript-stringify/-/javascript-stringify-2.1.0.tgz", + "integrity": "sha512-JVAfqNPTvNq3sB/VHQJAFxN/sPgKnsKrCwyRt15zwNCdrMMJDdcEOdubuy+DuJYYdm0ox1J4uzEuYKkN+9yhVg==", + "dev": true + }, + "js-message": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/js-message/-/js-message-1.0.7.tgz", + "integrity": "sha512-efJLHhLjIyKRewNS9EGZ4UpI8NguuL6fKkhRxVuMmrGV2xN/0APGdQYwLFky5w9naebSZ0OwAGp0G6/2Cg90rA==", + "dev": true + }, + "js-queue": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/js-queue/-/js-queue-2.0.2.tgz", + "integrity": "sha512-pbKLsbCfi7kriM3s1J4DDCo7jQkI58zPLHi0heXPzPlj0hjUsm+FesPUbE0DSbIVIK503A36aUBoCN7eMFedkA==", + "dev": true, + "requires": { + "easy-stack": "^1.0.1" + } + }, + "js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "js-yaml": { + "version": "3.14.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", + "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", + "dev": true, + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "jsbn": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", + "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", + "dev": true + }, + "jsesc": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", + "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", + "dev": true + }, + "json-parse-better-errors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", + "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", + "dev": true + }, + "json-parse-even-better-errors": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", + "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", + "dev": true + }, + "json-schema": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", + "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", + "dev": true + }, + "json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", + "dev": true + }, + "json-stringify-safe": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", + "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", + "dev": true + }, + "json3": { + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/json3/-/json3-3.3.3.tgz", + "integrity": "sha512-c7/8mbUsKigAbLkD5B010BK4D9LZm7A1pNItkEwiUZRpIN66exu/e7YQWysGun+TRKaJp8MhemM+VkfWv42aCA==", + "dev": true + }, + "json5": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.3.tgz", + "integrity": "sha512-KXPvOm8K9IJKFM0bmdn8QXh7udDh1g/giieX0NLCaMnb4hEiVFqnop2ImTXCc5e0/oHz3LTqmHGtExn5hfMkOA==", + "dev": true, + "requires": { + "minimist": "^1.2.5" + } + }, + "jsonfile": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", + "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.6" + } + }, + "jsprim": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", + "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", + "dev": true, + "requires": { + "assert-plus": "1.0.0", + "extsprintf": "1.3.0", + "json-schema": "0.2.3", + "verror": "1.10.0" + } + }, + "killable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/killable/-/killable-1.0.1.tgz", + "integrity": "sha512-LzqtLKlUwirEUyl/nicirVmNiPvYs7l5n8wOPP7fyJVpUPkvCnW/vuiXGpylGUlnPDnB7311rARzAt3Mhswpjg==", + "dev": true + }, + "kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", + "dev": true + }, + "klona": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/klona/-/klona-2.0.4.tgz", + "integrity": "sha512-ZRbnvdg/NxqzC7L9Uyqzf4psi1OM4Cuc+sJAkQPjO6XkQIJTNbfK2Rsmbw8fx1p2mkZdp2FZYo2+LwXYY/uwIA==", + "dev": true + }, + "launch-editor": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/launch-editor/-/launch-editor-2.2.1.tgz", + "integrity": "sha512-On+V7K2uZK6wK7x691ycSUbLD/FyKKelArkbaAMSSJU8JmqmhwN2+mnJDNINuJWSrh2L0kDk+ZQtbC/gOWUwLw==", + "dev": true, + "requires": { + "chalk": "^2.3.0", + "shell-quote": "^1.6.1" + } + }, + "launch-editor-middleware": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/launch-editor-middleware/-/launch-editor-middleware-2.2.1.tgz", + "integrity": "sha512-s0UO2/gEGiCgei3/2UN3SMuUj1phjQN8lcpnvgLSz26fAzNWPQ6Nf/kF5IFClnfU2ehp6LrmKdMU/beveO+2jg==", + "dev": true, + "requires": { + "launch-editor": "^2.2.1" + } + }, + "levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + } + }, + "lines-and-columns": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.1.6.tgz", + "integrity": "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=", + "dev": true + }, + "loader-fs-cache": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/loader-fs-cache/-/loader-fs-cache-1.0.3.tgz", + "integrity": "sha512-ldcgZpjNJj71n+2Mf6yetz+c9bM4xpKtNds4LbqXzU/PTdeAX0g3ytnU1AJMEcTk2Lex4Smpe3Q/eCTsvUBxbA==", + "dev": true, + "requires": { + "find-cache-dir": "^0.1.1", + "mkdirp": "^0.5.1" + }, + "dependencies": { + "find-cache-dir": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-0.1.1.tgz", + "integrity": "sha1-yN765XyKUqinhPnjHFfHQumToLk=", + "dev": true, + "requires": { + "commondir": "^1.0.1", + "mkdirp": "^0.5.1", + "pkg-dir": "^1.0.0" + } + }, + "find-up": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", + "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", + "dev": true, + "requires": { + "path-exists": "^2.0.0", + "pinkie-promise": "^2.0.0" + } + }, + "path-exists": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", + "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", + "dev": true, + "requires": { + "pinkie-promise": "^2.0.0" + } + }, + "pkg-dir": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-1.0.0.tgz", + "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", + "dev": true, + "requires": { + "find-up": "^1.0.0" + } + } + } + }, + "loader-runner": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-2.4.0.tgz", + "integrity": "sha512-Jsmr89RcXGIwivFY21FcRrisYZfvLMTWx5kOLc+JTxtpBOG6xML0vzbc6SEQG2FO9/4Fc3wW4LVcB5DmGflaRw==", + "dev": true + }, + "loader-utils": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-1.4.0.tgz", + "integrity": "sha512-qH0WSMBtn/oHuwjy/NucEgbx5dbxxnxup9s4PVXJUDHZBQY+s0NWA9rJf53RBnQZxfch7euUui7hpoAPvALZdA==", + "dev": true, + "requires": { + "big.js": "^5.2.2", + "emojis-list": "^3.0.0", + "json5": "^1.0.1" + }, + "dependencies": { + "json5": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", + "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", + "dev": true, + "requires": { + "minimist": "^1.2.0" + } + } + } + }, + "locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "dev": true, + "requires": { + "p-locate": "^4.1.0" + } + }, + "lodash": { + "version": "4.17.20", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.20.tgz", + "integrity": "sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA==", + "dev": true + }, + "lodash.clonedeep": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", + "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=", + "dev": true + }, + "lodash.debounce": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", + "integrity": "sha1-gteb/zCmfEAF/9XiUVMArZyk168=", + "dev": true + }, + "lodash.defaultsdeep": { + "version": "4.6.1", + "resolved": "https://registry.npmjs.org/lodash.defaultsdeep/-/lodash.defaultsdeep-4.6.1.tgz", + "integrity": "sha512-3j8wdDzYuWO3lM3Reg03MuQR957t287Rpcxp1njpEa8oDrikb+FwGdW3n+FELh/A6qib6yPit0j/pv9G/yeAqA==", + "dev": true + }, + "lodash.kebabcase": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/lodash.kebabcase/-/lodash.kebabcase-4.1.1.tgz", + "integrity": "sha1-hImxyw0p/4gZXM7KRI/21swpXDY=", + "dev": true + }, + "lodash.mapvalues": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/lodash.mapvalues/-/lodash.mapvalues-4.6.0.tgz", + "integrity": "sha1-G6+lAF3p3W9PJmaMMMo3IwzJaJw=", + "dev": true + }, + "lodash.memoize": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz", + "integrity": "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=", + "dev": true + }, + "lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true + }, + "lodash.transform": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/lodash.transform/-/lodash.transform-4.6.0.tgz", + "integrity": "sha1-EjBkIvYzJK7YSD0/ODMrX2cFR6A=", + "dev": true + }, + "lodash.truncate": { + "version": "4.4.2", + "resolved": "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz", + "integrity": "sha1-WjUNoLERO4N+z//VgSy+WNbq4ZM=", + "dev": true + }, + "lodash.uniq": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.uniq/-/lodash.uniq-4.5.0.tgz", + "integrity": "sha1-0CJTc662Uq3BvILklFM5qEJ1R3M=", + "dev": true + }, + "log-symbols": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-2.2.0.tgz", + "integrity": "sha512-VeIAFslyIerEJLXHziedo2basKbMKtTw3vfn5IzG0XTjhAVEJyNHnL2p7vc+wBDSdQuUpNw3M2u6xb9QsAY5Eg==", + "dev": true, + "requires": { + "chalk": "^2.0.1" + } + }, + "loglevel": { + "version": "1.7.1", + "resolved": "https://registry.npmjs.org/loglevel/-/loglevel-1.7.1.tgz", + "integrity": "sha512-Hesni4s5UkWkwCGJMQGAh71PaLUmKFM60dHvq0zi/vDhhrzuk+4GgNbTXJ12YYQJn6ZKBDNIjYcuQGKudvqrIw==", + "dev": true + }, + "lower-case": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-1.1.4.tgz", + "integrity": "sha1-miyr0bno4K6ZOkv31YdcOcQujqw=", + "dev": true + }, + "lru-cache": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", + "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", + "dev": true, + "requires": { + "yallist": "^3.0.2" + } + }, + "make-dir": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", + "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", + "dev": true, + "requires": { + "semver": "^6.0.0" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "map-cache": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", + "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", + "dev": true + }, + "map-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", + "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", + "dev": true, + "requires": { + "object-visit": "^1.0.0" + } + }, + "md5.js": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz", + "integrity": "sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg==", + "dev": true, + "requires": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "mdn-data": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.4.tgz", + "integrity": "sha512-iV3XNKw06j5Q7mi6h+9vbx23Tv7JkjEVgKHW4pimwyDGWm0OIQntJJ+u1C6mg6mK1EaTv42XQ7w76yuzH7M2cA==", + "dev": true + }, + "media-typer": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", + "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=", + "dev": true + }, + "memory-fs": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.4.1.tgz", + "integrity": "sha1-OpoguEYlI+RHz7x+i7gO1me/xVI=", + "dev": true, + "requires": { + "errno": "^0.1.3", + "readable-stream": "^2.0.1" + } + }, + "merge-descriptors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", + "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=", + "dev": true + }, + "merge-source-map": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/merge-source-map/-/merge-source-map-1.1.0.tgz", + "integrity": "sha512-Qkcp7P2ygktpMPh2mCQZaf3jhN6D3Z/qVZHSdWvQ+2Ef5HgRAPBO57A77+ENm0CPx2+1Ce/MYKi3ymqdfuqibw==", + "dev": true, + "requires": { + "source-map": "^0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "merge-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", + "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", + "dev": true + }, + "merge2": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", + "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", + "dev": true + }, + "methods": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", + "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", + "dev": true + }, + "micromatch": { + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", + "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", + "dev": true, + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "braces": "^2.3.1", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "extglob": "^2.0.4", + "fragment-cache": "^0.2.1", + "kind-of": "^6.0.2", + "nanomatch": "^1.2.9", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.2" + } + }, + "miller-rabin": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/miller-rabin/-/miller-rabin-4.0.1.tgz", + "integrity": "sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA==", + "dev": true, + "requires": { + "bn.js": "^4.0.0", + "brorand": "^1.0.1" + }, + "dependencies": { + "bn.js": { + "version": "4.11.9", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.9.tgz", + "integrity": "sha512-E6QoYqCKZfgatHTdHzs1RRKP7ip4vvm+EyRUeE2RF0NblwVvb0p6jSVeNTOFxPn26QXN2o6SMfNxKp6kU8zQaw==", + "dev": true + } + } + }, + "mime": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/mime/-/mime-2.5.2.tgz", + "integrity": "sha512-tqkh47FzKeCPD2PUiPB6pkbMzsCasjxAfC62/Wap5qrUWcb+sFasXUC5I3gYM5iBM8v/Qpn4UK0x+j0iHyFPDg==", + "dev": true + }, + "mime-db": { + "version": "1.44.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.44.0.tgz", + "integrity": "sha512-/NOTfLrsPBVeH7YtFPgsVWveuL+4SjjYxaQ1xtM1KMFj7HdxlBlxeyNLzhyJVx7r4rZGJAZ/6lkKCitSc/Nmpg==", + "dev": true + }, + "mime-types": { + "version": "2.1.27", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.27.tgz", + "integrity": "sha512-JIhqnCasI9yD+SsmkquHBxTSEuZdQX5BuQnS2Vc7puQQQ+8yiP5AY5uWhpdv4YL4VM5c6iliiYWPgJ/nJQLp7w==", + "dev": true, + "requires": { + "mime-db": "1.44.0" + } + }, + "mimic-fn": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", + "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", + "dev": true + }, + "mini-css-extract-plugin": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-0.9.0.tgz", + "integrity": "sha512-lp3GeY7ygcgAmVIcRPBVhIkf8Us7FZjA+ILpal44qLdSu11wmjKQ3d9k15lfD7pO4esu9eUIAW7qiYIBppv40A==", + "dev": true, + "requires": { + "loader-utils": "^1.1.0", + "normalize-url": "1.9.1", + "schema-utils": "^1.0.0", + "webpack-sources": "^1.1.0" + }, + "dependencies": { + "normalize-url": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-1.9.1.tgz", + "integrity": "sha1-LMDWazHqIwNkWENuNiDYWVTGbDw=", + "dev": true, + "requires": { + "object-assign": "^4.0.1", + "prepend-http": "^1.0.0", + "query-string": "^4.1.0", + "sort-keys": "^1.0.0" + } + }, + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + } + } + }, + "minimalistic-assert": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", + "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==", + "dev": true + }, + "minimalistic-crypto-utils": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz", + "integrity": "sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo=", + "dev": true + }, + "minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", + "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", + "dev": true + }, + "minipass": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.1.3.tgz", + "integrity": "sha512-Mgd2GdMVzY+x3IJ+oHnVM+KG3lA5c8tnabyJKmHSaG2kAGpudxuOf8ToDkhumF7UzME7DecbQE9uOZhNm7PuJg==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + }, + "dependencies": { + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + } + } + }, + "mississippi": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/mississippi/-/mississippi-3.0.0.tgz", + "integrity": "sha512-x471SsVjUtBRtcvd4BzKE9kFC+/2TeWgKCgw0bZcw1b9l2X3QX5vCWgF+KaZaYm87Ss//rHnWryupDrgLvmSkA==", + "dev": true, + "requires": { + "concat-stream": "^1.5.0", + "duplexify": "^3.4.2", + "end-of-stream": "^1.1.0", + "flush-write-stream": "^1.0.0", + "from2": "^2.1.0", + "parallel-transform": "^1.1.0", + "pump": "^3.0.0", + "pumpify": "^1.3.3", + "stream-each": "^1.1.0", + "through2": "^2.0.0" + } + }, + "mixin-deep": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.2.tgz", + "integrity": "sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA==", + "dev": true, + "requires": { + "for-in": "^1.0.2", + "is-extendable": "^1.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "dev": true, + "requires": { + "is-plain-object": "^2.0.4" + } + } + } + }, + "mkdirp": { + "version": "0.5.5", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", + "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", + "dev": true, + "requires": { + "minimist": "^1.2.5" + } + }, + "moment": { + "version": "2.29.1", + "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz", + "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ==" + }, + "move-concurrently": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/move-concurrently/-/move-concurrently-1.0.1.tgz", + "integrity": "sha1-viwAX9oy4LKa8fBdfEszIUxwH5I=", + "dev": true, + "requires": { + "aproba": "^1.1.1", + "copy-concurrently": "^1.0.0", + "fs-write-stream-atomic": "^1.0.8", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.4", + "run-queue": "^1.0.3" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "multicast-dns": { + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/multicast-dns/-/multicast-dns-6.2.3.tgz", + "integrity": "sha512-ji6J5enbMyGRHIAkAOu3WdV8nggqviKCEKtXcOqfphZZtQrmHKycfynJ2V7eVPUA4NhJ6V7Wf4TmGbTwKE9B6g==", + "dev": true, + "requires": { + "dns-packet": "^1.3.1", + "thunky": "^1.0.2" + } + }, + "multicast-dns-service-types": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/multicast-dns-service-types/-/multicast-dns-service-types-1.1.0.tgz", + "integrity": "sha1-iZ8R2WhuXgXLkbNdXw5jt3PPyQE=", + "dev": true + }, + "mute-stream": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", + "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", + "dev": true + }, + "mz": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz", + "integrity": "sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==", + "dev": true, + "requires": { + "any-promise": "^1.0.0", + "object-assign": "^4.0.1", + "thenify-all": "^1.0.0" + } + }, + "nan": { + "version": "2.14.2", + "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.2.tgz", + "integrity": "sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ==", + "dev": true, + "optional": true + }, + "nanomatch": { + "version": "1.2.13", + "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", + "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", + "dev": true, + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "fragment-cache": "^0.2.1", + "is-windows": "^1.0.2", + "kind-of": "^6.0.2", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + } + }, + "natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", + "dev": true + }, + "negotiator": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", + "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==", + "dev": true + }, + "neo-async": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz", + "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==", + "dev": true + }, + "nice-try": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", + "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", + "dev": true + }, + "no-case": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/no-case/-/no-case-2.3.2.tgz", + "integrity": "sha512-rmTZ9kz+f3rCvK2TD1Ue/oZlns7OGoIWP4fc3llxxRXlOkHKoWPPWJOfFYpITabSow43QJbRIoHQXtt10VldyQ==", + "dev": true, + "requires": { + "lower-case": "^1.1.1" + } + }, + "node-fetch": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.1.tgz", + "integrity": "sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw==" + }, + "node-forge": { + "version": "0.10.0", + "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-0.10.0.tgz", + "integrity": "sha512-PPmu8eEeG9saEUvI97fm4OYxXVB6bFvyNTyiUOBichBpFG8A1Ljw3bY62+5oOjDEMHRnd0Y7HQ+x7uzxOzC6JA==", + "dev": true + }, + "node-ipc": { + "version": "9.1.3", + "resolved": "https://registry.npmjs.org/node-ipc/-/node-ipc-9.1.3.tgz", + "integrity": "sha512-8RS4RZyS/KMKKYG8mrje+cLxwATe9dBCuOiqKFSWND4oOuKytfuKCiR9yinvhoXF/nGdX/WnbywaUee+9U87zA==", + "dev": true, + "requires": { + "event-pubsub": "4.3.0", + "js-message": "1.0.7", + "js-queue": "2.0.2" + } + }, + "node-libs-browser": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/node-libs-browser/-/node-libs-browser-2.2.1.tgz", + "integrity": "sha512-h/zcD8H9kaDZ9ALUWwlBUDo6TKF8a7qBSCSEGfjTVIYeqsioSKaAX+BN7NgiMGp6iSIXZ3PxgCu8KS3b71YK5Q==", + "dev": true, + "requires": { + "assert": "^1.1.1", + "browserify-zlib": "^0.2.0", + "buffer": "^4.3.0", + "console-browserify": "^1.1.0", + "constants-browserify": "^1.0.0", + "crypto-browserify": "^3.11.0", + "domain-browser": "^1.1.1", + "events": "^3.0.0", + "https-browserify": "^1.0.0", + "os-browserify": "^0.3.0", + "path-browserify": "0.0.1", + "process": "^0.11.10", + "punycode": "^1.2.4", + "querystring-es3": "^0.2.0", + "readable-stream": "^2.3.3", + "stream-browserify": "^2.0.1", + "stream-http": "^2.7.2", + "string_decoder": "^1.0.0", + "timers-browserify": "^2.0.4", + "tty-browserify": "0.0.0", + "url": "^0.11.0", + "util": "^0.11.0", + "vm-browserify": "^1.0.1" + }, + "dependencies": { + "punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", + "dev": true + } + } + }, + "node-releases": { + "version": "1.1.67", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.67.tgz", + "integrity": "sha512-V5QF9noGFl3EymEwUYzO+3NTDpGfQB4ve6Qfnzf3UNydMhjQRVPR1DZTuvWiLzaFJYw2fmDwAfnRNEVb64hSIg==", + "dev": true + }, + "normalize-package-data": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", + "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", + "dev": true, + "requires": { + "hosted-git-info": "^2.1.4", + "resolve": "^1.10.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + } + }, + "normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "dev": true + }, + "normalize-range": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", + "integrity": "sha1-LRDAa9/TEuqXd2laTShDlFa3WUI=", + "dev": true + }, + "normalize-url": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-3.3.0.tgz", + "integrity": "sha512-U+JJi7duF1o+u2pynbp2zXDW2/PADgC30f0GsHZtRh+HOcXHnw137TrNlyxxRvWW5fjKd3bcLHPxofWuCjaeZg==", + "dev": true + }, + "npm-run-path": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", + "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", + "dev": true, + "requires": { + "path-key": "^2.0.0" + } + }, + "nth-check": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-1.0.2.tgz", + "integrity": "sha512-WeBOdju8SnzPN5vTUJYxYUxLeXpCaVP5i5e0LF8fg7WORF2Wd7wFX/pk0tYZk7s8T+J7VLy0Da6J1+wCT0AtHg==", + "dev": true, + "requires": { + "boolbase": "~1.0.0" + } + }, + "num2fraction": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/num2fraction/-/num2fraction-1.2.2.tgz", + "integrity": "sha1-b2gragJ6Tp3fpFZM0lidHU5mnt4=", + "dev": true + }, + "oauth-sign": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", + "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", + "dev": true + }, + "object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", + "dev": true + }, + "object-copy": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", + "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", + "dev": true, + "requires": { + "copy-descriptor": "^0.1.0", + "define-property": "^0.2.5", + "kind-of": "^3.0.3" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "object-hash": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-1.3.1.tgz", + "integrity": "sha512-OSuu/pU4ENM9kmREg0BdNrUDIl1heYa4mBZacJc+vVWz4GtAwu7jO8s4AIt2aGRUTqxykpWzI3Oqnsm13tTMDA==", + "dev": true + }, + "object-inspect": { + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.11.0.tgz", + "integrity": "sha512-jp7ikS6Sd3GxQfZJPyH3cjcbJF6GZPClgdV+EFygjFLQ5FmW/dRUnTd9PQ9k0JhoNDabWFbpF1yCdSWCC6gexg==", + "dev": true + }, + "object-is": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/object-is/-/object-is-1.1.5.tgz", + "integrity": "sha512-3cyDsyHgtmi7I7DfSSI2LDp6SK2lwvtbg0p0R1e0RvTqF5ceGx+K2dfSjm1bKDMVCFEDAQvy+o8c6a7VujOddw==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3" + }, + "dependencies": { + "call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + } + }, + "get-intrinsic": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", + "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + } + } + } + }, + "object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", + "dev": true + }, + "object-visit": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", + "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", + "dev": true, + "requires": { + "isobject": "^3.0.0" + } + }, + "object.assign": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz", + "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.0", + "define-properties": "^1.1.3", + "has-symbols": "^1.0.1", + "object-keys": "^1.1.1" + } + }, + "object.getownpropertydescriptors": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.2.tgz", + "integrity": "sha512-WtxeKSzfBjlzL+F9b7M7hewDzMwy+C8NRssHd1YrNlzHzIDrXcXiNOMrezdAEM4UXixgV+vvnyBeN7Rygl2ttQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3", + "es-abstract": "^1.18.0-next.2" + }, + "dependencies": { + "call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + } + }, + "get-intrinsic": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", + "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + } + } + } + }, + "object.pick": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", + "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", + "dev": true, + "requires": { + "isobject": "^3.0.1" + } + }, + "object.values": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.4.tgz", + "integrity": "sha512-TnGo7j4XSnKQoK3MfvkzqKCi0nVe/D9I9IjwTNYdb/fxYHpjrluHVOgw0AF6jrRFGMPHdfuidR09tIDiIvnaSg==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3", + "es-abstract": "^1.18.2" + }, + "dependencies": { + "call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + } + }, + "get-intrinsic": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", + "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + } + } + } + }, + "obuf": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/obuf/-/obuf-1.1.2.tgz", + "integrity": "sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg==", + "dev": true + }, + "on-finished": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", + "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", + "dev": true, + "requires": { + "ee-first": "1.1.1" + } + }, + "on-headers": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", + "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==", + "dev": true + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "onetime": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", + "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", + "dev": true, + "requires": { + "mimic-fn": "^1.0.0" + } + }, + "open": { + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/open/-/open-6.4.0.tgz", + "integrity": "sha512-IFenVPgF70fSm1keSd2iDBIDIBZkroLeuffXq+wKTzTJlBpesFWojV9lb8mzOfaAzM1sr7HQHuO0vtV0zYekGg==", + "dev": true, + "requires": { + "is-wsl": "^1.1.0" + } + }, + "opener": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/opener/-/opener-1.5.2.tgz", + "integrity": "sha512-ur5UIdyw5Y7yEj9wLzhqXiy6GZ3Mwx0yGI+5sMn2r0N0v3cKJvUmFH5yPP+WXh9e0xfyzyJX95D8l088DNFj7A==", + "dev": true + }, + "opn": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/opn/-/opn-5.5.0.tgz", + "integrity": "sha512-PqHpggC9bLV0VeWcdKhkpxY+3JTzetLSqTCWL/z/tFIbI6G8JCjondXklT1JinczLz2Xib62sSp0T/gKT4KksA==", + "dev": true, + "requires": { + "is-wsl": "^1.1.0" + } + }, + "optionator": { + "version": "0.9.1", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", + "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", + "dev": true, + "requires": { + "deep-is": "^0.1.3", + "fast-levenshtein": "^2.0.6", + "levn": "^0.4.1", + "prelude-ls": "^1.2.1", + "type-check": "^0.4.0", + "word-wrap": "^1.2.3" + } + }, + "ora": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/ora/-/ora-3.4.0.tgz", + "integrity": "sha512-eNwHudNbO1folBP3JsZ19v9azXWtQZjICdr3Q0TDPIaeBQ3mXLrh54wM+er0+hSp+dWKf+Z8KM58CYzEyIYxYg==", + "dev": true, + "requires": { + "chalk": "^2.4.2", + "cli-cursor": "^2.1.0", + "cli-spinners": "^2.0.0", + "log-symbols": "^2.2.0", + "strip-ansi": "^5.2.0", + "wcwidth": "^1.0.1" + }, + "dependencies": { + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + } + } + }, + "original": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/original/-/original-1.0.2.tgz", + "integrity": "sha512-hyBVl6iqqUOJ8FqRe+l/gS8H+kKYjrEndd5Pm1MfBtsEKA038HkkdbAl/72EAXGyonD/PFsvmVG+EvcIpliMBg==", + "dev": true, + "requires": { + "url-parse": "^1.4.3" + } + }, + "os-browserify": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/os-browserify/-/os-browserify-0.3.0.tgz", + "integrity": "sha1-hUNzx/XCMVkU/Jv8a9gjj92h7Cc=", + "dev": true + }, + "os-tmpdir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", + "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", + "dev": true + }, + "p-finally": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", + "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=", + "dev": true + }, + "p-limit": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", + "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", + "dev": true, + "requires": { + "p-try": "^2.0.0" + } + }, + "p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "dev": true, + "requires": { + "p-limit": "^2.2.0" + } + }, + "p-map": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/p-map/-/p-map-2.1.0.tgz", + "integrity": "sha512-y3b8Kpd8OAN444hxfBbFfj1FY/RjtTd8tzYwhUqNYXx0fXx2iX4maP4Qr6qhIKbQXI02wTLAda4fYUbDagTUFw==", + "dev": true + }, + "p-retry": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/p-retry/-/p-retry-3.0.1.tgz", + "integrity": "sha512-XE6G4+YTTkT2a0UWb2kjZe8xNwf8bIbnqpc/IS/idOBVhyves0mK5OJgeocjx7q5pvX/6m23xuzVPYT1uGM73w==", + "dev": true, + "requires": { + "retry": "^0.12.0" + } + }, + "p-try": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", + "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", + "dev": true + }, + "pako": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.11.tgz", + "integrity": "sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==", + "dev": true + }, + "parallel-transform": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/parallel-transform/-/parallel-transform-1.2.0.tgz", + "integrity": "sha512-P2vSmIu38uIlvdcU7fDkyrxj33gTUy/ABO5ZUbGowxNCopBq/OoD42bP4UmMrJoPyk4Uqf0mu3mtWBhHCZD8yg==", + "dev": true, + "requires": { + "cyclist": "^1.0.1", + "inherits": "^2.0.3", + "readable-stream": "^2.1.5" + } + }, + "param-case": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/param-case/-/param-case-2.1.1.tgz", + "integrity": "sha1-35T9jPZTHs915r75oIWPvHK+Ikc=", + "dev": true, + "requires": { + "no-case": "^2.2.0" + } + }, + "parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "requires": { + "callsites": "^3.0.0" + }, + "dependencies": { + "callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true + } + } + }, + "parse-asn1": { + "version": "5.1.6", + "resolved": "https://registry.npmjs.org/parse-asn1/-/parse-asn1-5.1.6.tgz", + "integrity": "sha512-RnZRo1EPU6JBnra2vGHj0yhp6ebyjBZpmUCLHWiFhxlzvBCCpAuZ7elsBp1PVAbQN0/04VD/19rfzlBSwLstMw==", + "dev": true, + "requires": { + "asn1.js": "^5.2.0", + "browserify-aes": "^1.0.0", + "evp_bytestokey": "^1.0.0", + "pbkdf2": "^3.0.3", + "safe-buffer": "^5.1.1" + } + }, + "parse-json": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.1.0.tgz", + "integrity": "sha512-+mi/lmVVNKFNVyLXV31ERiy2CY5E1/F6QtJFEzoChPRwwngMNXRDQ9GJ5WdE2Z2P4AujsOi0/+2qHID68KwfIQ==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.0.0", + "error-ex": "^1.3.1", + "json-parse-even-better-errors": "^2.3.0", + "lines-and-columns": "^1.1.6" + } + }, + "parse5": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-5.1.1.tgz", + "integrity": "sha512-ugq4DFI0Ptb+WWjAdOK16+u/nHfiIrcE+sh8kZMaM0WllQKLI9rOUq6c2b7cwPkXdzfQESqvoqK6ug7U/Yyzug==", + "dev": true + }, + "parse5-htmlparser2-tree-adapter": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-6.0.1.tgz", + "integrity": "sha512-qPuWvbLgvDGilKc5BoicRovlT4MtYT6JfJyBOMDsKoiT+GiuP5qyrPCnR9HcPECIJJmZh5jRndyNThnhhb/vlA==", + "dev": true, + "requires": { + "parse5": "^6.0.1" + }, + "dependencies": { + "parse5": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz", + "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==", + "dev": true + } + } + }, + "parseurl": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", + "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", + "dev": true + }, + "pascalcase": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", + "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=", + "dev": true + }, + "path-browserify": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-0.0.1.tgz", + "integrity": "sha512-BapA40NHICOS+USX9SN4tyhq+A2RrN/Ws5F0Z5aMHDp98Fl86lX8Oti8B7uN93L4Ifv4fHOEA+pQw87gmMO/lQ==", + "dev": true + }, + "path-dirname": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", + "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", + "dev": true + }, + "path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", + "dev": true + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", + "dev": true + }, + "path-is-inside": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", + "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", + "dev": true + }, + "path-key": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", + "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", + "dev": true + }, + "path-parse": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", + "dev": true + }, + "path-to-regexp": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", + "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=", + "dev": true + }, + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "dev": true, + "requires": { + "pify": "^3.0.0" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + } + } + }, + "pbkdf2": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/pbkdf2/-/pbkdf2-3.1.1.tgz", + "integrity": "sha512-4Ejy1OPxi9f2tt1rRV7Go7zmfDQ+ZectEQz3VGUQhgq62HtIRPDyG/JtnwIxs6x3uNMwo2V7q1fMvKjb+Tnpqg==", + "dev": true, + "requires": { + "create-hash": "^1.1.2", + "create-hmac": "^1.1.4", + "ripemd160": "^2.0.1", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + } + }, + "performance-now": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", + "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", + "dev": true + }, + "picomatch": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", + "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", + "dev": true + }, + "pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", + "dev": true + }, + "pinkie": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", + "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", + "dev": true + }, + "pinkie-promise": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", + "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", + "dev": true, + "requires": { + "pinkie": "^2.0.0" + } + }, + "pkg-dir": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", + "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", + "dev": true, + "requires": { + "find-up": "^4.0.0" + } + }, + "pnp-webpack-plugin": { + "version": "1.6.4", + "resolved": "https://registry.npmjs.org/pnp-webpack-plugin/-/pnp-webpack-plugin-1.6.4.tgz", + "integrity": "sha512-7Wjy+9E3WwLOEL30D+m8TSTF7qJJUJLONBnwQp0518siuMxUQUbgZwssaFX+QKlZkjHZcw/IpZCt/H0srrntSg==", + "dev": true, + "requires": { + "ts-pnp": "^1.1.6" + } + }, + "popper.js": { + "version": "1.16.1", + "resolved": "https://registry.npmjs.org/popper.js/-/popper.js-1.16.1.tgz", + "integrity": "sha512-Wb4p1J4zyFTbM+u6WuO4XstYx4Ky9Cewe4DWrel7B0w6VVICvPwdOpotjzcf6eD8TsckVnIMNONQyPIUFOUbCQ==" + }, + "portal-vue": { + "version": "2.1.7", + "resolved": "https://registry.npmjs.org/portal-vue/-/portal-vue-2.1.7.tgz", + "integrity": "sha512-+yCno2oB3xA7irTt0EU5Ezw22L2J51uKAacE/6hMPMoO/mx3h4rXFkkBkT4GFsMDv/vEe8TNKC3ujJJ0PTwb6g==" + }, + "portfinder": { + "version": "1.0.28", + "resolved": "https://registry.npmjs.org/portfinder/-/portfinder-1.0.28.tgz", + "integrity": "sha512-Se+2isanIcEqf2XMHjyUKskczxbPH7dQnlMjXX6+dybayyHvAf/TCgyMRlzf/B6QDhAEFOGes0pzRo3by4AbMA==", + "dev": true, + "requires": { + "async": "^2.6.2", + "debug": "^3.1.1", + "mkdirp": "^0.5.5" + }, + "dependencies": { + "debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "posix-character-classes": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", + "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=", + "dev": true + }, + "postcss": { + "version": "7.0.36", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.36.tgz", + "integrity": "sha512-BebJSIUMwJHRH0HAQoxN4u1CN86glsrwsW0q7T+/m44eXOUAxSNdHRkNZPYz5vVUbg17hFgOQDE7fZk7li3pZw==", + "dev": true, + "requires": { + "chalk": "^2.4.2", + "source-map": "^0.6.1", + "supports-color": "^6.1.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + }, + "supports-color": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", + "integrity": "sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "postcss-calc": { + "version": "7.0.5", + "resolved": "https://registry.npmjs.org/postcss-calc/-/postcss-calc-7.0.5.tgz", + "integrity": "sha512-1tKHutbGtLtEZF6PT4JSihCHfIVldU72mZ8SdZHIYriIZ9fh9k9aWSppaT8rHsyI3dX+KSR+W+Ix9BMY3AODrg==", + "dev": true, + "requires": { + "postcss": "^7.0.27", + "postcss-selector-parser": "^6.0.2", + "postcss-value-parser": "^4.0.2" + } + }, + "postcss-colormin": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-colormin/-/postcss-colormin-4.0.3.tgz", + "integrity": "sha512-WyQFAdDZpExQh32j0U0feWisZ0dmOtPl44qYmJKkq9xFWY3p+4qnRzCHeNrkeRhwPHz9bQ3mo0/yVkaply0MNw==", + "dev": true, + "requires": { + "browserslist": "^4.0.0", + "color": "^3.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-convert-values": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-convert-values/-/postcss-convert-values-4.0.1.tgz", + "integrity": "sha512-Kisdo1y77KUC0Jmn0OXU/COOJbzM8cImvw1ZFsBgBgMgb1iL23Zs/LXRe3r+EZqM3vGYKdQ2YJVQ5VkJI+zEJQ==", + "dev": true, + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-discard-comments": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-discard-comments/-/postcss-discard-comments-4.0.2.tgz", + "integrity": "sha512-RJutN259iuRf3IW7GZyLM5Sw4GLTOH8FmsXBnv8Ab/Tc2k4SR4qbV4DNbyyY4+Sjo362SyDmW2DQ7lBSChrpkg==", + "dev": true, + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-discard-duplicates": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-discard-duplicates/-/postcss-discard-duplicates-4.0.2.tgz", + "integrity": "sha512-ZNQfR1gPNAiXZhgENFfEglF93pciw0WxMkJeVmw8eF+JZBbMD7jp6C67GqJAXVZP2BWbOztKfbsdmMp/k8c6oQ==", + "dev": true, + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-discard-empty": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-discard-empty/-/postcss-discard-empty-4.0.1.tgz", + "integrity": "sha512-B9miTzbznhDjTfjvipfHoqbWKwd0Mj+/fL5s1QOz06wufguil+Xheo4XpOnc4NqKYBCNqqEzgPv2aPBIJLox0w==", + "dev": true, + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-discard-overridden": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-discard-overridden/-/postcss-discard-overridden-4.0.1.tgz", + "integrity": "sha512-IYY2bEDD7g1XM1IDEsUT4//iEYCxAmP5oDSFMVU/JVvT7gh+l4fmjciLqGgwjdWpQIdb0Che2VX00QObS5+cTg==", + "dev": true, + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-load-config": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-2.1.2.tgz", + "integrity": "sha512-/rDeGV6vMUo3mwJZmeHfEDvwnTKKqQ0S7OHUi/kJvvtx3aWtyWG2/0ZWnzCt2keEclwN6Tf0DST2v9kITdOKYw==", + "dev": true, + "requires": { + "cosmiconfig": "^5.0.0", + "import-cwd": "^2.0.0" + } + }, + "postcss-loader": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-3.0.0.tgz", + "integrity": "sha512-cLWoDEY5OwHcAjDnkyRQzAXfs2jrKjXpO/HQFcc5b5u/r7aa471wdmChmwfnv7x2u840iat/wi0lQ5nbRgSkUA==", + "dev": true, + "requires": { + "loader-utils": "^1.1.0", + "postcss": "^7.0.0", + "postcss-load-config": "^2.0.0", + "schema-utils": "^1.0.0" + }, + "dependencies": { + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + } + } + }, + "postcss-merge-longhand": { + "version": "4.0.11", + "resolved": "https://registry.npmjs.org/postcss-merge-longhand/-/postcss-merge-longhand-4.0.11.tgz", + "integrity": "sha512-alx/zmoeXvJjp7L4mxEMjh8lxVlDFX1gqWHzaaQewwMZiVhLo42TEClKaeHbRf6J7j82ZOdTJ808RtN0ZOZwvw==", + "dev": true, + "requires": { + "css-color-names": "0.0.4", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "stylehacks": "^4.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-merge-rules": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-merge-rules/-/postcss-merge-rules-4.0.3.tgz", + "integrity": "sha512-U7e3r1SbvYzO0Jr3UT/zKBVgYYyhAz0aitvGIYOYK5CPmkNih+WDSsS5tvPrJ8YMQYlEMvsZIiqmn7HdFUaeEQ==", + "dev": true, + "requires": { + "browserslist": "^4.0.0", + "caniuse-api": "^3.0.0", + "cssnano-util-same-parent": "^4.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0", + "vendors": "^1.0.0" + }, + "dependencies": { + "postcss-selector-parser": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-3.1.2.tgz", + "integrity": "sha512-h7fJ/5uWuRVyOtkO45pnt1Ih40CEleeyCHzipqAZO2e5H20g25Y48uYnFUiShvY4rZWNJ/Bib/KVPmanaCtOhA==", + "dev": true, + "requires": { + "dot-prop": "^5.2.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-minify-font-values": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-font-values/-/postcss-minify-font-values-4.0.2.tgz", + "integrity": "sha512-j85oO6OnRU9zPf04+PZv1LYIYOprWm6IA6zkXkrJXyRveDEuQggG6tvoy8ir8ZwjLxLuGfNkCZEQG7zan+Hbtg==", + "dev": true, + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-minify-gradients": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-gradients/-/postcss-minify-gradients-4.0.2.tgz", + "integrity": "sha512-qKPfwlONdcf/AndP1U8SJ/uzIJtowHlMaSioKzebAXSG4iJthlWC9iSWznQcX4f66gIWX44RSA841HTHj3wK+Q==", + "dev": true, + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "is-color-stop": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-minify-params": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-params/-/postcss-minify-params-4.0.2.tgz", + "integrity": "sha512-G7eWyzEx0xL4/wiBBJxJOz48zAKV2WG3iZOqVhPet/9geefm/Px5uo1fzlHu+DOjT+m0Mmiz3jkQzVHe6wxAWg==", + "dev": true, + "requires": { + "alphanum-sort": "^1.0.0", + "browserslist": "^4.0.0", + "cssnano-util-get-arguments": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "uniqs": "^2.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-minify-selectors": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-selectors/-/postcss-minify-selectors-4.0.2.tgz", + "integrity": "sha512-D5S1iViljXBj9kflQo4YutWnJmwm8VvIsU1GeXJGiG9j8CIg9zs4voPMdQDUmIxetUOh60VilsNzCiAFTOqu3g==", + "dev": true, + "requires": { + "alphanum-sort": "^1.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0" + }, + "dependencies": { + "postcss-selector-parser": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-3.1.2.tgz", + "integrity": "sha512-h7fJ/5uWuRVyOtkO45pnt1Ih40CEleeyCHzipqAZO2e5H20g25Y48uYnFUiShvY4rZWNJ/Bib/KVPmanaCtOhA==", + "dev": true, + "requires": { + "dot-prop": "^5.2.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-modules-extract-imports": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-2.0.0.tgz", + "integrity": "sha512-LaYLDNS4SG8Q5WAWqIJgdHPJrDDr/Lv775rMBFUbgjTz6j34lUznACHcdRWroPvXANP2Vj7yNK57vp9eFqzLWQ==", + "dev": true, + "requires": { + "postcss": "^7.0.5" + } + }, + "postcss-modules-local-by-default": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-3.0.3.tgz", + "integrity": "sha512-e3xDq+LotiGesympRlKNgaJ0PCzoUIdpH0dj47iWAui/kyTgh3CiAr1qP54uodmJhl6p9rN6BoNcdEDVJx9RDw==", + "dev": true, + "requires": { + "icss-utils": "^4.1.1", + "postcss": "^7.0.32", + "postcss-selector-parser": "^6.0.2", + "postcss-value-parser": "^4.1.0" + } + }, + "postcss-modules-scope": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-2.2.0.tgz", + "integrity": "sha512-YyEgsTMRpNd+HmyC7H/mh3y+MeFWevy7V1evVhJWewmMbjDHIbZbOXICC2y+m1xI1UVfIT1HMW/O04Hxyu9oXQ==", + "dev": true, + "requires": { + "postcss": "^7.0.6", + "postcss-selector-parser": "^6.0.0" + } + }, + "postcss-modules-values": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-modules-values/-/postcss-modules-values-3.0.0.tgz", + "integrity": "sha512-1//E5jCBrZ9DmRX+zCtmQtRSV6PV42Ix7Bzj9GbwJceduuf7IqP8MgeTXuRDHOWj2m0VzZD5+roFWDuU8RQjcg==", + "dev": true, + "requires": { + "icss-utils": "^4.0.0", + "postcss": "^7.0.6" + } + }, + "postcss-normalize-charset": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-charset/-/postcss-normalize-charset-4.0.1.tgz", + "integrity": "sha512-gMXCrrlWh6G27U0hF3vNvR3w8I1s2wOBILvA87iNXaPvSNo5uZAMYsZG7XjCUf1eVxuPfyL4TJ7++SGZLc9A3g==", + "dev": true, + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-normalize-display-values": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-display-values/-/postcss-normalize-display-values-4.0.2.tgz", + "integrity": "sha512-3F2jcsaMW7+VtRMAqf/3m4cPFhPD3EFRgNs18u+k3lTJJlVe7d0YPO+bnwqo2xg8YiRpDXJI2u8A0wqJxMsQuQ==", + "dev": true, + "requires": { + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-normalize-positions": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-positions/-/postcss-normalize-positions-4.0.2.tgz", + "integrity": "sha512-Dlf3/9AxpxE+NF1fJxYDeggi5WwV35MXGFnnoccP/9qDtFrTArZ0D0R+iKcg5WsUd8nUYMIl8yXDCtcrT8JrdA==", + "dev": true, + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-normalize-repeat-style": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-repeat-style/-/postcss-normalize-repeat-style-4.0.2.tgz", + "integrity": "sha512-qvigdYYMpSuoFs3Is/f5nHdRLJN/ITA7huIoCyqqENJe9PvPmLhNLMu7QTjPdtnVf6OcYYO5SHonx4+fbJE1+Q==", + "dev": true, + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-normalize-string": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-string/-/postcss-normalize-string-4.0.2.tgz", + "integrity": "sha512-RrERod97Dnwqq49WNz8qo66ps0swYZDSb6rM57kN2J+aoyEAJfZ6bMx0sx/F9TIEX0xthPGCmeyiam/jXif0eA==", + "dev": true, + "requires": { + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-normalize-timing-functions": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-timing-functions/-/postcss-normalize-timing-functions-4.0.2.tgz", + "integrity": "sha512-acwJY95edP762e++00Ehq9L4sZCEcOPyaHwoaFOhIwWCDfik6YvqsYNxckee65JHLKzuNSSmAdxwD2Cud1Z54A==", + "dev": true, + "requires": { + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-normalize-unicode": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-unicode/-/postcss-normalize-unicode-4.0.1.tgz", + "integrity": "sha512-od18Uq2wCYn+vZ/qCOeutvHjB5jm57ToxRaMeNuf0nWVHaP9Hua56QyMF6fs/4FSUnVIw0CBPsU0K4LnBPwYwg==", + "dev": true, + "requires": { + "browserslist": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-normalize-url": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-url/-/postcss-normalize-url-4.0.1.tgz", + "integrity": "sha512-p5oVaF4+IHwu7VpMan/SSpmpYxcJMtkGppYf0VbdH5B6hN8YNmVyJLuY9FmLQTzY3fag5ESUUHDqM+heid0UVA==", + "dev": true, + "requires": { + "is-absolute-url": "^2.0.0", + "normalize-url": "^3.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-normalize-whitespace": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-whitespace/-/postcss-normalize-whitespace-4.0.2.tgz", + "integrity": "sha512-tO8QIgrsI3p95r8fyqKV+ufKlSHh9hMJqACqbv2XknufqEDhDvbguXGBBqxw9nsQoXWf0qOqppziKJKHMD4GtA==", + "dev": true, + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-ordered-values": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/postcss-ordered-values/-/postcss-ordered-values-4.1.2.tgz", + "integrity": "sha512-2fCObh5UanxvSxeXrtLtlwVThBvHn6MQcu4ksNT2tsaV2Fg76R2CV98W7wNSlX+5/pFwEyaDwKLLoEV7uRybAw==", + "dev": true, + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-reduce-initial": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-reduce-initial/-/postcss-reduce-initial-4.0.3.tgz", + "integrity": "sha512-gKWmR5aUulSjbzOfD9AlJiHCGH6AEVLaM0AV+aSioxUDd16qXP1PCh8d1/BGVvpdWn8k/HiK7n6TjeoXN1F7DA==", + "dev": true, + "requires": { + "browserslist": "^4.0.0", + "caniuse-api": "^3.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0" + } + }, + "postcss-reduce-transforms": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-reduce-transforms/-/postcss-reduce-transforms-4.0.2.tgz", + "integrity": "sha512-EEVig1Q2QJ4ELpJXMZR8Vt5DQx8/mo+dGWSR7vWXqcob2gQLyQGsionYcGKATXvQzMPn6DSN1vTN7yFximdIAg==", + "dev": true, + "requires": { + "cssnano-util-get-match": "^4.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-selector-parser": { + "version": "6.0.6", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.6.tgz", + "integrity": "sha512-9LXrvaaX3+mcv5xkg5kFwqSzSH1JIObIx51PrndZwlmznwXRfxMddDvo9gve3gVR8ZTKgoFDdWkbRFmEhT4PMg==", + "dev": true, + "requires": { + "cssesc": "^3.0.0", + "util-deprecate": "^1.0.2" + } + }, + "postcss-svgo": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-svgo/-/postcss-svgo-4.0.3.tgz", + "integrity": "sha512-NoRbrcMWTtUghzuKSoIm6XV+sJdvZ7GZSc3wdBN0W19FTtp2ko8NqLsgoh/m9CzNhU3KLPvQmjIwtaNFkaFTvw==", + "dev": true, + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "svgo": "^1.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + } + } + }, + "postcss-unique-selectors": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-unique-selectors/-/postcss-unique-selectors-4.0.1.tgz", + "integrity": "sha512-+JanVaryLo9QwZjKrmJgkI4Fn8SBgRO6WXQBJi7KiAVPlmxikB5Jzc4EvXMT2H0/m0RjrVVm9rGNhZddm/8Spg==", + "dev": true, + "requires": { + "alphanum-sort": "^1.0.0", + "postcss": "^7.0.0", + "uniqs": "^2.0.0" + } + }, + "postcss-value-parser": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.1.0.tgz", + "integrity": "sha512-97DXOFbQJhk71ne5/Mt6cOu6yxsSfM0QGQyl0L25Gca4yGWEGJaig7l7gbCX623VqTBNGLRLaVUCnNkcedlRSQ==", + "dev": true + }, + "prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true + }, + "prepend-http": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz", + "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=", + "dev": true + }, + "prettier": { + "version": "1.19.1", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-1.19.1.tgz", + "integrity": "sha512-s7PoyDv/II1ObgQunCbB9PdLmUcBZcnWOcxDh7O0N/UwDEsHyqkW+Qh28jW+mVuCdx7gLB0BotYI1Y6uI9iyew==", + "dev": true, + "optional": true + }, + "pretty-error": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/pretty-error/-/pretty-error-2.1.2.tgz", + "integrity": "sha512-EY5oDzmsX5wvuynAByrmY0P0hcp+QpnAKbJng2A2MPjVKXCxrDSUkzghVJ4ZGPIv+JC4gX8fPUWscC0RtjsWGw==", + "dev": true, + "requires": { + "lodash": "^4.17.20", + "renderkid": "^2.0.4" + } + }, + "process": { + "version": "0.11.10", + "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", + "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=", + "dev": true + }, + "process-nextick-args": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", + "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", + "dev": true + }, + "progress": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", + "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", + "dev": true + }, + "promise-inflight": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/promise-inflight/-/promise-inflight-1.0.1.tgz", + "integrity": "sha1-mEcocL8igTL8vdhoEputEsPAKeM=", + "dev": true + }, + "proxy-addr": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", + "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", + "dev": true, + "requires": { + "forwarded": "0.2.0", + "ipaddr.js": "1.9.1" + } + }, + "prr": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz", + "integrity": "sha1-0/wRS6BplaRexok/SEzrHXj19HY=", + "dev": true + }, + "pseudomap": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", + "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", + "dev": true + }, + "psl": { + "version": "1.8.0", + "resolved": "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz", + "integrity": "sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==", + "dev": true + }, + "public-encrypt": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/public-encrypt/-/public-encrypt-4.0.3.tgz", + "integrity": "sha512-zVpa8oKZSz5bTMTFClc1fQOnyyEzpl5ozpi1B5YcvBrdohMjH2rfsBtyXcuNuwjsDIXmBYlF2N5FlJYhR29t8Q==", + "dev": true, + "requires": { + "bn.js": "^4.1.0", + "browserify-rsa": "^4.0.0", + "create-hash": "^1.1.0", + "parse-asn1": "^5.0.0", + "randombytes": "^2.0.1", + "safe-buffer": "^5.1.2" + }, + "dependencies": { + "bn.js": { + "version": "4.11.9", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.9.tgz", + "integrity": "sha512-E6QoYqCKZfgatHTdHzs1RRKP7ip4vvm+EyRUeE2RF0NblwVvb0p6jSVeNTOFxPn26QXN2o6SMfNxKp6kU8zQaw==", + "dev": true + } + } + }, + "pump": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", + "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", + "dev": true, + "requires": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + }, + "pumpify": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-1.5.1.tgz", + "integrity": "sha512-oClZI37HvuUJJxSKKrC17bZ9Cu0ZYhEAGPsPUy9KlMUmv9dKX2o77RUmq7f3XjIxbwyGwYzbzQ1L2Ks8sIradQ==", + "dev": true, + "requires": { + "duplexify": "^3.6.0", + "inherits": "^2.0.3", + "pump": "^2.0.0" + }, + "dependencies": { + "pump": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pump/-/pump-2.0.1.tgz", + "integrity": "sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==", + "dev": true, + "requires": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + } + } + }, + "punycode": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", + "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", + "dev": true + }, + "q": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", + "integrity": "sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc=", + "dev": true + }, + "qs": { + "version": "6.5.2", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", + "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", + "dev": true + }, + "query-string": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/query-string/-/query-string-4.3.4.tgz", + "integrity": "sha1-u7aTucqRXCMlFbIosaArYJBD2+s=", + "dev": true, + "requires": { + "object-assign": "^4.1.0", + "strict-uri-encode": "^1.0.0" + } + }, + "querystring": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", + "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", + "dev": true + }, + "querystring-es3": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/querystring-es3/-/querystring-es3-0.2.1.tgz", + "integrity": "sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM=", + "dev": true + }, + "querystringify": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz", + "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==", + "dev": true + }, + "randombytes": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", + "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", + "dev": true, + "requires": { + "safe-buffer": "^5.1.0" + } + }, + "randomfill": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/randomfill/-/randomfill-1.0.4.tgz", + "integrity": "sha512-87lcbR8+MhcWcUiQ+9e+Rwx8MyR2P7qnt15ynUlbm3TU/fjbgz4GsvfSUDTemtCCtVCqb4ZcEFlyPNTh9bBTLw==", + "dev": true, + "requires": { + "randombytes": "^2.0.5", + "safe-buffer": "^5.1.0" + } + }, + "range-parser": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", + "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", + "dev": true + }, + "raw-body": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", + "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", + "dev": true, + "requires": { + "bytes": "3.1.0", + "http-errors": "1.7.2", + "iconv-lite": "0.4.24", + "unpipe": "1.0.0" + } + }, + "read-pkg": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-5.2.0.tgz", + "integrity": "sha512-Ug69mNOpfvKDAc2Q8DRpMjjzdtrnv9HcSMX+4VsZxD1aZ6ZzrIE7rlzXBtWTyhULSMKg076AW6WR5iZpD0JiOg==", + "dev": true, + "requires": { + "@types/normalize-package-data": "^2.4.0", + "normalize-package-data": "^2.5.0", + "parse-json": "^5.0.0", + "type-fest": "^0.6.0" + } + }, + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "dev": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "readdirp": { + "version": "3.5.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.5.0.tgz", + "integrity": "sha512-cMhu7c/8rdhkHXWsY+osBhfSy0JikwpHK/5+imo+LpeasTF8ouErHrlYkwT0++njiyuDvc7OFY5T3ukvZ8qmFQ==", + "dev": true, + "requires": { + "picomatch": "^2.2.1" + } + }, + "regenerate": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz", + "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==", + "dev": true + }, + "regenerate-unicode-properties": { + "version": "8.2.0", + "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-8.2.0.tgz", + "integrity": "sha512-F9DjY1vKLo/tPePDycuH3dn9H1OTPIkVD9Kz4LODu+F2C75mgjAJ7x/gwy6ZcSNRAAkhNlJSOHRe8k3p+K9WhA==", + "dev": true, + "requires": { + "regenerate": "^1.4.0" + } + }, + "regenerator-runtime": { + "version": "0.13.7", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.7.tgz", + "integrity": "sha512-a54FxoJDIr27pgf7IgeQGxmqUNYrcV338lf/6gH456HZ/PhX+5BcwHXG9ajESmwe6WRO0tAzRUrRmNONWgkrew==", + "dev": true + }, + "regenerator-transform": { + "version": "0.14.5", + "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.14.5.tgz", + "integrity": "sha512-eOf6vka5IO151Jfsw2NO9WpGX58W6wWmefK3I1zEGr0lOD0u8rwPaNqQL1aRxUaxLeKO3ArNh3VYg1KbaD+FFw==", + "dev": true, + "requires": { + "@babel/runtime": "^7.8.4" + } + }, + "regex-not": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", + "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", + "dev": true, + "requires": { + "extend-shallow": "^3.0.2", + "safe-regex": "^1.1.0" + } + }, + "regexp.prototype.flags": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.3.1.tgz", + "integrity": "sha512-JiBdRBq91WlY7uRJ0ds7R+dU02i6LKi8r3BuQhNXn+kmeLN+EfHhfjqMRis1zJxnlu88hq/4dx0P2OP3APRTOA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3" + }, + "dependencies": { + "call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + } + }, + "get-intrinsic": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", + "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + } + } + } + }, + "regexpp": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", + "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", + "dev": true + }, + "regexpu-core": { + "version": "4.7.1", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-4.7.1.tgz", + "integrity": "sha512-ywH2VUraA44DZQuRKzARmw6S66mr48pQVva4LBeRhcOltJ6hExvWly5ZjFLYo67xbIxb6W1q4bAGtgfEl20zfQ==", + "dev": true, + "requires": { + "regenerate": "^1.4.0", + "regenerate-unicode-properties": "^8.2.0", + "regjsgen": "^0.5.1", + "regjsparser": "^0.6.4", + "unicode-match-property-ecmascript": "^1.0.4", + "unicode-match-property-value-ecmascript": "^1.2.0" + } + }, + "regjsgen": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.5.2.tgz", + "integrity": "sha512-OFFT3MfrH90xIW8OOSyUrk6QHD5E9JOTeGodiJeBS3J6IwlgzJMNE/1bZklWz5oTg+9dCMyEetclvCVXOPoN3A==", + "dev": true + }, + "regjsparser": { + "version": "0.6.9", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.6.9.tgz", + "integrity": "sha512-ZqbNRz1SNjLAiYuwY0zoXW8Ne675IX5q+YHioAGbCw4X96Mjl2+dcX9B2ciaeyYjViDAfvIjFpQjJgLttTEERQ==", + "dev": true, + "requires": { + "jsesc": "~0.5.0" + }, + "dependencies": { + "jsesc": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", + "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", + "dev": true + } + } + }, + "relateurl": { + "version": "0.2.7", + "resolved": "https://registry.npmjs.org/relateurl/-/relateurl-0.2.7.tgz", + "integrity": "sha1-VNvzd+UUQKypCkzSdGANP/LYiKk=", + "dev": true + }, + "remove-trailing-separator": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", + "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", + "dev": true + }, + "renderkid": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/renderkid/-/renderkid-2.0.7.tgz", + "integrity": "sha512-oCcFyxaMrKsKcTY59qnCAtmDVSLfPbrv6A3tVbPdFMMrv5jaK10V6m40cKsoPNhAqN6rmHW9sswW4o3ruSrwUQ==", + "dev": true, + "requires": { + "css-select": "^4.1.3", + "dom-converter": "^0.2.0", + "htmlparser2": "^6.1.0", + "lodash": "^4.17.21", + "strip-ansi": "^3.0.1" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + }, + "css-select": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/css-select/-/css-select-4.1.3.tgz", + "integrity": "sha512-gT3wBNd9Nj49rAbmtFHj1cljIAOLYSX1nZ8CB7TBO3INYckygm5B7LISU/szY//YmdiSLbJvDLOx9VnMVpMBxA==", + "dev": true, + "requires": { + "boolbase": "^1.0.0", + "css-what": "^5.0.0", + "domhandler": "^4.2.0", + "domutils": "^2.6.0", + "nth-check": "^2.0.0" + } + }, + "css-what": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/css-what/-/css-what-5.0.1.tgz", + "integrity": "sha512-FYDTSHb/7KXsWICVsxdmiExPjCfRC4qRFBdVwv7Ax9hMnvMmEjP9RfxTEZ3qPZGmADDn2vAKSo9UcN1jKVYscg==", + "dev": true + }, + "dom-serializer": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.3.2.tgz", + "integrity": "sha512-5c54Bk5Dw4qAxNOI1pFEizPSjVsx5+bpJKmL2kPn8JhBUq2q09tTCa3mjijun2NfK78NMouDYNMBkOrPZiS+ig==", + "dev": true, + "requires": { + "domelementtype": "^2.0.1", + "domhandler": "^4.2.0", + "entities": "^2.0.0" + } + }, + "domelementtype": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.2.0.tgz", + "integrity": "sha512-DtBMo82pv1dFtUmHyr48beiuq792Sxohr+8Hm9zoxklYPfa6n0Z3Byjj2IV7bmr2IyqClnqEQhfgHJJ5QF0R5A==", + "dev": true + }, + "domutils": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.7.0.tgz", + "integrity": "sha512-8eaHa17IwJUPAiB+SoTYBo5mCdeMgdcAoXJ59m6DT1vw+5iLS3gNoqYaRowaBKtGVrOF1Jz4yDTgYKLK2kvfJg==", + "dev": true, + "requires": { + "dom-serializer": "^1.0.1", + "domelementtype": "^2.2.0", + "domhandler": "^4.2.0" + } + }, + "lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "dev": true + }, + "nth-check": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.0.0.tgz", + "integrity": "sha512-i4sc/Kj8htBrAiH1viZ0TgU8Y5XqCaV/FziYK6TBczxmeKm3AEFWqqF3195yKudrarqy7Zu80Ra5dobFjn9X/Q==", + "dev": true, + "requires": { + "boolbase": "^1.0.0" + } + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + } + } + }, + "repeat-element": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz", + "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==", + "dev": true + }, + "repeat-string": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", + "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", + "dev": true + }, + "request": { + "version": "2.88.2", + "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz", + "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==", + "dev": true, + "requires": { + "aws-sign2": "~0.7.0", + "aws4": "^1.8.0", + "caseless": "~0.12.0", + "combined-stream": "~1.0.6", + "extend": "~3.0.2", + "forever-agent": "~0.6.1", + "form-data": "~2.3.2", + "har-validator": "~5.1.3", + "http-signature": "~1.2.0", + "is-typedarray": "~1.0.0", + "isstream": "~0.1.2", + "json-stringify-safe": "~5.0.1", + "mime-types": "~2.1.19", + "oauth-sign": "~0.9.0", + "performance-now": "^2.1.0", + "qs": "~6.5.2", + "safe-buffer": "^5.1.2", + "tough-cookie": "~2.5.0", + "tunnel-agent": "^0.6.0", + "uuid": "^3.3.2" + } + }, + "require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", + "dev": true + }, + "require-from-string": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", + "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", + "dev": true + }, + "require-main-filename": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", + "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", + "dev": true + }, + "requires-port": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", + "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=", + "dev": true + }, + "resolve": { + "version": "1.19.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.19.0.tgz", + "integrity": "sha512-rArEXAgsBG4UgRGcynxWIWKFvh/XZCcS8UJdHhwy91zwAvCZIbcs+vAbflgBnNjYMs/i/i+/Ux6IZhML1yPvxg==", + "dev": true, + "requires": { + "is-core-module": "^2.1.0", + "path-parse": "^1.0.6" + } + }, + "resolve-cwd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-2.0.0.tgz", + "integrity": "sha1-AKn3OHVW4nA46uIyyqNypqWbZlo=", + "dev": true, + "requires": { + "resolve-from": "^3.0.0" + } + }, + "resolve-from": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-3.0.0.tgz", + "integrity": "sha1-six699nWiBvItuZTM17rywoYh0g=", + "dev": true + }, + "resolve-url": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", + "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=", + "dev": true + }, + "restore-cursor": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", + "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", + "dev": true, + "requires": { + "onetime": "^2.0.0", + "signal-exit": "^3.0.2" + } + }, + "ret": { + "version": "0.1.15", + "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", + "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==", + "dev": true + }, + "retry": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/retry/-/retry-0.12.0.tgz", + "integrity": "sha1-G0KmJmoh8HQh0bC1S33BZ7AcATs=", + "dev": true + }, + "rgb-regex": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/rgb-regex/-/rgb-regex-1.0.1.tgz", + "integrity": "sha1-wODWiC3w4jviVKR16O3UGRX+rrE=", + "dev": true + }, + "rgba-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/rgba-regex/-/rgba-regex-1.0.0.tgz", + "integrity": "sha1-QzdOLiyglosO8VI0YLfXMP8i7rM=", + "dev": true + }, + "rimraf": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", + "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", + "dev": true, + "requires": { + "glob": "^7.1.3" + } + }, + "ripemd160": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.2.tgz", + "integrity": "sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA==", + "dev": true, + "requires": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1" + } + }, + "run-async": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.1.tgz", + "integrity": "sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==", + "dev": true + }, + "run-queue": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/run-queue/-/run-queue-1.0.3.tgz", + "integrity": "sha1-6Eg5bwV9Ij8kOGkkYY4laUFh7Ec=", + "dev": true, + "requires": { + "aproba": "^1.1.1" + } + }, + "rxjs": { + "version": "6.6.7", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.6.7.tgz", + "integrity": "sha512-hTdwr+7yYNIT5n4AMYp85KA6yw2Va0FLa3Rguvbpa4W3I5xynaBZo41cM3XM+4Q6fRMj3sBYIR1VAmZMXYJvRQ==", + "dev": true, + "requires": { + "tslib": "^1.9.0" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "dev": true + }, + "safe-regex": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", + "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", + "dev": true, + "requires": { + "ret": "~0.1.10" + } + }, + "safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "dev": true + }, + "sass": { + "version": "1.35.2", + "resolved": "https://registry.npmjs.org/sass/-/sass-1.35.2.tgz", + "integrity": "sha512-jhO5KAR+AMxCEwIH3v+4zbB2WB0z67V1X0jbapfVwQQdjHZUGUyukpnoM6+iCMfsIUC016w9OPKQ5jrNOS9uXw==", + "dev": true, + "requires": { + "chokidar": ">=3.0.0 <4.0.0" + } + }, + "sass-loader": { + "version": "10.2.0", + "resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-10.2.0.tgz", + "integrity": "sha512-kUceLzC1gIHz0zNJPpqRsJyisWatGYNFRmv2CKZK2/ngMJgLqxTbXwe/hJ85luyvZkgqU3VlJ33UVF2T/0g6mw==", + "dev": true, + "requires": { + "klona": "^2.0.4", + "loader-utils": "^2.0.0", + "neo-async": "^2.6.2", + "schema-utils": "^3.0.0", + "semver": "^7.3.2" + }, + "dependencies": { + "@types/json-schema": { + "version": "7.0.8", + "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.8.tgz", + "integrity": "sha512-YSBPTLTVm2e2OoQIDYx8HaeWJ5tTToLH67kXR7zYNGupXMEHa2++G8k+DczX2cFVgalypqtyZIcU19AFcmOpmg==", + "dev": true + }, + "loader-utils": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.0.tgz", + "integrity": "sha512-rP4F0h2RaWSvPEkD7BLDFQnvSf+nK+wr3ESUjNTyAGobqrijmW92zc+SO6d4p4B1wh7+B/Jg1mkQe5NYUEHtHQ==", + "dev": true, + "requires": { + "big.js": "^5.2.2", + "emojis-list": "^3.0.0", + "json5": "^2.1.2" + } + }, + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + } + }, + "schema-utils": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.1.0.tgz", + "integrity": "sha512-tTEaeYkyIhEZ9uWgAjDerWov3T9MgX8dhhy2r0IGeeX4W8ngtGl1++dUve/RUqzuaASSh7shwCDJjEzthxki8w==", + "dev": true, + "requires": { + "@types/json-schema": "^7.0.7", + "ajv": "^6.12.5", + "ajv-keywords": "^3.5.2" + } + }, + "semver": { + "version": "7.3.5", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", + "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + } + } + }, + "sax": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", + "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==", + "dev": true + }, + "schema-utils": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-2.7.1.tgz", + "integrity": "sha512-SHiNtMOUGWBQJwzISiVYKu82GiV4QYGePp3odlY1tuKO7gPtphAT5R/py0fA6xtbgLL/RvtJZnU9b8s0F1q0Xg==", + "dev": true, + "requires": { + "@types/json-schema": "^7.0.5", + "ajv": "^6.12.4", + "ajv-keywords": "^3.5.2" + } + }, + "select-hose": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz", + "integrity": "sha1-Yl2GWPhlr0Psliv8N2o3NZpJlMo=", + "dev": true + }, + "selfsigned": { + "version": "1.10.11", + "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-1.10.11.tgz", + "integrity": "sha512-aVmbPOfViZqOZPgRBT0+3u4yZFHpmnIghLMlAcb5/xhp5ZtB/RVnKhz5vl2M32CLXAqR4kha9zfhNg0Lf/sxKA==", + "dev": true, + "requires": { + "node-forge": "^0.10.0" + } + }, + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", + "dev": true + }, + "send": { + "version": "0.17.1", + "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", + "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", + "dev": true, + "requires": { + "debug": "2.6.9", + "depd": "~1.1.2", + "destroy": "~1.0.4", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "fresh": "0.5.2", + "http-errors": "~1.7.2", + "mime": "1.6.0", + "ms": "2.1.1", + "on-finished": "~2.3.0", + "range-parser": "~1.2.1", + "statuses": "~1.5.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + }, + "dependencies": { + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + } + } + }, + "mime": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", + "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", + "dev": true + }, + "ms": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", + "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", + "dev": true + } + } + }, + "serialize-javascript": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-4.0.0.tgz", + "integrity": "sha512-GaNA54380uFefWghODBWEGisLZFj00nS5ACs6yHa9nLqlLpVLO8ChDGeKRjZnV4Nh4n0Qi7nhYZD/9fCPzEqkw==", + "dev": true, + "requires": { + "randombytes": "^2.1.0" + } + }, + "serve-index": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/serve-index/-/serve-index-1.9.1.tgz", + "integrity": "sha1-03aNabHn2C5c4FD/9bRTvqEqkjk=", + "dev": true, + "requires": { + "accepts": "~1.3.4", + "batch": "0.6.1", + "debug": "2.6.9", + "escape-html": "~1.0.3", + "http-errors": "~1.6.2", + "mime-types": "~2.1.17", + "parseurl": "~1.3.2" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "http-errors": { + "version": "1.6.3", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", + "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", + "dev": true, + "requires": { + "depd": "~1.1.2", + "inherits": "2.0.3", + "setprototypeof": "1.1.0", + "statuses": ">= 1.4.0 < 2" + } + }, + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", + "dev": true + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + }, + "setprototypeof": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", + "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==", + "dev": true + } + } + }, + "serve-static": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", + "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", + "dev": true, + "requires": { + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "parseurl": "~1.3.3", + "send": "0.17.1" + } + }, + "set-blocking": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", + "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", + "dev": true + }, + "set-value": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.1.tgz", + "integrity": "sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw==", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-extendable": "^0.1.1", + "is-plain-object": "^2.0.3", + "split-string": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "setimmediate": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", + "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=", + "dev": true + }, + "setprototypeof": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", + "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==", + "dev": true + }, + "sha.js": { + "version": "2.4.11", + "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz", + "integrity": "sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ==", + "dev": true, + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", + "dev": true, + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", + "dev": true + }, + "shell-quote": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.7.2.tgz", + "integrity": "sha512-mRz/m/JVscCrkMyPqHc/bczi3OQHkLTqXHEFu0zDhK/qfv3UcOA4SVmRCLmos4bhjr9ekVQubj/R7waKapmiQg==", + "dev": true + }, + "signal-exit": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", + "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", + "dev": true + }, + "simple-swizzle": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/simple-swizzle/-/simple-swizzle-0.2.2.tgz", + "integrity": "sha1-pNprY1/8zMoz9w0Xy5JZLeleVXo=", + "dev": true, + "requires": { + "is-arrayish": "^0.3.1" + }, + "dependencies": { + "is-arrayish": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.3.2.tgz", + "integrity": "sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==", + "dev": true + } + } + }, + "slash": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-2.0.0.tgz", + "integrity": "sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A==", + "dev": true + }, + "slice-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", + "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", + "dev": true, + "requires": { + "ansi-styles": "^4.0.0", + "astral-regex": "^2.0.0", + "is-fullwidth-code-point": "^3.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + } + } + }, + "snapdragon": { + "version": "0.8.2", + "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", + "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", + "dev": true, + "requires": { + "base": "^0.11.1", + "debug": "^2.2.0", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "map-cache": "^0.2.2", + "source-map": "^0.5.6", + "source-map-resolve": "^0.5.0", + "use": "^3.1.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + } + } + }, + "snapdragon-node": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", + "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", + "dev": true, + "requires": { + "define-property": "^1.0.0", + "isobject": "^3.0.0", + "snapdragon-util": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "snapdragon-util": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", + "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", + "dev": true, + "requires": { + "kind-of": "^3.2.0" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "sockjs": { + "version": "0.3.21", + "resolved": "https://registry.npmjs.org/sockjs/-/sockjs-0.3.21.tgz", + "integrity": "sha512-DhbPFGpxjc6Z3I+uX07Id5ZO2XwYsWOrYjaSeieES78cq+JaJvVe5q/m1uvjIQhXinhIeCFRH6JgXe+mvVMyXw==", + "dev": true, + "requires": { + "faye-websocket": "^0.11.3", + "uuid": "^3.4.0", + "websocket-driver": "^0.7.4" + } + }, + "sockjs-client": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/sockjs-client/-/sockjs-client-1.5.1.tgz", + "integrity": "sha512-VnVAb663fosipI/m6pqRXakEOw7nvd7TUgdr3PlR/8V2I95QIdwT8L4nMxhyU8SmDBHYXU1TOElaKOmKLfYzeQ==", + "dev": true, + "requires": { + "debug": "^3.2.6", + "eventsource": "^1.0.7", + "faye-websocket": "^0.11.3", + "inherits": "^2.0.4", + "json3": "^3.3.3", + "url-parse": "^1.5.1" + }, + "dependencies": { + "debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "sort-keys": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/sort-keys/-/sort-keys-1.1.2.tgz", + "integrity": "sha1-RBttTTRnmPG05J6JIK37oOVD+a0=", + "dev": true, + "requires": { + "is-plain-obj": "^1.0.0" + }, + "dependencies": { + "is-plain-obj": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", + "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=", + "dev": true + } + } + }, + "source-list-map": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/source-list-map/-/source-list-map-2.0.1.tgz", + "integrity": "sha512-qnQ7gVMxGNxsiL4lEuJwe/To8UnK7fAnmbGEEH8RpLouuKbeEm0lhbQVFIrNSuB+G7tVrAlVsZgETT5nljf+Iw==", + "dev": true + }, + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", + "dev": true + }, + "source-map-resolve": { + "version": "0.5.3", + "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.3.tgz", + "integrity": "sha512-Htz+RnsXWk5+P2slx5Jh3Q66vhQj1Cllm0zvnaY98+NFx+Dv2CF/f5O/t8x+KaNdrdIAsruNzoh/KpialbqAnw==", + "dev": true, + "requires": { + "atob": "^2.1.2", + "decode-uri-component": "^0.2.0", + "resolve-url": "^0.2.1", + "source-map-url": "^0.4.0", + "urix": "^0.1.0" + } + }, + "source-map-support": { + "version": "0.5.19", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.19.tgz", + "integrity": "sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "source-map-url": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz", + "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=", + "dev": true + }, + "spdx-correct": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", + "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", + "dev": true, + "requires": { + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-exceptions": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", + "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", + "dev": true + }, + "spdx-expression-parse": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", + "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", + "dev": true, + "requires": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-license-ids": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.7.tgz", + "integrity": "sha512-U+MTEOO0AiDzxwFvoa4JVnMV6mZlJKk2sBLt90s7G0Gd0Mlknc7kxEn3nuDPNZRta7O2uy8oLcZLVT+4sqNZHQ==", + "dev": true + }, + "spdy": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/spdy/-/spdy-4.0.2.tgz", + "integrity": "sha512-r46gZQZQV+Kl9oItvl1JZZqJKGr+oEkB08A6BzkiR7593/7IbtuncXHd2YoYeTsG4157ZssMu9KYvUHLcjcDoA==", + "dev": true, + "requires": { + "debug": "^4.1.0", + "handle-thing": "^2.0.0", + "http-deceiver": "^1.2.7", + "select-hose": "^2.0.0", + "spdy-transport": "^3.0.0" + } + }, + "spdy-transport": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/spdy-transport/-/spdy-transport-3.0.0.tgz", + "integrity": "sha512-hsLVFE5SjA6TCisWeJXFKniGGOpBgMLmerfO2aCyCU5s7nJ/rpAepqmFifv/GCbSbueEeAJJnmSQ2rKC/g8Fcw==", + "dev": true, + "requires": { + "debug": "^4.1.0", + "detect-node": "^2.0.4", + "hpack.js": "^2.1.6", + "obuf": "^1.1.2", + "readable-stream": "^3.0.6", + "wbuf": "^1.7.3" + }, + "dependencies": { + "readable-stream": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", + "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", + "dev": true, + "requires": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + } + } + } + }, + "split-string": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", + "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", + "dev": true, + "requires": { + "extend-shallow": "^3.0.0" + } + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", + "dev": true + }, + "sshpk": { + "version": "1.16.1", + "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", + "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", + "dev": true, + "requires": { + "asn1": "~0.2.3", + "assert-plus": "^1.0.0", + "bcrypt-pbkdf": "^1.0.0", + "dashdash": "^1.12.0", + "ecc-jsbn": "~0.1.1", + "getpass": "^0.1.1", + "jsbn": "~0.1.0", + "safer-buffer": "^2.0.2", + "tweetnacl": "~0.14.0" + } + }, + "ssri": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/ssri/-/ssri-6.0.1.tgz", + "integrity": "sha512-3Wge10hNcT1Kur4PDFwEieXSCMCJs/7WvSACcrMYrNp+b8kDL1/0wJch5Ni2WrtwEa2IO8OsVfeKIciKCDx/QA==", + "dev": true, + "requires": { + "figgy-pudding": "^3.5.1" + } + }, + "stable": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/stable/-/stable-0.1.8.tgz", + "integrity": "sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w==", + "dev": true + }, + "stackframe": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/stackframe/-/stackframe-1.2.0.tgz", + "integrity": "sha512-GrdeshiRmS1YLMYgzF16olf2jJ/IzxXY9lhKOskuVziubpTYcYqyOwYeJKzQkwy7uN0fYSsbsC4RQaXf9LCrYA==", + "dev": true + }, + "static-extend": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", + "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", + "dev": true, + "requires": { + "define-property": "^0.2.5", + "object-copy": "^0.1.0" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "statuses": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", + "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", + "dev": true + }, + "stream-browserify": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.2.tgz", + "integrity": "sha512-nX6hmklHs/gr2FuxYDltq8fJA1GDlxKQCz8O/IM4atRqBH8OORmBNgfvW5gG10GT/qQ9u0CzIvr2X5Pkt6ntqg==", + "dev": true, + "requires": { + "inherits": "~2.0.1", + "readable-stream": "^2.0.2" + } + }, + "stream-each": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/stream-each/-/stream-each-1.2.3.tgz", + "integrity": "sha512-vlMC2f8I2u/bZGqkdfLQW/13Zihpej/7PmSiMQsbYddxuTsJp8vRe2x2FvVExZg7FaOds43ROAuFJwPR4MTZLw==", + "dev": true, + "requires": { + "end-of-stream": "^1.1.0", + "stream-shift": "^1.0.0" + } + }, + "stream-http": { + "version": "2.8.3", + "resolved": "https://registry.npmjs.org/stream-http/-/stream-http-2.8.3.tgz", + "integrity": "sha512-+TSkfINHDo4J+ZobQLWiMouQYB+UVYFttRA94FpEzzJ7ZdqcL4uUUQ7WkdkI4DSozGmgBUE/a47L+38PenXhUw==", + "dev": true, + "requires": { + "builtin-status-codes": "^3.0.0", + "inherits": "^2.0.1", + "readable-stream": "^2.3.6", + "to-arraybuffer": "^1.0.0", + "xtend": "^4.0.0" + } + }, + "stream-shift": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.1.tgz", + "integrity": "sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ==", + "dev": true + }, + "strict-uri-encode": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz", + "integrity": "sha1-J5siXfHVgrH1TmWt3UNS4Y+qBxM=", + "dev": true + }, + "string-width": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", + "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", + "dev": true, + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.0" + } + }, + "string.prototype.trimend": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.4.tgz", + "integrity": "sha512-y9xCjw1P23Awk8EvTpcyL2NIr1j7wJ39f+k6lvRnSMz+mz9CGz9NYPelDk42kOz6+ql8xjfK8oYzy3jAP5QU5A==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3" + }, + "dependencies": { + "call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + } + }, + "get-intrinsic": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", + "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + } + } + } + }, + "string.prototype.trimstart": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.4.tgz", + "integrity": "sha512-jh6e984OBfvxS50tdY2nRZnoC5/mLFKOREQfw8t5yytkoUsJRNxvI/E39qu1sD0OtWI3OC0XgKSmcWwziwYuZw==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3" + }, + "dependencies": { + "call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + } + }, + "get-intrinsic": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", + "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + } + } + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "dev": true, + "requires": { + "safe-buffer": "~5.1.0" + } + }, + "strip-ansi": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", + "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", + "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", + "dev": true + } + } + }, + "strip-eof": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", + "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", + "dev": true + }, + "strip-final-newline": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", + "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", + "dev": true + }, + "strip-indent": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-2.0.0.tgz", + "integrity": "sha1-XvjbKV0B5u1sv3qrlpmNeCJSe2g=", + "dev": true + }, + "strip-json-comments": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", + "dev": true + }, + "stylehacks": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/stylehacks/-/stylehacks-4.0.3.tgz", + "integrity": "sha512-7GlLk9JwlElY4Y6a/rmbH2MhVlTyVmiJd1PfTCqFaIBEGMYNsrO/v3SeGTdhBThLg4Z+NbOk/qFMwCa+J+3p/g==", + "dev": true, + "requires": { + "browserslist": "^4.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0" + }, + "dependencies": { + "postcss-selector-parser": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-3.1.2.tgz", + "integrity": "sha512-h7fJ/5uWuRVyOtkO45pnt1Ih40CEleeyCHzipqAZO2e5H20g25Y48uYnFUiShvY4rZWNJ/Bib/KVPmanaCtOhA==", + "dev": true, + "requires": { + "dot-prop": "^5.2.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "svg-tags": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/svg-tags/-/svg-tags-1.0.0.tgz", + "integrity": "sha1-WPcc7jvVGbWdSyqEO2x95krAR2Q=", + "dev": true + }, + "svgo": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/svgo/-/svgo-1.3.2.tgz", + "integrity": "sha512-yhy/sQYxR5BkC98CY7o31VGsg014AKLEPxdfhora76l36hD9Rdy5NZA/Ocn6yayNPgSamYdtX2rFJdcv07AYVw==", + "dev": true, + "requires": { + "chalk": "^2.4.1", + "coa": "^2.0.2", + "css-select": "^2.0.0", + "css-select-base-adapter": "^0.1.1", + "css-tree": "1.0.0-alpha.37", + "csso": "^4.0.2", + "js-yaml": "^3.13.1", + "mkdirp": "~0.5.1", + "object.values": "^1.1.0", + "sax": "~1.2.4", + "stable": "^0.1.8", + "unquote": "~1.1.1", + "util.promisify": "~1.0.0" + } + }, + "table": { + "version": "6.7.1", + "resolved": "https://registry.npmjs.org/table/-/table-6.7.1.tgz", + "integrity": "sha512-ZGum47Yi6KOOFDE8m223td53ath2enHcYLgOCjGr5ngu8bdIARQk6mN/wRMv4yMRcHnCSnHbCEha4sobQx5yWg==", + "dev": true, + "requires": { + "ajv": "^8.0.1", + "lodash.clonedeep": "^4.5.0", + "lodash.truncate": "^4.4.2", + "slice-ansi": "^4.0.0", + "string-width": "^4.2.0", + "strip-ansi": "^6.0.0" + }, + "dependencies": { + "ajv": { + "version": "8.6.2", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.6.2.tgz", + "integrity": "sha512-9807RlWAgT564wT+DjeyU5OFMPjmzxVobvDFmNAhY+5zD6A2ly3jDp6sgnfyDtlIQ+7H97oc/DGCzzfu9rjw9w==", + "dev": true, + "requires": { + "fast-deep-equal": "^3.1.1", + "json-schema-traverse": "^1.0.0", + "require-from-string": "^2.0.2", + "uri-js": "^4.2.2" + } + }, + "json-schema-traverse": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", + "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", + "dev": true + } + } + }, + "tapable": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/tapable/-/tapable-1.1.3.tgz", + "integrity": "sha512-4WK/bYZmj8xLr+HUCODHGF1ZFzsYffasLUgEiMBY4fgtltdO6B4WJtlSbPaDTLpYTcGVwM2qLnFTICEcNxs3kA==", + "dev": true + }, + "terser": { + "version": "4.8.0", + "resolved": "https://registry.npmjs.org/terser/-/terser-4.8.0.tgz", + "integrity": "sha512-EAPipTNeWsb/3wLPeup1tVPaXfIaU68xMnVdPafIL1TV05OhASArYyIfFvnvJCNrR2NIOvDVNNTFRa+Re2MWyw==", + "dev": true, + "requires": { + "commander": "^2.20.0", + "source-map": "~0.6.1", + "source-map-support": "~0.5.12" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "terser-webpack-plugin": { + "version": "1.4.5", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-1.4.5.tgz", + "integrity": "sha512-04Rfe496lN8EYruwi6oPQkG0vo8C+HT49X687FZnpPF0qMAIHONI6HEXYPKDOE8e5HjXTyKfqRd/agHtH0kOtw==", + "dev": true, + "requires": { + "cacache": "^12.0.2", + "find-cache-dir": "^2.1.0", + "is-wsl": "^1.1.0", + "schema-utils": "^1.0.0", + "serialize-javascript": "^4.0.0", + "source-map": "^0.6.1", + "terser": "^4.1.2", + "webpack-sources": "^1.4.0", + "worker-farm": "^1.7.0" + }, + "dependencies": { + "find-cache-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", + "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", + "dev": true, + "requires": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + } + }, + "find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "requires": { + "locate-path": "^3.0.0" + } + }, + "locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "dev": true, + "requires": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + } + }, + "make-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", + "dev": true, + "requires": { + "pify": "^4.0.1", + "semver": "^5.6.0" + } + }, + "p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "dev": true, + "requires": { + "p-limit": "^2.0.0" + } + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + }, + "pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", + "dev": true, + "requires": { + "find-up": "^3.0.0" + } + }, + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", + "dev": true + }, + "thenify": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz", + "integrity": "sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw==", + "dev": true, + "requires": { + "any-promise": "^1.0.0" + } + }, + "thenify-all": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/thenify-all/-/thenify-all-1.6.0.tgz", + "integrity": "sha1-GhkY1ALY/D+Y+/I02wvMjMEOlyY=", + "dev": true, + "requires": { + "thenify": ">= 3.1.0 < 4" + } + }, + "thread-loader": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/thread-loader/-/thread-loader-2.1.3.tgz", + "integrity": "sha512-wNrVKH2Lcf8ZrWxDF/khdlLlsTMczdcwPA9VEK4c2exlEPynYWxi9op3nPTo5lAnDIkE0rQEB3VBP+4Zncc9Hg==", + "dev": true, + "requires": { + "loader-runner": "^2.3.1", + "loader-utils": "^1.1.0", + "neo-async": "^2.6.0" + } + }, + "through": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", + "dev": true + }, + "through2": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", + "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==", + "dev": true, + "requires": { + "readable-stream": "~2.3.6", + "xtend": "~4.0.1" + } + }, + "thunky": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/thunky/-/thunky-1.1.0.tgz", + "integrity": "sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==", + "dev": true + }, + "timers-browserify": { + "version": "2.0.12", + "resolved": "https://registry.npmjs.org/timers-browserify/-/timers-browserify-2.0.12.tgz", + "integrity": "sha512-9phl76Cqm6FhSX9Xe1ZUAMLtm1BLkKj2Qd5ApyWkXzsMRaA7dgr81kf4wJmQf/hAvg8EEyJxDo3du/0KlhPiKQ==", + "dev": true, + "requires": { + "setimmediate": "^1.0.4" + } + }, + "timsort": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/timsort/-/timsort-0.3.0.tgz", + "integrity": "sha1-QFQRqOfmM5/mTbmiNN4R3DHgK9Q=", + "dev": true + }, + "tmp": { + "version": "0.0.33", + "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", + "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", + "dev": true, + "requires": { + "os-tmpdir": "~1.0.2" + } + }, + "to-arraybuffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz", + "integrity": "sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M=", + "dev": true + }, + "to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", + "dev": true + }, + "to-object-path": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", + "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "to-regex": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", + "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", + "dev": true, + "requires": { + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "regex-not": "^1.0.2", + "safe-regex": "^1.1.0" + } + }, + "to-regex-range": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", + "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", + "dev": true, + "requires": { + "is-number": "^3.0.0", + "repeat-string": "^1.6.1" + } + }, + "toidentifier": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", + "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", + "dev": true + }, + "toposort": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/toposort/-/toposort-1.0.7.tgz", + "integrity": "sha1-LmhELZ9k7HILjMieZEOsbKqVACk=", + "dev": true + }, + "tough-cookie": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", + "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", + "dev": true, + "requires": { + "psl": "^1.1.28", + "punycode": "^2.1.1" + } + }, + "tryer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/tryer/-/tryer-1.0.1.tgz", + "integrity": "sha512-c3zayb8/kWWpycWYg87P71E1S1ZL6b6IJxfb5fvsUgsf0S2MVGaDhDXXjDMpdCpfWXqptc+4mXwmiy1ypXqRAA==", + "dev": true + }, + "ts-pnp": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/ts-pnp/-/ts-pnp-1.2.0.tgz", + "integrity": "sha512-csd+vJOb/gkzvcCHgTGSChYpy5f1/XKNsmvBGO4JXS+z1v2HobugDz4s1IeFXM3wZB44uczs+eazB5Q/ccdhQw==", + "dev": true + }, + "tslib": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", + "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", + "dev": true + }, + "tty-browserify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/tty-browserify/-/tty-browserify-0.0.0.tgz", + "integrity": "sha1-oVe6QC2iTpv5V/mqadUk7tQpAaY=", + "dev": true + }, + "tunnel-agent": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", + "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", + "dev": true, + "requires": { + "safe-buffer": "^5.0.1" + } + }, + "tweetnacl": { + "version": "0.14.5", + "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", + "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", + "dev": true + }, + "type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1" + } + }, + "type-fest": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.6.0.tgz", + "integrity": "sha512-q+MB8nYR1KDLrgr4G5yemftpMC7/QLqVndBmEEdqzmNj5dcFOO4Oo8qlwZE3ULT3+Zim1F8Kq4cBnikNhlCMlg==", + "dev": true + }, + "type-is": { + "version": "1.6.18", + "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", + "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", + "dev": true, + "requires": { + "media-typer": "0.3.0", + "mime-types": "~2.1.24" + } + }, + "typedarray": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", + "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", + "dev": true + }, + "uglify-js": { + "version": "3.4.10", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.4.10.tgz", + "integrity": "sha512-Y2VsbPVs0FIshJztycsO2SfPk7/KAF/T72qzv9u5EpQ4kB2hQoHlhNQTsNyy6ul7lQtqJN/AoWeS23OzEiEFxw==", + "dev": true, + "requires": { + "commander": "~2.19.0", + "source-map": "~0.6.1" + }, + "dependencies": { + "commander": { + "version": "2.19.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.19.0.tgz", + "integrity": "sha512-6tvAOO+D6OENvRAh524Dh9jcfKTYDQAqvqezbCW82xj5X0pSrcpxtvRKHLG0yBY6SD7PSDrJaj+0AiOcKVd1Xg==", + "dev": true + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "unbox-primitive": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.1.tgz", + "integrity": "sha512-tZU/3NqK3dA5gpE1KtyiJUrEB0lxnGkMFHptJ7q6ewdZ8s12QrODwNbhIJStmJkd1QDXa1NRA8aF2A1zk/Ypyw==", + "dev": true, + "requires": { + "function-bind": "^1.1.1", + "has-bigints": "^1.0.1", + "has-symbols": "^1.0.2", + "which-boxed-primitive": "^1.0.2" + }, + "dependencies": { + "has-symbols": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", + "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", + "dev": true + } + } + }, + "unicode-canonical-property-names-ecmascript": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-1.0.4.tgz", + "integrity": "sha512-jDrNnXWHd4oHiTZnx/ZG7gtUTVp+gCcTTKr8L0HjlwphROEW3+Him+IpvC+xcJEFegapiMZyZe02CyuOnRmbnQ==", + "dev": true + }, + "unicode-match-property-ecmascript": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-1.0.4.tgz", + "integrity": "sha512-L4Qoh15vTfntsn4P1zqnHulG0LdXgjSO035fEpdtp6YxXhMT51Q6vgM5lYdG/5X3MjS+k/Y9Xw4SFCY9IkR0rg==", + "dev": true, + "requires": { + "unicode-canonical-property-names-ecmascript": "^1.0.4", + "unicode-property-aliases-ecmascript": "^1.0.4" + } + }, + "unicode-match-property-value-ecmascript": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-1.2.0.tgz", + "integrity": "sha512-wjuQHGQVofmSJv1uVISKLE5zO2rNGzM/KCYZch/QQvez7C1hUhBIuZ701fYXExuufJFMPhv2SyL8CyoIfMLbIQ==", + "dev": true + }, + "unicode-property-aliases-ecmascript": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-1.1.0.tgz", + "integrity": "sha512-PqSoPh/pWetQ2phoj5RLiaqIk4kCNwoV3CI+LfGmWLKI3rE3kl1h59XpX2BjgDrmbxD9ARtQobPGU1SguCYuQg==", + "dev": true + }, + "union-value": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz", + "integrity": "sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg==", + "dev": true, + "requires": { + "arr-union": "^3.1.0", + "get-value": "^2.0.6", + "is-extendable": "^0.1.1", + "set-value": "^2.0.1" + } + }, + "uniq": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/uniq/-/uniq-1.0.1.tgz", + "integrity": "sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8=", + "dev": true + }, + "uniqs": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/uniqs/-/uniqs-2.0.0.tgz", + "integrity": "sha1-/+3ks2slKQaW5uFl1KWe25mOawI=", + "dev": true + }, + "unique-filename": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-1.1.1.tgz", + "integrity": "sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ==", + "dev": true, + "requires": { + "unique-slug": "^2.0.0" + } + }, + "unique-slug": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/unique-slug/-/unique-slug-2.0.2.tgz", + "integrity": "sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w==", + "dev": true, + "requires": { + "imurmurhash": "^0.1.4" + } + }, + "universalify": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", + "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", + "dev": true + }, + "unpipe": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", + "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", + "dev": true + }, + "unquote": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/unquote/-/unquote-1.1.1.tgz", + "integrity": "sha1-j97XMk7G6IoP+LkF58CYzcCG1UQ=", + "dev": true + }, + "unset-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", + "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", + "dev": true, + "requires": { + "has-value": "^0.3.1", + "isobject": "^3.0.0" + }, + "dependencies": { + "has-value": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", + "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", + "dev": true, + "requires": { + "get-value": "^2.0.3", + "has-values": "^0.1.4", + "isobject": "^2.0.0" + }, + "dependencies": { + "isobject": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", + "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", + "dev": true, + "requires": { + "isarray": "1.0.0" + } + } + } + }, + "has-values": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", + "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", + "dev": true + } + } + }, + "upath": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/upath/-/upath-1.2.0.tgz", + "integrity": "sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg==", + "dev": true + }, + "upper-case": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/upper-case/-/upper-case-1.1.3.tgz", + "integrity": "sha1-9rRQHC7EzdJrp4vnIilh3ndiFZg=", + "dev": true + }, + "uri-js": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.0.tgz", + "integrity": "sha512-B0yRTzYdUCCn9n+F4+Gh4yIDtMQcaJsmYBDsTSG8g/OejKBodLQ2IHfN3bM7jUsRXndopT7OIXWdYqc1fjmV6g==", + "dev": true, + "requires": { + "punycode": "^2.1.0" + } + }, + "urix": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", + "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=", + "dev": true + }, + "url": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", + "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", + "dev": true, + "requires": { + "punycode": "1.3.2", + "querystring": "0.2.0" + }, + "dependencies": { + "punycode": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", + "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=", + "dev": true + } + } + }, + "url-loader": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/url-loader/-/url-loader-2.3.0.tgz", + "integrity": "sha512-goSdg8VY+7nPZKUEChZSEtW5gjbS66USIGCeSJ1OVOJ7Yfuh/36YxCwMi5HVEJh6mqUYOoy3NJ0vlOMrWsSHog==", + "dev": true, + "requires": { + "loader-utils": "^1.2.3", + "mime": "^2.4.4", + "schema-utils": "^2.5.0" + } + }, + "url-parse": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.1.tgz", + "integrity": "sha512-HOfCOUJt7iSYzEx/UqgtwKRMC6EU91NFhsCHMv9oM03VJcVo2Qrp8T8kI9D7amFf1cu+/3CEhgb3rF9zL7k85Q==", + "dev": true, + "requires": { + "querystringify": "^2.1.1", + "requires-port": "^1.0.0" + } + }, + "use": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", + "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==", + "dev": true + }, + "util": { + "version": "0.11.1", + "resolved": "https://registry.npmjs.org/util/-/util-0.11.1.tgz", + "integrity": "sha512-HShAsny+zS2TZfaXxD9tYj4HQGlBezXZMZuM/S5PKLLoZkShZiGk9o5CzukI1LVHZvjdvZ2Sj1aW/Ndn2NB/HQ==", + "dev": true, + "requires": { + "inherits": "2.0.3" + }, + "dependencies": { + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", + "dev": true + } + } + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", + "dev": true + }, + "util.promisify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/util.promisify/-/util.promisify-1.0.1.tgz", + "integrity": "sha512-g9JpC/3He3bm38zsLupWryXHoEcS22YHthuPQSJdMy6KNrzIRzWqcsHzD/WUnqe45whVou4VIsPew37DoXWNrA==", + "dev": true, + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.2", + "has-symbols": "^1.0.1", + "object.getownpropertydescriptors": "^2.1.0" + } + }, + "utila": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/utila/-/utila-0.4.0.tgz", + "integrity": "sha1-ihagXURWV6Oupe7MWxKk+lN5dyw=", + "dev": true + }, + "utils-merge": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", + "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", + "dev": true + }, + "uuid": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", + "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", + "dev": true + }, + "v8-compile-cache": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", + "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", + "dev": true + }, + "validate-npm-package-license": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", + "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", + "dev": true, + "requires": { + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" + } + }, + "vary": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", + "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", + "dev": true + }, + "vendors": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/vendors/-/vendors-1.0.4.tgz", + "integrity": "sha512-/juG65kTL4Cy2su4P8HjtkTxk6VmJDiOPBufWniqQ6wknac6jNiXS9vU+hO3wgusiyqWlzTbVHi0dyJqRONg3w==", + "dev": true + }, + "verror": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", + "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", + "dev": true, + "requires": { + "assert-plus": "^1.0.0", + "core-util-is": "1.0.2", + "extsprintf": "^1.2.0" + } + }, + "vm-browserify": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vm-browserify/-/vm-browserify-1.1.2.tgz", + "integrity": "sha512-2ham8XPWTONajOR0ohOKOHXkm3+gaBmGut3SRuu75xLd/RRaY6vqgh8NBYYk7+RW3u5AtzPQZG8F10LHkl0lAQ==", + "dev": true + }, + "vue": { + "version": "2.6.14", + "resolved": "https://registry.npmjs.org/vue/-/vue-2.6.14.tgz", + "integrity": "sha512-x2284lgYvjOMj3Za7kqzRcUSxBboHqtgRE2zlos1qWaOye5yUmHn42LB1250NJBLRwEcdrB0JRwyPTEPhfQjiQ==" + }, + "vue-eslint-parser": { + "version": "7.9.0", + "resolved": "https://registry.npmjs.org/vue-eslint-parser/-/vue-eslint-parser-7.9.0.tgz", + "integrity": "sha512-QBlhZ5LteDRVy2dISfQhNEmmcqph+GTaD4SH41bYzXcVHFPJ9p34zCG6QAqOZVa8PKaVgbomFnoZpGJRZi14vg==", + "dev": true, + "requires": { + "debug": "^4.1.1", + "eslint-scope": "^5.1.1", + "eslint-visitor-keys": "^1.1.0", + "espree": "^6.2.1", + "esquery": "^1.4.0", + "lodash": "^4.17.21", + "semver": "^6.3.0" + }, + "dependencies": { + "acorn": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", + "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", + "dev": true + }, + "eslint-scope": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", + "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", + "dev": true, + "requires": { + "esrecurse": "^4.3.0", + "estraverse": "^4.1.1" + } + }, + "espree": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-6.2.1.tgz", + "integrity": "sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==", + "dev": true, + "requires": { + "acorn": "^7.1.1", + "acorn-jsx": "^5.2.0", + "eslint-visitor-keys": "^1.1.0" + } + }, + "lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "dev": true + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "vue-functional-data-merge": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/vue-functional-data-merge/-/vue-functional-data-merge-3.1.0.tgz", + "integrity": "sha512-leT4kdJVQyeZNY1kmnS1xiUlQ9z1B/kdBFCILIjYYQDqZgLqCLa0UhjSSeRX6c3mUe6U5qYeM8LrEqkHJ1B4LA==" + }, + "vue-hot-reload-api": { + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/vue-hot-reload-api/-/vue-hot-reload-api-2.3.4.tgz", + "integrity": "sha512-BXq3jwIagosjgNVae6tkHzzIk6a8MHFtzAdwhnV5VlvPTFxDCvIttgSiHWjdGoTJvXtmRu5HacExfdarRcFhog==", + "dev": true + }, + "vue-loader": { + "version": "15.9.7", + "resolved": "https://registry.npmjs.org/vue-loader/-/vue-loader-15.9.7.tgz", + "integrity": "sha512-qzlsbLV1HKEMf19IqCJqdNvFJRCI58WNbS6XbPqK13MrLz65es75w392MSQ5TsARAfIjUw+ATm3vlCXUJSOH9Q==", + "dev": true, + "requires": { + "@vue/component-compiler-utils": "^3.1.0", + "hash-sum": "^1.0.2", + "loader-utils": "^1.1.0", + "vue-hot-reload-api": "^2.3.0", + "vue-style-loader": "^4.1.0" + }, + "dependencies": { + "hash-sum": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/hash-sum/-/hash-sum-1.0.2.tgz", + "integrity": "sha1-M7QHd3VMZDJXPBIMw4CLvRDUfwQ=", + "dev": true + } + } + }, + "vue-loader-v16": { + "version": "npm:vue-loader@16.3.1", + "resolved": "https://registry.npmjs.org/vue-loader/-/vue-loader-16.3.1.tgz", + "integrity": "sha512-QTtXgdqQ+4G3d8dmhnnfJSiKKHQtp53XiivSYAvAqNCOufL9aK0DYOc9MW9MSy7Xzj/1qdcghb28zKhOPvQYqQ==", + "dev": true, + "optional": true, + "requires": { + "chalk": "^4.1.0", + "hash-sum": "^2.0.0", + "loader-utils": "^2.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "optional": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz", + "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==", + "dev": true, + "optional": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "optional": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true, + "optional": true + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "optional": true + }, + "loader-utils": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.0.tgz", + "integrity": "sha512-rP4F0h2RaWSvPEkD7BLDFQnvSf+nK+wr3ESUjNTyAGobqrijmW92zc+SO6d4p4B1wh7+B/Jg1mkQe5NYUEHtHQ==", + "dev": true, + "optional": true, + "requires": { + "big.js": "^5.2.2", + "emojis-list": "^3.0.0", + "json5": "^2.1.2" + } + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "optional": true, + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, + "vue-moment": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/vue-moment/-/vue-moment-4.1.0.tgz", + "integrity": "sha512-Gzisqpg82ItlrUyiD9d0Kfru+JorW2o4mQOH06lEDZNgxci0tv/fua1Hl0bo4DozDV2JK1r52Atn/8QVCu8qQw==", + "requires": { + "moment": "^2.19.2" + } + }, + "vue-router": { + "version": "3.5.2", + "resolved": "https://registry.npmjs.org/vue-router/-/vue-router-3.5.2.tgz", + "integrity": "sha512-807gn82hTnjCYGrnF3eNmIw/dk7/GE4B5h69BlyCK9KHASwSloD1Sjcn06zg9fVG4fYH2DrsNBZkpLtb25WtaQ==" + }, + "vue-style-loader": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/vue-style-loader/-/vue-style-loader-4.1.3.tgz", + "integrity": "sha512-sFuh0xfbtpRlKfm39ss/ikqs9AbKCoXZBpHeVZ8Tx650o0k0q/YCM7FRvigtxpACezfq6af+a7JeqVTWvncqDg==", + "dev": true, + "requires": { + "hash-sum": "^1.0.2", + "loader-utils": "^1.0.2" + }, + "dependencies": { + "hash-sum": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/hash-sum/-/hash-sum-1.0.2.tgz", + "integrity": "sha1-M7QHd3VMZDJXPBIMw4CLvRDUfwQ=", + "dev": true + } + } + }, + "vue-template-compiler": { + "version": "2.6.14", + "resolved": "https://registry.npmjs.org/vue-template-compiler/-/vue-template-compiler-2.6.14.tgz", + "integrity": "sha512-ODQS1SyMbjKoO1JBJZojSw6FE4qnh9rIpUZn2EUT86FKizx9uH5z6uXiIrm4/Nb/gwxTi/o17ZDEGWAXHvtC7g==", + "dev": true, + "requires": { + "de-indent": "^1.0.2", + "he": "^1.1.0" + } + }, + "vue-template-es2015-compiler": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/vue-template-es2015-compiler/-/vue-template-es2015-compiler-1.9.1.tgz", + "integrity": "sha512-4gDntzrifFnCEvyoO8PqyJDmguXgVPxKiIxrBKjIowvL9l+N66196+72XVYR8BBf1Uv1Fgt3bGevJ+sEmxfZzw==", + "dev": true + }, + "vuex": { + "version": "3.6.2", + "resolved": "https://registry.npmjs.org/vuex/-/vuex-3.6.2.tgz", + "integrity": "sha512-ETW44IqCgBpVomy520DT5jf8n0zoCac+sxWnn+hMe/CzaSejb/eVw2YToiXYX+Ex/AuHHia28vWTq4goAexFbw==" + }, + "watchpack": { + "version": "1.7.5", + "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-1.7.5.tgz", + "integrity": "sha512-9P3MWk6SrKjHsGkLT2KHXdQ/9SNkyoJbabxnKOoJepsvJjJG8uYTR3yTPxPQvNDI3w4Nz1xnE0TLHK4RIVe/MQ==", + "dev": true, + "requires": { + "chokidar": "^3.4.1", + "graceful-fs": "^4.1.2", + "neo-async": "^2.5.0", + "watchpack-chokidar2": "^2.0.1" + } + }, + "watchpack-chokidar2": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/watchpack-chokidar2/-/watchpack-chokidar2-2.0.1.tgz", + "integrity": "sha512-nCFfBIPKr5Sh61s4LPpy1Wtfi0HE8isJ3d2Yb5/Ppw2P2B/3eVSEBjKfN0fmHJSK14+31KwMKmcrzs2GM4P0Ww==", + "dev": true, + "optional": true, + "requires": { + "chokidar": "^2.1.8" + }, + "dependencies": { + "anymatch": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", + "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", + "dev": true, + "optional": true, + "requires": { + "micromatch": "^3.1.4", + "normalize-path": "^2.1.1" + }, + "dependencies": { + "normalize-path": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", + "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", + "dev": true, + "optional": true, + "requires": { + "remove-trailing-separator": "^1.0.1" + } + } + } + }, + "binary-extensions": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz", + "integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==", + "dev": true, + "optional": true + }, + "chokidar": { + "version": "2.1.8", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz", + "integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==", + "dev": true, + "optional": true, + "requires": { + "anymatch": "^2.0.0", + "async-each": "^1.0.1", + "braces": "^2.3.2", + "fsevents": "^1.2.7", + "glob-parent": "^3.1.0", + "inherits": "^2.0.3", + "is-binary-path": "^1.0.0", + "is-glob": "^4.0.0", + "normalize-path": "^3.0.0", + "path-is-absolute": "^1.0.0", + "readdirp": "^2.2.1", + "upath": "^1.1.1" + } + }, + "fsevents": { + "version": "1.2.13", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.13.tgz", + "integrity": "sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw==", + "dev": true, + "optional": true, + "requires": { + "bindings": "^1.5.0", + "nan": "^2.12.1" + } + }, + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "dev": true, + "optional": true, + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "dev": true, + "optional": true, + "requires": { + "is-extglob": "^2.1.0" + } + } + } + }, + "is-binary-path": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", + "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", + "dev": true, + "optional": true, + "requires": { + "binary-extensions": "^1.0.0" + } + }, + "readdirp": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz", + "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==", + "dev": true, + "optional": true, + "requires": { + "graceful-fs": "^4.1.11", + "micromatch": "^3.1.10", + "readable-stream": "^2.0.2" + } + } + } + }, + "wbuf": { + "version": "1.7.3", + "resolved": "https://registry.npmjs.org/wbuf/-/wbuf-1.7.3.tgz", + "integrity": "sha512-O84QOnr0icsbFGLS0O3bI5FswxzRr8/gHwWkDlQFskhSPryQXvrTMxjxGP4+iWYoauLoBvfDpkrOauZ+0iZpDA==", + "dev": true, + "requires": { + "minimalistic-assert": "^1.0.0" + } + }, + "wcwidth": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/wcwidth/-/wcwidth-1.0.1.tgz", + "integrity": "sha1-8LDc+RW8X/FSivrbLA4XtTLaL+g=", + "dev": true, + "requires": { + "defaults": "^1.0.3" + } + }, + "webpack": { + "version": "4.44.2", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-4.44.2.tgz", + "integrity": "sha512-6KJVGlCxYdISyurpQ0IPTklv+DULv05rs2hseIXer6D7KrUicRDLFb4IUM1S6LUAKypPM/nSiVSuv8jHu1m3/Q==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-module-context": "1.9.0", + "@webassemblyjs/wasm-edit": "1.9.0", + "@webassemblyjs/wasm-parser": "1.9.0", + "acorn": "^6.4.1", + "ajv": "^6.10.2", + "ajv-keywords": "^3.4.1", + "chrome-trace-event": "^1.0.2", + "enhanced-resolve": "^4.3.0", + "eslint-scope": "^4.0.3", + "json-parse-better-errors": "^1.0.2", + "loader-runner": "^2.4.0", + "loader-utils": "^1.2.3", + "memory-fs": "^0.4.1", + "micromatch": "^3.1.10", + "mkdirp": "^0.5.3", + "neo-async": "^2.6.1", + "node-libs-browser": "^2.2.1", + "schema-utils": "^1.0.0", + "tapable": "^1.1.3", + "terser-webpack-plugin": "^1.4.3", + "watchpack": "^1.7.4", + "webpack-sources": "^1.4.1" + }, + "dependencies": { + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + } + } + }, + "webpack-bundle-analyzer": { + "version": "3.9.0", + "resolved": "https://registry.npmjs.org/webpack-bundle-analyzer/-/webpack-bundle-analyzer-3.9.0.tgz", + "integrity": "sha512-Ob8amZfCm3rMB1ScjQVlbYYUEJyEjdEtQ92jqiFUYt5VkEeO2v5UMbv49P/gnmCZm3A6yaFQzCBvpZqN4MUsdA==", + "dev": true, + "requires": { + "acorn": "^7.1.1", + "acorn-walk": "^7.1.1", + "bfj": "^6.1.1", + "chalk": "^2.4.1", + "commander": "^2.18.0", + "ejs": "^2.6.1", + "express": "^4.16.3", + "filesize": "^3.6.1", + "gzip-size": "^5.0.0", + "lodash": "^4.17.19", + "mkdirp": "^0.5.1", + "opener": "^1.5.1", + "ws": "^6.0.0" + }, + "dependencies": { + "acorn": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", + "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", + "dev": true + } + } + }, + "webpack-chain": { + "version": "6.5.1", + "resolved": "https://registry.npmjs.org/webpack-chain/-/webpack-chain-6.5.1.tgz", + "integrity": "sha512-7doO/SRtLu8q5WM0s7vPKPWX580qhi0/yBHkOxNkv50f6qB76Zy9o2wRTrrPULqYTvQlVHuvbA8v+G5ayuUDsA==", + "dev": true, + "requires": { + "deepmerge": "^1.5.2", + "javascript-stringify": "^2.0.1" + } + }, + "webpack-dev-middleware": { + "version": "3.7.3", + "resolved": "https://registry.npmjs.org/webpack-dev-middleware/-/webpack-dev-middleware-3.7.3.tgz", + "integrity": "sha512-djelc/zGiz9nZj/U7PTBi2ViorGJXEWo/3ltkPbDyxCXhhEXkW0ce99falaok4TPj+AsxLiXJR0EBOb0zh9fKQ==", + "dev": true, + "requires": { + "memory-fs": "^0.4.1", + "mime": "^2.4.4", + "mkdirp": "^0.5.1", + "range-parser": "^1.2.1", + "webpack-log": "^2.0.0" + } + }, + "webpack-dev-server": { + "version": "3.11.2", + "resolved": "https://registry.npmjs.org/webpack-dev-server/-/webpack-dev-server-3.11.2.tgz", + "integrity": "sha512-A80BkuHRQfCiNtGBS1EMf2ChTUs0x+B3wGDFmOeT4rmJOHhHTCH2naNxIHhmkr0/UillP4U3yeIyv1pNp+QDLQ==", + "dev": true, + "requires": { + "ansi-html": "0.0.7", + "bonjour": "^3.5.0", + "chokidar": "^2.1.8", + "compression": "^1.7.4", + "connect-history-api-fallback": "^1.6.0", + "debug": "^4.1.1", + "del": "^4.1.1", + "express": "^4.17.1", + "html-entities": "^1.3.1", + "http-proxy-middleware": "0.19.1", + "import-local": "^2.0.0", + "internal-ip": "^4.3.0", + "ip": "^1.1.5", + "is-absolute-url": "^3.0.3", + "killable": "^1.0.1", + "loglevel": "^1.6.8", + "opn": "^5.5.0", + "p-retry": "^3.0.1", + "portfinder": "^1.0.26", + "schema-utils": "^1.0.0", + "selfsigned": "^1.10.8", + "semver": "^6.3.0", + "serve-index": "^1.9.1", + "sockjs": "^0.3.21", + "sockjs-client": "^1.5.0", + "spdy": "^4.0.2", + "strip-ansi": "^3.0.1", + "supports-color": "^6.1.0", + "url": "^0.11.0", + "webpack-dev-middleware": "^3.7.2", + "webpack-log": "^2.0.0", + "ws": "^6.2.1", + "yargs": "^13.3.2" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + }, + "anymatch": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", + "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", + "dev": true, + "requires": { + "micromatch": "^3.1.4", + "normalize-path": "^2.1.1" + }, + "dependencies": { + "normalize-path": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", + "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", + "dev": true, + "requires": { + "remove-trailing-separator": "^1.0.1" + } + } + } + }, + "binary-extensions": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz", + "integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==", + "dev": true + }, + "camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "dev": true + }, + "chokidar": { + "version": "2.1.8", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz", + "integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==", + "dev": true, + "requires": { + "anymatch": "^2.0.0", + "async-each": "^1.0.1", + "braces": "^2.3.2", + "fsevents": "^1.2.7", + "glob-parent": "^3.1.0", + "inherits": "^2.0.3", + "is-binary-path": "^1.0.0", + "is-glob": "^4.0.0", + "normalize-path": "^3.0.0", + "path-is-absolute": "^1.0.0", + "readdirp": "^2.2.1", + "upath": "^1.1.1" + } + }, + "cliui": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", + "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", + "dev": true, + "requires": { + "string-width": "^3.1.0", + "strip-ansi": "^5.2.0", + "wrap-ansi": "^5.1.0" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", + "dev": true + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + } + } + }, + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", + "dev": true + }, + "find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "requires": { + "locate-path": "^3.0.0" + } + }, + "fsevents": { + "version": "1.2.13", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.13.tgz", + "integrity": "sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw==", + "dev": true, + "optional": true, + "requires": { + "bindings": "^1.5.0", + "nan": "^2.12.1" + } + }, + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "dev": true, + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "dev": true, + "requires": { + "is-extglob": "^2.1.0" + } + } + } + }, + "http-proxy-middleware": { + "version": "0.19.1", + "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-0.19.1.tgz", + "integrity": "sha512-yHYTgWMQO8VvwNS22eLLloAkvungsKdKTLO8AJlftYIKNfJr3GK3zK0ZCfzDDGUBttdGc8xFy1mCitvNKQtC3Q==", + "dev": true, + "requires": { + "http-proxy": "^1.17.0", + "is-glob": "^4.0.0", + "lodash": "^4.17.11", + "micromatch": "^3.1.10" + } + }, + "is-absolute-url": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/is-absolute-url/-/is-absolute-url-3.0.3.tgz", + "integrity": "sha512-opmNIX7uFnS96NtPmhWQgQx6/NYFgsUXYMllcfzwWKUMwfo8kku1TvE6hkNcH+Q1ts5cMVrsY7j0bxXQDciu9Q==", + "dev": true + }, + "is-binary-path": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", + "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", + "dev": true, + "requires": { + "binary-extensions": "^1.0.0" + } + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "dev": true + }, + "locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "dev": true, + "requires": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + } + }, + "p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "dev": true, + "requires": { + "p-limit": "^2.0.0" + } + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + }, + "readdirp": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz", + "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.11", + "micromatch": "^3.1.10", + "readable-stream": "^2.0.2" + } + }, + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "dev": true, + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", + "dev": true + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + } + } + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "supports-color": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", + "integrity": "sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "wrap-ansi": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", + "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.0", + "string-width": "^3.0.0", + "strip-ansi": "^5.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", + "dev": true + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + } + } + }, + "yargs": { + "version": "13.3.2", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz", + "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==", + "dev": true, + "requires": { + "cliui": "^5.0.0", + "find-up": "^3.0.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^3.0.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^13.1.2" + } + }, + "yargs-parser": { + "version": "13.1.2", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz", + "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==", + "dev": true, + "requires": { + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" + } + } + } + }, + "webpack-log": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/webpack-log/-/webpack-log-2.0.0.tgz", + "integrity": "sha512-cX8G2vR/85UYG59FgkoMamwHUIkSSlV3bBMRsbxVXVUk2j6NleCKjQ/WE9eYg9WY4w25O9w8wKP4rzNZFmUcUg==", + "dev": true, + "requires": { + "ansi-colors": "^3.0.0", + "uuid": "^3.3.2" + } + }, + "webpack-merge": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/webpack-merge/-/webpack-merge-4.2.2.tgz", + "integrity": "sha512-TUE1UGoTX2Cd42j3krGYqObZbOD+xF7u28WB7tfUordytSjbWTIjK/8V0amkBfTYN4/pB/GIDlJZZ657BGG19g==", + "dev": true, + "requires": { + "lodash": "^4.17.15" + } + }, + "webpack-sources": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-1.4.3.tgz", + "integrity": "sha512-lgTS3Xhv1lCOKo7SA5TjKXMjpSM4sBjNV5+q2bqesbSPs5FjGmU6jjtBSkX9b4qW87vDIsCIlUPOEhbZrMdjeQ==", + "dev": true, + "requires": { + "source-list-map": "^2.0.0", + "source-map": "~0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "websocket-driver": { + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz", + "integrity": "sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg==", + "dev": true, + "requires": { + "http-parser-js": ">=0.5.1", + "safe-buffer": ">=5.1.0", + "websocket-extensions": ">=0.1.1" + } + }, + "websocket-extensions": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.4.tgz", + "integrity": "sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==", + "dev": true + }, + "which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "which-boxed-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", + "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", + "dev": true, + "requires": { + "is-bigint": "^1.0.1", + "is-boolean-object": "^1.1.0", + "is-number-object": "^1.0.4", + "is-string": "^1.0.5", + "is-symbol": "^1.0.3" + } + }, + "which-module": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", + "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", + "dev": true + }, + "word-wrap": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", + "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", + "dev": true + }, + "worker-farm": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/worker-farm/-/worker-farm-1.7.0.tgz", + "integrity": "sha512-rvw3QTZc8lAxyVrqcSGVm5yP/IJ2UcB3U0graE3LCFoZ0Yn2x4EoVSqJKdB/T5M+FLcRPjz4TDacRf3OCfNUzw==", + "dev": true, + "requires": { + "errno": "~0.1.7" + } + }, + "wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dev": true, + "requires": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + } + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", + "dev": true + }, + "ws": { + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/ws/-/ws-6.2.2.tgz", + "integrity": "sha512-zmhltoSR8u1cnDsD43TX59mzoMZsLKqUweyYBAIvTngR3shc0W6aOZylZmq/7hqyVxPdi+5Ud2QInblgyE72fw==", + "dev": true, + "requires": { + "async-limiter": "~1.0.0" + } + }, + "xtend": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", + "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", + "dev": true + }, + "y18n": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.1.tgz", + "integrity": "sha512-wNcy4NvjMYL8gogWWYAO7ZFWFfHcbdbE57tZO8e4cbpj8tfUcwrwqSl3ad8HxpYWCdXcJUCeKKZS62Av1affwQ==", + "dev": true + }, + "yallist": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", + "dev": true + }, + "yargs": { + "version": "16.2.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", + "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", + "dev": true, + "requires": { + "cliui": "^7.0.2", + "escalade": "^3.1.1", + "get-caller-file": "^2.0.5", + "require-directory": "^2.1.1", + "string-width": "^4.2.0", + "y18n": "^5.0.5", + "yargs-parser": "^20.2.2" + }, + "dependencies": { + "cliui": { + "version": "7.0.4", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", + "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", + "dev": true, + "requires": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.0", + "wrap-ansi": "^7.0.0" + } + }, + "y18n": { + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", + "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", + "dev": true + } + } + }, + "yargs-parser": { + "version": "20.2.9", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", + "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", + "dev": true + }, + "yorkie": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/yorkie/-/yorkie-2.0.0.tgz", + "integrity": "sha512-jcKpkthap6x63MB4TxwCyuIGkV0oYP/YRyuQU5UO0Yz/E/ZAu+653/uov+phdmO54n6BcvFRyyt0RRrWdN2mpw==", + "dev": true, + "requires": { + "execa": "^0.8.0", + "is-ci": "^1.0.10", + "normalize-path": "^1.0.0", + "strip-indent": "^2.0.0" + }, + "dependencies": { + "cross-spawn": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", + "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", + "dev": true, + "requires": { + "lru-cache": "^4.0.1", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "execa": { + "version": "0.8.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-0.8.0.tgz", + "integrity": "sha1-2NdrvBtVIX7RkP1t1J08d07PyNo=", + "dev": true, + "requires": { + "cross-spawn": "^5.0.1", + "get-stream": "^3.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + } + }, + "get-stream": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", + "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=", + "dev": true + }, + "lru-cache": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", + "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", + "dev": true, + "requires": { + "pseudomap": "^1.0.2", + "yallist": "^2.1.2" + } + }, + "normalize-path": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-1.0.0.tgz", + "integrity": "sha1-MtDkcvkf80VwHBWoMRAY07CpA3k=", + "dev": true + }, + "yallist": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", + "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", + "dev": true + } + } + } + } +} diff --git a/KST-ASD-BI-101/cts/client/package.json b/KST-ASD-BI-101/cts/client/package.json new file mode 100644 index 0000000..1101540 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/package.json @@ -0,0 +1,40 @@ +{ + "name": "catapult-cts-client", + "version": "1.0.0", + "description": "Catapult CTS UI", + "repository": { + "type": "git", + "url": "git+https://github.com/adlnet/CATAPULT.git" + }, + "scripts": { + "serve": "vue-cli-service serve", + "build": "vue-cli-service build", + "lint": "vue-cli-service lint" + }, + "author": "Rustici Software ", + "license": "Apache-2.0", + "dependencies": { + "@cmi5/requirements": "^1.0.0", + "@stardazed/streams-polyfill": "^2.4.0", + "bootstrap-vue": "^2.21.2", + "core-js": "^3.15.2", + "faker": "^5.5.3", + "vue": "^2.6.14", + "vue-moment": "^4.1.0", + "vue-router": "^3.5.2", + "vuex": "^3.6.2" + }, + "devDependencies": { + "@vue/cli-plugin-babel": "^4.5.13", + "@vue/cli-plugin-eslint": "^4.5.13", + "@vue/cli-plugin-router": "^4.5.13", + "@vue/cli-plugin-vuex": "^4.5.13", + "@vue/cli-service": "^4.5.13", + "babel-eslint": "^10.1.0", + "eslint": "^7.31.0", + "eslint-plugin-vue": "^7.14.0", + "sass": "^1.35.2", + "sass-loader": "^10.2.0", + "vue-template-compiler": "^2.6.14" + } +} diff --git a/KST-ASD-BI-101/cts/client/public/index.html b/KST-ASD-BI-101/cts/client/public/index.html new file mode 100644 index 0000000..4123528 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/public/index.html @@ -0,0 +1,17 @@ + + + + + + + + <%= htmlWebpackPlugin.options.title %> + + + +
+ + + diff --git a/KST-ASD-BI-101/cts/client/src/components/alerts.vue b/KST-ASD-BI-101/cts/client/src/components/alerts.vue new file mode 100644 index 0000000..ec9d4a4 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/alerts.vue @@ -0,0 +1,53 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/app.vue b/KST-ASD-BI-101/cts/client/src/components/app.vue new file mode 100644 index 0000000..48442ce --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/app.vue @@ -0,0 +1,58 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated.vue new file mode 100644 index 0000000..c44a14c --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated.vue @@ -0,0 +1,66 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/admin.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/admin.vue new file mode 100644 index 0000000..99bf2fb --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/admin.vue @@ -0,0 +1,54 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/admin/about.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/admin/about.vue new file mode 100644 index 0000000..3ebd66e --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/admin/about.vue @@ -0,0 +1,34 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/admin/user/list.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/admin/user/list.vue new file mode 100644 index 0000000..48af136 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/admin/user/list.vue @@ -0,0 +1,257 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/course/detail.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/detail.vue new file mode 100644 index 0000000..a78c721 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/detail.vue @@ -0,0 +1,123 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/course/detail/structure.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/detail/structure.vue new file mode 100644 index 0000000..b537f3a --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/detail/structure.vue @@ -0,0 +1,179 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/course/detail/structure/node.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/detail/structure/node.vue new file mode 100644 index 0000000..012eb0d --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/detail/structure/node.vue @@ -0,0 +1,106 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/course/detail/testList.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/detail/testList.vue new file mode 100644 index 0000000..33589f1 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/detail/testList.vue @@ -0,0 +1,147 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/course/list.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/list.vue new file mode 100644 index 0000000..95a99d6 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/list.vue @@ -0,0 +1,223 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/course/new.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/new.vue new file mode 100644 index 0000000..bbefc26 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/new.vue @@ -0,0 +1,50 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/course/new/upload.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/new/upload.vue new file mode 100644 index 0000000..f90cf44 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/new/upload.vue @@ -0,0 +1,79 @@ + + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/course/new/xmlEditor.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/new/xmlEditor.vue new file mode 100644 index 0000000..4a21dc2 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/course/new/xmlEditor.vue @@ -0,0 +1,90 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/navBar.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/navBar.vue new file mode 100644 index 0000000..1c42d64 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/navBar.vue @@ -0,0 +1,144 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/navBar/testNew.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/navBar/testNew.vue new file mode 100644 index 0000000..e2d31f1 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/navBar/testNew.vue @@ -0,0 +1,85 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/requirements/list.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/requirements/list.vue new file mode 100644 index 0000000..5b669b1 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/requirements/list.vue @@ -0,0 +1,164 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/session/detail.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/session/detail.vue new file mode 100644 index 0000000..25a9f4f --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/session/detail.vue @@ -0,0 +1,221 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/test/detail.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/test/detail.vue new file mode 100644 index 0000000..eb2437c --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/test/detail.vue @@ -0,0 +1,490 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/test/detail/structure/node.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/test/detail/structure/node.vue new file mode 100644 index 0000000..d5f65ca --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/test/detail/structure/node.vue @@ -0,0 +1,86 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/authenticated/test/new.vue b/KST-ASD-BI-101/cts/client/src/components/authenticated/test/new.vue new file mode 100644 index 0000000..a592ba6 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/authenticated/test/new.vue @@ -0,0 +1,145 @@ + + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/notFound.vue b/KST-ASD-BI-101/cts/client/src/components/notFound.vue new file mode 100644 index 0000000..ad5240f --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/notFound.vue @@ -0,0 +1,38 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/testStatus.vue b/KST-ASD-BI-101/cts/client/src/components/testStatus.vue new file mode 100644 index 0000000..38909cb --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/testStatus.vue @@ -0,0 +1,100 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/unauthenticated.vue b/KST-ASD-BI-101/cts/client/src/components/unauthenticated.vue new file mode 100644 index 0000000..4b7eefc --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/unauthenticated.vue @@ -0,0 +1,80 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/unauthenticated/bootstrap.vue b/KST-ASD-BI-101/cts/client/src/components/unauthenticated/bootstrap.vue new file mode 100644 index 0000000..d25bbc9 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/unauthenticated/bootstrap.vue @@ -0,0 +1,91 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/components/unauthenticated/signIn.vue b/KST-ASD-BI-101/cts/client/src/components/unauthenticated/signIn.vue new file mode 100644 index 0000000..ef22419 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/components/unauthenticated/signIn.vue @@ -0,0 +1,92 @@ + + + + + + diff --git a/KST-ASD-BI-101/cts/client/src/main.js b/KST-ASD-BI-101/cts/client/src/main.js new file mode 100644 index 0000000..1c9628c --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/main.js @@ -0,0 +1,60 @@ +/* + Copyright 2020 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +import Vue from "vue"; +import BootstrapVue from "bootstrap-vue"; +import Moment from "vue-moment"; +import faker from "faker/locale/en"; +import router from "./router"; +import store from "./store"; +import app from "./components/app.vue"; + +import "./main.scss"; + +Vue.use(Moment); +Vue.use(BootstrapVue); + +Vue.config.productionTip = false; + +Object.defineProperty( + Vue.prototype, + "$faker", + { + get () { + return faker; + } + } +); + +const provision = async () => { + // + // Try to init the credential to see if there is a cookie already + // available, if so, the login screen won't be presented, otherwise + // they need to enter their username and password and optionally get + // a cookie set, if they don't request a cookie then a refresh of the + // page will re-present the login form + // + await store.dispatch("service/apiAccess/initCredential"); + + new Vue( + { + router, + store, + render: (h) => h(app) + } + ).$mount("#app"); +}; + +provision(); diff --git a/KST-ASD-BI-101/cts/client/src/main.scss b/KST-ASD-BI-101/cts/client/src/main.scss new file mode 100644 index 0000000..c8fa943 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/main.scss @@ -0,0 +1,17 @@ +/* + Copyright 2020 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +@import "../node_modules/bootstrap/scss/bootstrap"; +@import "../node_modules/bootstrap-vue/src/index.scss"; diff --git a/KST-ASD-BI-101/cts/client/src/router/index.js b/KST-ASD-BI-101/cts/client/src/router/index.js new file mode 100644 index 0000000..9ba5f6c --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/router/index.js @@ -0,0 +1,122 @@ +/* + Copyright 2020 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +import Vue from "vue"; +import VueRouter from "vue-router"; + +import notFound from "@/components/notFound"; +import courseList from "@/components/authenticated/course/list"; +import courseDetail from "@/components/authenticated/course/detail"; +import courseNew from "@/components/authenticated/course/new"; +import courseNewUpload from "@/components/authenticated/course/new/upload"; +import courseNewXmlEditor from "@/components/authenticated/course/new/xmlEditor"; +import courseDetailStructure from "@/components/authenticated/course/detail/structure"; +import courseDetailTestList from "@/components/authenticated/course/detail/testList"; +import testNew from "@/components/authenticated/test/new"; +import testDetail from "@/components/authenticated/test/detail"; +import sessionDetail from "@/components/authenticated/session/detail"; +import requirementsList from "@/components/authenticated/requirements/list"; +import admin from "@/components/authenticated/admin"; +import adminAbout from "@/components/authenticated/admin/about"; +import adminUserList from "@/components/authenticated/admin/user/list"; + +Vue.use(VueRouter); + +const idPropToNumber = ({params}) => ({id: Number.parseInt(params.id, 10)}), + router = new VueRouter( + { + routes: [ + { + path: "/course-new", + component: courseNew, + children: [ + { + path: "upload", + component: courseNewUpload + }, + { + path: "xml-editor", + component: courseNewXmlEditor + } + ] + }, + { + path: "/course/:id", + component: courseDetail, + props: idPropToNumber, + children: [ + { + path: "structure", + component: courseDetailStructure, + props: idPropToNumber + }, + { + path: "", + component: courseDetailTestList, + props: idPropToNumber + } + ] + }, + { + path: "/test-new/:courseId", + component: testNew, + props: ({params}) => ({courseId: Number.parseInt(params.courseId, 10)}) + }, + { + path: "/test/:id", + component: testDetail, + props: idPropToNumber + }, + { + path: "/session/:id", + component: sessionDetail, + props: idPropToNumber + }, + { + path: "/requirements", + component: requirementsList + }, + { + path: "/admin", + component: admin, + children: [ + { + path: "user-list/:initPage?", + component: adminUserList, + props: true + }, + { + path: "", + component: adminAbout + } + ] + }, + { + path: "/:initPage?", + component: courseList, + props: true + }, + { + path: "*", + component: notFound, + props: (route) => ({ + path: route.params.pathMatch + }) + } + ] + } + ); + +export default router; diff --git a/KST-ASD-BI-101/cts/client/src/store/alerts.js b/KST-ASD-BI-101/cts/client/src/store/alerts.js new file mode 100644 index 0000000..0e53971 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/store/alerts.js @@ -0,0 +1,72 @@ +/* + Copyright 2020 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +import Vue from "vue"; + +const initialState = () => ({ + cacheContainer: {}, +}); + +export default { + namespaced: true, + state: { + initialState, + ...initialState() + }, + getters: { + list: (state) => (kind) => { + if (! state.cacheContainer[kind]) { + return; + } + + return state.cacheContainer[kind]; + } + }, + mutations: { + add (state, {kind, payload}) { + if (! state.cacheContainer[kind]) { + Vue.set( + state.cacheContainer, + kind, + [] + ); + } + + state.cacheContainer[kind].push( + { + id: Date.now(), + variant: "danger", + ...payload + } + ); + }, + remove (state, {kind, id}) { + const alerts = state.cacheContainer[kind], + alertIndex = alerts.findIndex((i) => i.id === id); + + if (alertIndex !== -1) { + alerts.splice(alertIndex, 1); + } + } + }, + actions: { + add: ({commit}, {kind, payload}) => { + commit("add", {kind, payload}); + }, + remove: ({commit}, {kind, id}) => { + commit("remove", {kind, id}); + } + } +}; diff --git a/KST-ASD-BI-101/cts/client/src/store/index.js b/KST-ASD-BI-101/cts/client/src/store/index.js new file mode 100644 index 0000000..d75ea8d --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/store/index.js @@ -0,0 +1,47 @@ +/* + Copyright 2020 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +import Vue from "vue"; +import Vuex from "vuex"; +import alerts from "./alerts"; +import service from "./service"; + +Vue.use(Vuex); + +export default new Vuex.Store( + { + namespaced: true, + modules: { + alerts, + service + }, + mutations: { + resetState (state) { + Object.assign(state.alerts, state.alerts.initialState()); + + Object.assign(state.service.sessions, state.service.sessions.initialState()); + Object.assign(state.service.tests, state.service.tests.initialState()); + Object.assign(state.service.courses, state.service.courses.initialState()); + + // logout shouldn't clear isBootstrapped + const apiAccess = state.service.apiAccess.initialState(); + + apiAccess.isBootstrapped = state.service.apiAccess.isBootstrapped; + + Object.assign(state.service.apiAccess, apiAccess); + } + } + } +); diff --git a/KST-ASD-BI-101/cts/client/src/store/service.js b/KST-ASD-BI-101/cts/client/src/store/service.js new file mode 100644 index 0000000..c3951de --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/store/service.js @@ -0,0 +1,49 @@ +/* + Copyright 2020 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +import apiAccess from "./service/apiAccess"; +import courses from "./service/courses"; +import tests from "./service/tests"; +import sessions from "./service/sessions"; +import users from "./service/users"; + +export default { + namespaced: true, + getters: { + baseApiUrl: () => process.env.VUE_APP_API_URL ? process.env.VUE_APP_API_URL : "", + makeApiRequest: (state, getters) => (resource, cfg = {}) => { + const fetchCfg = { + ...cfg + }; + + if (state.apiAccess.username) { + fetchCfg.headers = fetchCfg.headers || {}; + fetchCfg.headers.Authorization = `Basic ${Buffer.from(`${state.apiAccess.username}:${state.apiAccess.password}`).toString("base64")}`; + } + else { + fetchCfg.credentials = "include"; + } + + return fetch(`${getters.baseApiUrl}/api/v1/${resource}`, fetchCfg); + } + }, + modules: { + apiAccess, + courses, + tests, + sessions, + users + } +}; diff --git a/KST-ASD-BI-101/cts/client/src/store/service/apiAccess.js b/KST-ASD-BI-101/cts/client/src/store/service/apiAccess.js new file mode 100644 index 0000000..fdcec3f --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/store/service/apiAccess.js @@ -0,0 +1,214 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +const initialState = () => ({ + isBootstrapped: null, + loading: false, + error: false, + errMsg: "", + access: false, + item: null, + username: null, + password: null, + expiresAt: null +}); + +export default { + namespaced: true, + state: { + initialState, + ...initialState() + }, + getters: { + current: (state) => state.item, + isAdmin: (state) => () => { + if (state.access && state.item && state.item.roles && state.item.roles.includes("admin")) { + return true; + } + + return false; + } + }, + mutations: { + set: (state, {property, value}) => { + state[property] = value; + } + }, + actions: { + initCredential: async ({commit, rootGetters}) => { + try { + const response = await rootGetters["service/makeApiRequest"]( + "login", + { + method: "GET" + } + ); + + if (! response.ok) { + if (response.status === 401) { + let body = await response.json(); + + if (typeof body.isBootstrapped !== "undefined") { + commit("set", {property: "isBootstrapped", value: body.isBootstrapped}); + } + + return; + } + + throw new Error(`Request failed: ${response.status}`); + } + + let body = await response.json(); + + commit("set", {property: "item", value: body.user}); + commit("set", {property: "access", value: true}); + commit("set", {property: "expiresAt", value: body.expiresAt}); + commit("set", {property: "isBootstrapped", value: true}); + } + catch (ex) { + console.log(ex); + } + }, + + storeCredential: async ({commit, rootGetters}, {username, password, storeCookie = false}) => { + commit("set", {property: "error", value: false}); + commit("set", {property: "errMsg", value: ""}); + commit("set", {property: "loading", value: true}); + + try { + const response = await rootGetters["service/makeApiRequest"]( + "login", + { + method: "POST", + headers: { + "Content-Type": "application/json" + }, + body: JSON.stringify({ + username, + password, + storeCookie + }) + } + ); + + if (! response.ok) { + if (response.status === 401) { + throw "Your username and / or password is incorrect. Please try again."; + } + + throw new Error(`Request failed: ${response.status}`); + } + + let body = await response.json(); + + // + // if they didn't want to be remembered then we don't get a cookie + // in which case we just need to store the username/password and then + // make the requests set the basic auth + // + if (! storeCookie) { + commit("set", {property: "username", value: username}); + commit("set", {property: "password", value: password}); + } + + commit("set", {property: "item", value: body}); + commit("set", {property: "access", value: true}); + commit("set", {property: "expiresAt", value: body.expiresAt}); + } + catch (ex) { + commit("set", {property: "error", value: true}); + commit("set", {property: "errMsg", value: ex}); + } + finally { + commit("set", {property: "loading", value: false}); + } + }, + + clearCredential: async ({commit, rootGetters}) => { + try { + const response = await rootGetters["service/makeApiRequest"]( + "logout", + { + method: "GET" + } + ); + + if (! response.ok) { + if (response.status === 401) { + return; + } + + throw new Error(`Request failed: ${response.status}`); + } + } + catch (ex) { + console.log(ex); + } + + commit("resetState", null, {root: true}); + }, + + clearCredentialTimeout: async ({commit, dispatch}) => { + await dispatch("clearCredential"); + commit("set", {property: "error", value: true}); + commit("set", {property: "errMsg", value: "Your session has timed out, please sign in again."}); + }, + + bootstrap: async ({commit, rootGetters}, {username, password}) => { + commit("set", {property: "error", value: false}); + commit("set", {property: "errMsg", value: ""}); + commit("set", {property: "loading", value: true}); + + try { + const response = await rootGetters["service/makeApiRequest"]( + "bootstrap", + { + method: "POST", + headers: { + "Content-Type": "application/json" + }, + body: JSON.stringify({ + firstUser: { + username, + password + } + }) + } + ); + + if (! response.ok) { + if (response.status === 409) { + throw "Service has already been initialized. Verify potential security issue."; + } + + throw new Error(`Request failed: ${response.status}`); + } + + // + // successful response means the service is now setup, mark it + // as initialized which should then force them to login + // + commit("set", {property: "isBootstrapped", value: true}); + } + catch (ex) { + commit("set", {property: "error", value: true}); + commit("set", {property: "errMsg", value: ex}); + } + finally { + commit("set", {property: "loading", value: false}); + } + } + } +}; diff --git a/KST-ASD-BI-101/cts/client/src/store/service/courses.js b/KST-ASD-BI-101/cts/client/src/store/service/courses.js new file mode 100644 index 0000000..b6f7798 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/store/service/courses.js @@ -0,0 +1,257 @@ +/* + Copyright 2020 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +import Vue from "vue"; + +const initialState = () => ({ + detailCache: {}, + cacheContainer: {}, + defaultKeyProperties: {} + }), + wrapItem = (item, {loading = false, loaded = false}) => ({ + item, + loading, + loaded, + error: false, + errMsg: null + }), + populateItem = (item) => { + return item; + }; + +export default { + namespaced: true, + state: { + initialState, + ...initialState() + }, + getters: { + cacheKey: (state) => () => { + const cacheKey = "key"; + + if (! state.cacheContainer[cacheKey]) { + Vue.set( + state.cacheContainer, + cacheKey, + { + loaded: false, + loading: false, + items: [], + currentIndex: null + } + ); + } + + return cacheKey; + }, + defaultCacheKey: (state, getters) => getters.cacheKey({props: state.defaultKeyProperties}), + + cache: (state) => ({cacheKey}) => state.cacheContainer[cacheKey], + defaultCache: (state, getters) => getters.cache({cacheKey: getters.defaultCacheKey}), + + byId: (state) => ({id}) => { + if (! state.detailCache[id]) { + Vue.set( + state.detailCache, + id, + wrapItem( + populateItem({ + id + }), + { + loaded: false + } + ) + ); + } + + return state.detailCache[id]; + } + }, + actions: { + alert: ({dispatch}, {content, variant = "danger", kind = "courseList"}) => { + dispatch( + "alerts/add", + { + kind, + payload: { + content, + variant + } + }, + {root: true} + ); + }, + + loadById: async ({getters, rootGetters}, {id, force = false}) => { + const fromCache = getters.byId({id}); + + if (fromCache.loaded && ! force) { + return; + } + + fromCache.loading = true; + + try { + const response = await rootGetters["service/makeApiRequest"](`courses/${id}`); + + if (! response.ok) { + throw new Error(`Request failed: ${response.status}`); + } + + const body = await response.json(); + + fromCache.item = populateItem(body); + fromCache.loaded = true; + } + catch (ex) { + fromCache.error = true; + fromCache.errMsg = `Failed to load from id: ${ex}`; + } + finally { + fromCache.loading = false; + } + }, + + load: async ({dispatch, state, getters, rootGetters}, {props = state.defaultKeyProperties, force = false} = {}) => { + const cache = getters.cache({cacheKey: getters.cacheKey({props})}), + busyKey = "loading"; + + if (cache.loaded || cache.loading) { + if (! force) { + return; + } + + cache.items = cache.items.filter((i) => i.id === null); + } + + cache[busyKey] = true; + + try { + const response = await rootGetters["service/makeApiRequest"]("courses"), + lastNewItemIndex = cache.items.findIndex((i) => i.id !== null); + + if (! response.ok) { + throw new Error(`Request failed: ${response.status}`); + } + + const body = await response.json(); + + cache.items.splice( + lastNewItemIndex === -1 ? cache.items.length : lastNewItemIndex + 1, + 0, + ...body.items + ); + cache.loaded = true; + + for (const i of body.items) { + if (! state.detailCache[i.id]) { + Vue.set( + state.detailCache, + i.id, + wrapItem(i, {loaded: true}) + ); + } + } + } + catch (ex) { + const content = `Failed to load courses: ${ex}` + + cache.err = true; + cache.errMsg = content; + + dispatch("alert", {content}); + } + + // eslint-disable-next-line require-atomic-updates + cache[busyKey] = false; + }, + + delete: async ({dispatch, getters, rootGetters}, {item}) => { + const cache = getters.defaultCache, + itemIndex = cache.items.findIndex((i) => i === item); + + try { + const response = await rootGetters["service/makeApiRequest"]( + `courses/${item.id}`, + { + method: "DELETE", + mode: "cors" + } + ); + + if (response.ok) { + if (itemIndex !== -1) { + cache.items.splice(itemIndex, 1); + + if (cache.currentIndex === itemIndex) { + cache.currentIndex = null; + } + } + } + else { + const body = await response.json(); + + throw new Error(`${response.status} - ${body.message}`); + } + } + catch (ex) { + dispatch("alert", {content: `Failed to delete course (id: ${item.id}): ${ex}`}); + + return false; + } + + return true; + }, + + import: async ({dispatch, state, getters, rootGetters}, {body, contentType}) => { + const kind = "courseNew"; + + try { + const response = await rootGetters["service/makeApiRequest"]( + "courses", + { + method: "POST", + mode: "cors", + headers: { + "Content-Type": contentType + }, + body + } + ); + + let responseBody = await response.json(); + + if (! response.ok) { + throw new Error(`Request failed: ${responseBody.message ? responseBody.message : "no message"} (${response.status})`); + } + + responseBody = populateItem(responseBody); + + Vue.set(state.detailCache, responseBody.id, wrapItem(responseBody, {loaded: true})); + getters.cache({cacheKey: getters.cacheKey()}).items.unshift(responseBody); + + state.cacheContainer + + return responseBody.id; + } + catch (ex) { + dispatch("alert", {content: `Failed to import course: ${ex}`, kind}); + } + + return null; + } + } +}; diff --git a/KST-ASD-BI-101/cts/client/src/store/service/sessions.js b/KST-ASD-BI-101/cts/client/src/store/service/sessions.js new file mode 100644 index 0000000..9cb0935 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/store/service/sessions.js @@ -0,0 +1,184 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +import Vue from "vue"; +import logs from "./sessions/logs"; + +const initialState = () => ({ + detailCache: {} + }), + wrapItem = (item, {loading = false, loaded = false}) => ({ + item, + loading, + loaded, + error: false, + errMsg: null + }), + populateItem = (item) => { + item._listen = false; + item._listener = null; + item._events = []; + + return item; + }; + +export default { + namespaced: true, + modules: { + logs + }, + state: { + initialState, + ...initialState() + }, + getters: { + byId: (state) => ({id}) => { + if (! state.detailCache[id]) { + Vue.set( + state.detailCache, + id, + wrapItem( + populateItem({ + id + }), + { + loaded: false + } + ) + ); + } + + return state.detailCache[id]; + } + }, + actions: { + alert: ({dispatch}, {content, variant = "danger", kind = "sessionDetail"}) => { + dispatch( + "alerts/add", + { + kind, + payload: { + content, + variant + } + }, + {root: true} + ); + }, + + loadById: async ({getters, rootGetters}, {id, force = false}) => { + const fromCache = getters.byId({id}); + + if (fromCache.loaded && ! force) { + return; + } + + fromCache.loading = true; + + try { + const response = await rootGetters["service/makeApiRequest"](`sessions/${id}`); + + if (! response.ok) { + throw new Error(`Request failed: ${response.status}`); + } + + let body = await response.json(); + + body = populateItem(body); + + fromCache.item = body; + fromCache.loaded = true; + } + catch (ex) { + fromCache.error = true; + fromCache.errMsg = `Failed to load from id: ${ex}`; + } + finally { + fromCache.loading = false; + } + }, + + create: async ({dispatch, state, rootGetters}, {testId, auIndex, launchCfg = {}, launchMode, caller = "testDetail"}) => { + try { + const response = await rootGetters["service/makeApiRequest"]( + `sessions`, + { + method: "POST", + headers: { + "Content-Type": "application/json" + }, + body: JSON.stringify({ + testId, + auIndex, + launchMode, + contextTemplateAdditions: launchCfg.contextTemplateAdditions, + launchParameters: launchCfg.launchParameters, + masteryScore: launchCfg.masteryScore, + moveOn: launchCfg.moveOn, + alternateEntitlementKey: launchCfg.alternateEntitlementKey + }) + } + ); + + let responseBody = await response.json(); + + if (! response.ok) { + throw new Error(`Request failed: ${responseBody.message ? responseBody.message : "no message"} (${response.status}${responseBody.srcError ? " - " + responseBody.srcError : ""})`); + } + responseBody = populateItem(responseBody); + + if (launchCfg.launchMethod) { + responseBody.launchMethod = launchCfg.launchMethod; + } + + Vue.set(state.detailCache, responseBody.id, wrapItem(responseBody, {loaded: true})); + + return responseBody.id; + } + catch (ex) { + dispatch("alert", {content: `Failed to create session: ${ex}`, kind: caller}); + } + + return null; + }, + + abandon: async ({dispatch, rootGetters}, {id}) => { + try { + const response = await rootGetters["service/makeApiRequest"]( + `sessions/${id}/abandon`, + { + method: "POST", + headers: { + "Content-Type": "application/json" + } + } + ); + + if (response.status === 204) { + return; + } + + let responseBody = await response.json(); + + if (! response.ok) { + throw new Error(`Request failed: ${responseBody.message ? responseBody.message : "no message"} (${response.status}${responseBody.srcError ? " - " + responseBody.srcError : ""})`); + } + } + catch (ex) { + dispatch("alert", {content: `Failed to abandon session: ${ex}`, kind: "sessionDetail"}); + } + } + } +}; diff --git a/KST-ASD-BI-101/cts/client/src/store/service/sessions/logs.js b/KST-ASD-BI-101/cts/client/src/store/service/sessions/logs.js new file mode 100644 index 0000000..20241a8 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/store/service/sessions/logs.js @@ -0,0 +1,159 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +/* globals TextDecoderStream, TransformStream */ +import Vue from "vue"; +import "@stardazed/streams-polyfill"; + +const initialState = () => ({ + cacheContainer: {} +}); + +export default { + namespaced: true, + state: { + initialState, + ...initialState() + }, + getters: { + cacheKey: (state) => ({id}) => { + const cacheKey = `key-${id}`; + + if (! state.cacheContainer[cacheKey]) { + Vue.set( + state.cacheContainer, + cacheKey, + { + loaded: false, + loading: false, + items: [], + err: false, + errMsg: "", + listener: null, + listen: false + } + ); + } + + return cacheKey; + }, + + cache: (state) => ({cacheKey}) => state.cacheContainer[cacheKey] + }, + actions: { + load: async ({getters, rootGetters}, {props, force = false} = {}) => { + const cache = getters.cache({cacheKey: getters.cacheKey(props)}), + busyKey = "loading"; + + if (cache.loaded || cache.loading) { + if (! force) { + return; + } + } + + cache[busyKey] = true; + + try { + const response = await rootGetters["service/makeApiRequest"](`sessions/${props.id}/logs`); + + if (! response.ok) { + throw new Error(`Request failed: ${response.status}`); + } + + const body = await response.json(); + + cache.items = body; + cache.loaded = true; + } + catch (ex) { + const content = `Failed to load session logs (${props.id}): ${ex}` + + cache.err = true; + cache.errMsg = content; + } + + // eslint-disable-next-line require-atomic-updates + cache[busyKey] = false; + }, + + startListener: async ({getters, rootGetters}, props) => { + const cacheEntry = getters.cache({cacheKey: getters.cacheKey(props)}), + response = await rootGetters["service/makeApiRequest"](`sessions/${props.id}/logs?listen=true`), + stream = response.body.pipeThrough(new TextDecoderStream()).pipeThrough( + // + // this stream takes the text stream as input, splits the text on \n + // and then JSON parses the lines, providing each chunk of JSON to + // the next handler in the chain + // + new TransformStream( + { + start (controller) { + controller.buf = ""; + controller.pos = 0; + }, + transform (chunk, controller) { + controller.buf += chunk; + + while (controller.pos < controller.buf.length) { + if (controller.buf[controller.pos] === "\n") { + const line = controller.buf.substring(0, controller.pos); + + controller.enqueue(JSON.parse(line)); + + controller.buf = controller.buf.substring(controller.pos + 1); + controller.pos = 0; + } + else { + ++controller.pos; + } + } + } + } + ) + ), + reader = cacheEntry.listener = stream.getReader(); + + cacheEntry.listen = true; + + while (cacheEntry.listen) { // eslint-disable-line no-constant-condition + try { + const {done, value} = await reader.read(); + + cacheEntry.items.unshift(value); + + if (done) { + break; + } + } + catch (ex) { + break; + } + } + }, + + stopListener: async ({getters}, props) => { + const cacheEntry = getters.cache({cacheKey: getters.cacheKey(props)}); + + if (cacheEntry.listener) { + cacheEntry.listen = false; + + await cacheEntry.listener.closed; + cacheEntry.listener.releaseLock(); + + cacheEntry.listener = null; + } + } + } +}; diff --git a/KST-ASD-BI-101/cts/client/src/store/service/tests.js b/KST-ASD-BI-101/cts/client/src/store/service/tests.js new file mode 100644 index 0000000..c97d88e --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/store/service/tests.js @@ -0,0 +1,461 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +import Vue from "vue"; +import logs from "./tests/logs"; + +const initialState = () => ({ + detailCache: {}, + cacheContainer: {}, + defaultKeyProperties: {} + }), + wrapItem = (item, {loading = false, loaded = false}) => ({ + item, + loading, + loaded, + error: false, + errMsg: null + }), + populateItem = (item) => { + item.learnerPrefs = { + _etag: null, + languagePreference: "", + audioPreference: null + }; + + return item; + }; + +export default { + namespaced: true, + modules: { + logs + }, + state: { + initialState, + ...initialState() + }, + getters: { + cacheKey: (state) => ({courseId}) => { + // + // there isn't really a technical reason why we should only be able to pull the list + // of tests based on a course id, but when written the UI only provided for listing + // tests at the course level so this was arbitrarily restricted based on that and the + // service back end only has a route for getting tests under the /courses resource + // + if (typeof courseId === "undefined") { + throw new Error("courseId is a required cache key component"); + } + + const cacheKey = `key-${courseId}`; + + if (! state.cacheContainer[cacheKey]) { + Vue.set( + state.cacheContainer, + cacheKey, + { + loaded: false, + loading: false, + items: [], + currentIndex: null + } + ); + } + + return cacheKey; + }, + + cache: (state) => ({cacheKey}) => state.cacheContainer[cacheKey], + + byId: (state) => ({id}) => { + if (! state.detailCache[id]) { + Vue.set( + state.detailCache, + id, + wrapItem( + populateItem({ + id + }), + { + loaded: false + } + ) + ); + } + + return state.detailCache[id]; + } + }, + actions: { + alert: ({dispatch}, {content, variant = "danger", kind = "testList"}) => { + dispatch( + "alerts/add", + { + kind, + payload: { + content, + variant + } + }, + {root: true} + ); + }, + + loadById: async ({getters, rootGetters}, {id, force = false}) => { + const fromCache = getters.byId({id}); + + if (fromCache.loaded && ! force) { + return; + } + + fromCache.loading = true; + + try { + const response = await rootGetters["service/makeApiRequest"](`tests/${id}`); + + let body = await response.json(); + + if (! response.ok) { + throw new Error(`Request failed: ${body.message} (${response.status})${body.srcError ? " (" + body.srcError + ")" : ""}`); + } + + body = populateItem(body); + + fromCache.item = body; + fromCache.loaded = true; + } + catch (ex) { + fromCache.error = true; + fromCache.errMsg = `Failed to load from id: ${ex}`; + } + finally { + fromCache.loading = false; + } + }, + + load: async ({dispatch, state, getters, rootGetters}, {courseId, props = state.defaultKeyProperties, force = false} = {}) => { + const cache = getters.cache({cacheKey: getters.cacheKey({courseId, ...props})}), + busyKey = "loading"; + + if (cache.loaded || cache.loading) { + if (! force) { + return; + } + + cache.items = cache.items.filter((i) => i.id === null); + } + + cache[busyKey] = true; + + try { + const response = await rootGetters["service/makeApiRequest"](`courses/${courseId}/tests`); + + if (! response.ok) { + throw new Error(`Request failed: ${response.status}`); + } + + const body = await response.json(), + duplicateCheck = cache.items.map((i) => i.id); + + for (const i of body.items) { + if (duplicateCheck.includes(i.id)) { + continue; + } + + i.pending = null; + + cache.items.push(i); + } + + cache.loaded = true; + + for (const i of body.items) { + if (! state.detailCache[i.id]) { + Vue.set( + state.detailCache, + i.id, + wrapItem(populateItem(i), {loaded: true}) + ); + } + } + } + catch (ex) { + const content = `Failed to load tests: ${ex}` + + cache.err = true; + cache.errMsg = content; + + dispatch("alert", {content}); + } + + // eslint-disable-next-line require-atomic-updates + cache[busyKey] = false; + }, + + create: async ({dispatch, state, getters, rootGetters}, {courseId, actor}) => { + const kind = "testNew"; + + try { + const response = await rootGetters["service/makeApiRequest"]( + "tests", + { + method: "POST", + headers: { + "Content-Type": "application/json" + }, + body: JSON.stringify({ + courseId, + actor + }) + } + ); + + let responseBody = await response.json(); + + if (! response.ok) { + throw new Error(`Request failed: ${responseBody.message ? responseBody.message : "no message"} (${response.status}${responseBody.srcError ? " - " + responseBody.srcError : ""})`); + } + responseBody = populateItem(responseBody); + + Vue.set(state.detailCache, responseBody.id, wrapItem(responseBody, {loaded: true})); + + const courseCache = getters.cache({cacheKey: getters.cacheKey({courseId})}); + + courseCache.items.unshift(responseBody); + + return responseBody.id; + } + catch (ex) { + dispatch("alert", {content: `Failed to create test: ${ex}`, kind}); + } + + return null; + }, + + waiveAU: async ({dispatch, rootGetters}, {id, auIndex, reason}) => { + try { + const response = await rootGetters["service/makeApiRequest"]( + `tests/${id}/waive-au/${auIndex}`, + { + method: "POST", + headers: { + "Content-Type": "application/json" + }, + body: JSON.stringify({ + reason + }) + } + ); + + if (response.status === 204) { + dispatch("logs/load", {props: {id}, force: true}); + return; + } + + let responseBody = await response.json(); + + if (! response.ok) { + throw new Error(`Request failed: ${responseBody.message ? responseBody.message : "no message"} (${response.status}${responseBody.srcError ? " - " + responseBody.srcError : ""})`); + } + } + catch (ex) { + dispatch("alert", {content: `Failed to waive AU: ${ex}`, kind: "testDetail"}); + } + }, + + loadLearnerPrefs: async ({getters, dispatch, rootGetters}, {id}) => { + try { + const test = getters.byId({id}), + response = await rootGetters["service/makeApiRequest"]( + `tests/${id}/learner-prefs`, + { + method: "GET" + } + ); + + if (response.status === 404) { + test.item.learnerPrefs._etag = null; + test.item.learnerPrefs.languagePreference = ""; + test.item.learnerPrefs.audioPreference = null; + + return; + } + + let responseBody = await response.json(); + + if (! response.ok) { + throw new Error(`Request failed: ${responseBody.message ? responseBody.message : "no message"} (${response.status}${responseBody.srcError ? " - " + responseBody.srcError : ""})`); + } + + test.item.learnerPrefs._etag = response.headers.get("etag") || null; + test.item.learnerPrefs.languagePreference = responseBody.languagePreference; + test.item.learnerPrefs.audioPreference = responseBody.audioPreference; + } + catch (ex) { + dispatch("alert", {content: `Failed to load learner preferences: ${ex}`, kind: "testDetail"}); + } + }, + + saveLearnerPrefs: async ({getters, dispatch, rootGetters}, {id}) => { + const test = getters.byId({id}); + + try { + const response = await rootGetters["service/makeApiRequest"]( + `tests/${id}/learner-prefs`, + { + method: "POST", + headers: { + "Content-Type": "application/json", + ...(test.item.learnerPrefs._etag === null ? {"If-None-Match": "*"} : {"If-Match": test.item.learnerPrefs._etag}) + }, + body: JSON.stringify({ + languagePreference: test.item.learnerPrefs.languagePreference, + audioPreference: test.item.learnerPrefs.audioPreference + }) + } + ); + + if (response.status === 204) { + // + // after successfully saving the preferences the Etag is out of date, and rather than + // trying to calculate it client side for the new value, just fetch the preferences + // again to get the new Etag + // + dispatch("loadLearnerPrefs", {id}); + + dispatch("alert", {content: `Agent preferences saved`, kind: "testDetail", variant: "success"}); + + return; + } + + let responseBody = await response.json(); + + if (! response.ok) { + throw new Error(`Request failed: ${responseBody.message ? responseBody.message : "no message"} (${response.status}${responseBody.srcError ? " - " + responseBody.srcError : ""})`); + } + } + catch (ex) { + dispatch("alert", {content: `Failed to save learner preferences: ${ex}`, kind: "testDetail"}); + } + }, + + clearLearnerPrefs: async ({getters, dispatch, rootGetters}, {id}) => { + const test = getters.byId({id}); + + try { + const response = await rootGetters["service/makeApiRequest"]( + `tests/${id}/learner-prefs`, + { + method: "DELETE", + headers: { + "Content-Type": "application/json", + "If-Match": test.item.learnerPrefs._etag + } + } + ); + + if (response.status === 204) { + test.item.learnerPrefs.languagePreference = ""; + test.item.learnerPrefs.audioPreference = null; + test.item.learnerPrefs._etag = null; + + dispatch("alert", {content: `Agent preferences cleared`, kind: "testDetail", variant: "success"}); + + return; + } + + let responseBody = await response.json(); + + if (! response.ok) { + throw new Error(`Request failed: ${responseBody.message ? responseBody.message : "no message"} (${response.status}${responseBody.srcError ? " - " + responseBody.srcError : ""})`); + } + } + catch (ex) { + dispatch("alert", {content: `Failed to clear learner preferences: ${ex}`, kind: "testDetail"}); + } + }, + + triggerDownload: async ({getters, dispatch, rootGetters}, {id}) => { + await dispatch("loadById", {id, force: true}); + await dispatch("logs/load", {props: {id}, force: true}); + + const test = getters.byId({id}).item, + logs = getters["logs/cache"]({cacheKey: getters["logs/cacheKey"]({id})}), + code = test.code, + sessionCreationItems = logs.items.filter((item) => (item.metadata && item.metadata.resource === "sessions:create")), + sessionLoadPromises = []; + + for (const item of sessionCreationItems) { + sessionLoadPromises.push(dispatch("service/sessions/loadById", {id: item.metadata.sessionId, force: true}, {root: true})); + sessionLoadPromises.push(dispatch("service/sessions/logs/load", {props: {id: item.metadata.sessionId}, force: true}, {root: true})); + } + + await Promise.all(sessionLoadPromises); + + const fileContents = { + id, + code, + dateCreated: new Date().toJSON(), + metadata: test.metadata + }, + + // + // this is a little unorthodox/odd for a service to be performing but it + // makes some sort of sense because this service action can be dispatched + // by multiple components, and since the element handling is really outside + // of the scope of what Vue should be expected to provide it mostly doesn't + // matter where we put it, it'll be odd anywhere else too + // + element = document.createElement("a"); + + fileContents.logs = logs.items.map( + (logItem) => { + const result = { + ...logItem + }; + + if (logItem.metadata && logItem.metadata.resource === "sessions:create") { + result.session = { + metadata: rootGetters["service/sessions/byId"]({id: logItem.metadata.sessionId}).item.metadata, + // create a new array so that it can be inplace sorted + logs: [ + ...rootGetters["service/sessions/logs/cache"]( + { + cacheKey: rootGetters["service/sessions/logs/cacheKey"]({id: logItem.metadata.sessionId}) + } + ).items + ] + }; + + result.session.logs.sort((a, b) => a.id - b.id); + } + + return result; + } + ); + + fileContents.logs.sort((a, b) => a.id - b.id); + + element.setAttribute("href", "data:text/plain;charset=utf-8," + JSON.stringify(fileContents, null, 2)); // eslint-disable-line no-magic-numbers + element.setAttribute("download", `catapult-cts-${code}.json`); + + element.style.display = "none"; + document.body.appendChild(element); + + element.click(); + document.body.removeChild(element); + } + } +}; diff --git a/KST-ASD-BI-101/cts/client/src/store/service/tests/logs.js b/KST-ASD-BI-101/cts/client/src/store/service/tests/logs.js new file mode 100644 index 0000000..3c87b64 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/store/service/tests/logs.js @@ -0,0 +1,87 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +import Vue from "vue"; + +const initialState = () => ({ + cacheContainer: {} +}); + +export default { + namespaced: true, + state: { + initialState, + ...initialState() + }, + getters: { + cacheKey: (state) => ({id}) => { + const cacheKey = `key-${id}`; + + if (! state.cacheContainer[cacheKey]) { + Vue.set( + state.cacheContainer, + cacheKey, + { + loaded: false, + loading: false, + items: [], + err: false, + errMsg: "" + } + ); + } + + return cacheKey; + }, + + cache: (state) => ({cacheKey}) => state.cacheContainer[cacheKey] + }, + actions: { + load: async ({getters, rootGetters}, {props, force = false} = {}) => { + const cache = getters.cache({cacheKey: getters.cacheKey(props)}), + busyKey = "loading"; + + if (cache.loaded || cache.loading) { + if (! force) { + return; + } + } + + cache[busyKey] = true; + + try { + const response = await rootGetters["service/makeApiRequest"](`tests/${props.id}/logs`); + + if (! response.ok) { + throw new Error(`Request failed: ${response.status}`); + } + + const body = await response.json(); + + cache.items = body; + cache.loaded = true; + } + catch (ex) { + const content = `Failed to load session logs (${props.id}): ${ex}` + + cache.err = true; + cache.errMsg = content; + } + + // eslint-disable-next-line require-atomic-updates + cache[busyKey] = false; + } + } +}; diff --git a/KST-ASD-BI-101/cts/client/src/store/service/users.js b/KST-ASD-BI-101/cts/client/src/store/service/users.js new file mode 100644 index 0000000..2cc0006 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/store/service/users.js @@ -0,0 +1,259 @@ +/* + Copyright 2020 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +import Vue from "vue"; + +const initialState = () => ({ + detailCache: {}, + cacheContainer: {}, + defaultKeyProperties: {} + }), + wrapItem = (item, {loading = false, loaded = false}) => ({ + item, + loading, + loaded, + error: false, + errMsg: null + }), + populateItem = (item) => { + return item; + }; + +export default { + namespaced: true, + state: { + initialState, + ...initialState() + }, + getters: { + cacheKey: (state) => () => { + const cacheKey = "key"; + + if (! state.cacheContainer[cacheKey]) { + Vue.set( + state.cacheContainer, + cacheKey, + { + loaded: false, + loading: false, + items: [], + currentIndex: null + } + ); + } + + return cacheKey; + }, + defaultCacheKey: (state, getters) => getters.cacheKey({props: state.defaultKeyProperties}), + + cache: (state) => ({cacheKey}) => state.cacheContainer[cacheKey], + defaultCache: (state, getters) => getters.cache({cacheKey: getters.defaultCacheKey}), + + byId: (state) => ({id}) => { + if (! state.detailCache[id]) { + Vue.set( + state.detailCache, + id, + wrapItem( + populateItem({ + id + }), + { + loaded: false + } + ) + ); + } + + return state.detailCache[id]; + } + }, + actions: { + alert: ({dispatch}, {content, variant = "danger", kind = "adminUserList"}) => { + dispatch( + "alerts/add", + { + kind, + payload: { + content, + variant + } + }, + {root: true} + ); + }, + + loadById: async ({getters, rootGetters}, {id, force = false}) => { + const fromCache = getters.byId({id}); + + if (fromCache.loaded && ! force) { + return; + } + + fromCache.loading = true; + + try { + const response = await rootGetters["service/makeApiRequest"](`users/${id}`); + + if (! response.ok) { + throw new Error(`Request failed: ${response.status}`); + } + + const body = await response.json(); + + fromCache.item = populateItem(body); + fromCache.loaded = true; + } + catch (ex) { + fromCache.error = true; + fromCache.errMsg = `Failed to load from id: ${ex}`; + } + finally { + fromCache.loading = false; + } + }, + + load: async ({dispatch, state, getters, rootGetters}, {props = state.defaultKeyProperties, force = false} = {}) => { + const cache = getters.cache({cacheKey: getters.cacheKey({props})}), + busyKey = "loading"; + + if (cache.loaded || cache.loading) { + if (! force) { + return; + } + + cache.items = cache.items.filter((i) => i.id === null); + } + + cache[busyKey] = true; + + try { + const response = await rootGetters["service/makeApiRequest"]("users"), + lastNewItemIndex = cache.items.findIndex((i) => i.id !== null); + + if (! response.ok) { + throw new Error(`Request failed: ${response.status}`); + } + + const body = await response.json(); + + cache.items.splice( + lastNewItemIndex === -1 ? cache.items.length : lastNewItemIndex + 1, + 0, + ...body.items + ); + cache.loaded = true; + + for (const i of body.items) { + if (! state.detailCache[i.id]) { + Vue.set( + state.detailCache, + i.id, + wrapItem(i, {loaded: true}) + ); + } + } + } + catch (ex) { + const content = `Failed to load users: ${ex}` + + cache.err = true; + cache.errMsg = content; + + dispatch("alert", {content}); + } + + // eslint-disable-next-line require-atomic-updates + cache[busyKey] = false; + }, + + delete: async ({dispatch, getters, rootGetters}, {item}) => { + const cache = getters.defaultCache, + itemIndex = cache.items.findIndex((i) => i === item); + + try { + const response = await rootGetters["service/makeApiRequest"]( + `users/${item.id}`, + { + method: "DELETE", + mode: "cors" + } + ); + + if (response.ok) { + if (itemIndex !== -1) { + cache.items.splice(itemIndex, 1); + + if (cache.currentIndex === itemIndex) { + cache.currentIndex = null; + } + } + } + else { + const body = await response.json(); + + throw new Error(`${response.status} - ${body.message}`); + } + } + catch (ex) { + dispatch("alert", {content: `Failed to delete user (id: ${item.id}): ${ex}`}); + + return false; + } + + return true; + }, + + create: async ({dispatch, state, getters, rootGetters}, {username, password, roles = []}) => { + try { + const response = await rootGetters["service/makeApiRequest"]( + "users", + { + method: "POST", + mode: "cors", + headers: { + "Content-Type": "application/json" + }, + body: JSON.stringify({ + username, + password, + roles + }) + } + ); + + let responseBody = await response.json(); + + if (! response.ok) { + throw new Error(`Request failed: ${responseBody.message ? responseBody.message : "no message"} (${response.status})`); + } + + responseBody = populateItem(responseBody); + + Vue.set(state.detailCache, responseBody.id, wrapItem(responseBody, {loaded: true})); + getters.cache({cacheKey: getters.cacheKey()}).items.unshift(responseBody); + + dispatch("alert", {content: `User created: ${responseBody.id}`, kind: "success"}); + + return responseBody.id; + } + catch (ex) { + dispatch("alert", {content: `Failed to create user: ${ex}`}); + } + + return null; + } + } +}; diff --git a/KST-ASD-BI-101/cts/client/src/styles/custom-vars.scss b/KST-ASD-BI-101/cts/client/src/styles/custom-vars.scss new file mode 100644 index 0000000..0be1206 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/src/styles/custom-vars.scss @@ -0,0 +1,73 @@ +/* + Copyright 2020 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ + +// These are the closest USWDS "cool gray" colors to our own cool grayscale. +// Which really aren't all that close (ours are a bit more blue). Oh well. +$white: #fff; +$gray-100: #fbfcfd; +$gray-200: #f1f3f6; +$gray-300: #dfe1e2; +$gray-400: #c6cace; +$gray-500: #a9aeb1; +$gray-600: #71767a; +$gray-700: #565c65; +$gray-800: #2d2e2f; +$gray-900: #1c1d1f; +$black: #000; + +// The Bootstrap rainbow, using Rustici-ish colors from the USWDS palette. +// We don't have all of these colors in the Rustici palette (e.g., yellow), +// so I interpolated them from adjacent colors, did some manual adjustment, +// and picked the nearest USWDS colors that I could find. +$blue: #345d96; +$indigo: #5e519e; +$purple: #864381; +$pink: #d72d79; +$red: #e52207; +$orange: #fa9441; +$yellow: #face00; +$green: #008817; +$teal: #5abf95; +$cyan: #5dc0d1; + +// Theme colors. We mostly follow Bootstrap's lead here, except for using +// a slightly different grey for $dark. +$primary: $blue; +$secondary: $gray-600; +$success: $green; +$info: $cyan; +$warning: $yellow; +$danger: $red; +$light: $gray-100; +$dark: $gray-800; + +// Accessibility tweaks: +// - According to the Bootstrap docs[1], the colors in the default palette lead +// to insufficient contrast for WCAG 2.0 guidelines when used against a light +// background. Since our colors aren't too far off from the defaults, we may +// have to adjust some of the color scaling values to compensate. +// +// - Make sure that links are always underlined[2]. Otherwise, we'd need to +// ensure that there is a 3:1 contrast between body text and link text, on +// top of the standard 4.5:1 text contrast requirement. And we'd have to add +// an underline on hover or mouse focus anyway. +// +// [1]: https://getbootstrap.com/docs/4.5/getting-started/accessibility/ +// [2]: https://webaim.org/articles/contrast/#only +$text-muted: $gray-700; +$link-decoration: underline; + + diff --git a/KST-ASD-BI-101/cts/client/vue.config.js b/KST-ASD-BI-101/cts/client/vue.config.js new file mode 100644 index 0000000..be7ee61 --- /dev/null +++ b/KST-ASD-BI-101/cts/client/vue.config.js @@ -0,0 +1,26 @@ +module.exports = { + publicPath: "./", + devServer: { + port: 3396 + }, + css: { + loaderOptions: { + scss: { + // + // make all of our custom variables available in the style + // blocks of all of the components without importing in each + // + additionalData: `@import "~@/styles/custom-vars.scss";` + } + } + }, + chainWebpack: (config) => { + config.plugin("html").tap( + (args) => { + args[0].title = "Catapult: CTS" + + return args; + } + ); + } +}; diff --git a/KST-ASD-BI-101/cts/docker-compose.client-dev.yml b/KST-ASD-BI-101/cts/docker-compose.client-dev.yml new file mode 100755 index 0000000..95c77a6 --- /dev/null +++ b/KST-ASD-BI-101/cts/docker-compose.client-dev.yml @@ -0,0 +1,21 @@ +# Copyright 2021 Rustici Software +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +version: "3.8" +services: + client: + build: client/ + ports: + - 3396:3396 + volumes: + - ./client:/usr/src/app/src:ro diff --git a/KST-ASD-BI-101/cts/docker-compose.yml b/KST-ASD-BI-101/cts/docker-compose.yml new file mode 100644 index 0000000..e8f9dd0 --- /dev/null +++ b/KST-ASD-BI-101/cts/docker-compose.yml @@ -0,0 +1,154 @@ +# Copyleft 2024 Kusala Tech +# +# Licensed under the GNU General Public License v3.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# +# https://www.gnu.org/licenses/gpl-3.0.en.html +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on +# an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +# Copyright 2020 Rustici Software +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +services: + nginx: + restart: always + build: + context: nginx + args: + HOSTNAME: "${HOSTNAME}" + ports: + - "80:80" + container_name: docker_nginx + networks: + - public + + # certbot: + # container_name: 'docker_certbot' + # image: certbot/certbot + # volumes: + # - ./keys:/var/lib/letsencrypt + # - ./nginx/letsencrypt:/data/letsencrypt + # - ./certbot/etc:/etc/letsencrypt + # - ./certbot/log:/var/log/letsencrypt + # depends_on: + # - nginx + # networks: + # - public + + webservice: + build: . + container_name: docker_cts + restart: always # Deprecated but still available old auth method. + ports: + - 127.0.0.1:3399:3399 + depends_on: + - rdbms + volumes: + - ./service/index.js:/usr/src/app/index.js:ro + - ./service/knexfile.js:/usr/src/app/knexfile.js:ro + - ./service/plugins:/usr/src/app/plugins:ro + - ./service/lib:/usr/src/app/lib:ro + - ./migrations:/usr/src/app/migrations:ro + - ./seeds:/usr/src/app/seeds:ro + environment: + - HOSTNAME + - DB_HOST + - DB_NAME=catapult_cts + - DB_USERNAME + - DB_PASSWORD + # - DATABASE_USER=catapult + # - DATABASE_USER_PASSWORD=quartz + # - DATABASE_NAME=catapult_cts + - PLAYER_BASE_URL + - PLAYER_KEY + - PLAYER_SECRET + - NODE_TLS_REJECT_UNAUTHORIZED + - LRS_ENDPOINT + - LRS_USERNAME + - LRS_PASSWORD + - LRS_XAPI_VERSION + - CTS_SESSION_COOKIE_PASSWORD + networks: + - public + + player: + image: adlhub/player + container_name: docker_player + restart: always + depends_on: + - rdbms + ports: + - 127.0.0.1:3398:3398 + volumes: + # - ../migrations:/usr/src/app/migrations:ro + # - ../seeds:/usr/src/app/seeds:ro + - ../:/usr/src/app/content # FIXME: Less than ideal - fix as we make contributions back to ADLNet + environment: + - HOSTNAME + - DATABASE_USER=${DB_USERNAME} + - DATABASE_USER_PASSWORD=${DB_PASSWORD} + - DATABASE_NAME=${DB_NAME} + - CONTENT_URL=${PLAYER_CONTENT_URL} + - LRS_ENDPOINT + - LRS_USERNAME + - LRS_PASSWORD + - LRS_XAPI_VERSION + - TOKEN_SECRET=${PLAYER_TOKEN_SECRET} + - API_KEY=${PLAYER_KEY} + - API_SECRET=${PLAYER_SECRET} + - PLAYER_API_ROOT=${PLAYER_ROOT_PATH} + - PLAYER_STANDALONE_LAUNCH_URL_BASE + networks: + - public + + rdbms: + image: mysql:8.0.27 # Deprecated but still available old auth method. + container_name: mysql + restart: always + volumes: + - catapult-cts-data:/var/lib/mysql + - ./init_db.sh:/docker-entrypoint-initdb.d/init_db.sh:ro + environment: + - MYSQL_RANDOM_ROOT_PASSWORD=yes + - DATABASE_USER=${DB_USERNAME} + - DATABASE_USER_PASSWORD=${DB_PASSWORD} + - DATABASE_NAME=catapult_cts + - PLAYER_DATABASE_NAME=catapult_player + command: [ + "mysqld", + + # provide for full UTF-8 support + "--character-set-server=utf8mb4", + "--collation-server=utf8mb4_unicode_ci", + + # need the following because the mysql.js client lib doesn't yet support + # the newer default scheme used in MySQL 8.x + "--default-authentication-plugin=mysql_native_password" + ] + networks: + - public + +volumes: + catapult-cts-data: + +networks: + public: + driver: bridge diff --git a/KST-ASD-BI-101/cts/entrypoint.sh b/KST-ASD-BI-101/cts/entrypoint.sh new file mode 100755 index 0000000..b4deb1b --- /dev/null +++ b/KST-ASD-BI-101/cts/entrypoint.sh @@ -0,0 +1,24 @@ +#!/bin/sh + +# Copyright 2021 Rustici Software +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +if [ RUN_MIGRATIONS ]; then + node node_modules/.bin/knex migrate:latest +fi + +# legacy-watch is used because it improves auto restart in our specific +# use case for development, mounted volume in container, see "Application +# isn't restarting" in the docs +exec nodemon --legacy-watch --watch index.js --watch knexfile.js --watch lib --watch plugins index.js diff --git a/KST-ASD-BI-101/cts/init-ssl.sh b/KST-ASD-BI-101/cts/init-ssl.sh new file mode 100755 index 0000000..394fb8e --- /dev/null +++ b/KST-ASD-BI-101/cts/init-ssl.sh @@ -0,0 +1,14 @@ +#!/bin/bash + +mkdir -p ./certbot/etc/live/$1 + +echo "[SSL] Ensured Certbot SSL Directory" + +cp ./certbot/local/fullchain.pem ./certbot/etc/live/$1/fullchain.pem + +echo "[SSL] Copied temporary SSL Cert to ./certbot/etc/live/$1/fullchain.pem" + +cp ./certbot/local/privkey.pem ./certbot/etc/live/$1/privkey.pem + +echo "[SSL] Copied temporary SSL Key to ./certbot/etc/live/$1/privkey.pem" +echo "" diff --git a/KST-ASD-BI-101/cts/init_db.sh b/KST-ASD-BI-101/cts/init_db.sh new file mode 100755 index 0000000..68402f1 --- /dev/null +++ b/KST-ASD-BI-101/cts/init_db.sh @@ -0,0 +1,28 @@ +#!/bin/bash + +# Copyright 2021 Rustici Software +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +echo "Creating Catapult CTS Database: '$DATABASE_NAME', Player Database: '$PLAYER_DATABASE_NAME' and User: '$DATABASE_USER'"; +mysql --user=root --password=$MYSQL_ROOT_PASSWORD << END + +CREATE DATABASE IF NOT EXISTS $DATABASE_NAME; +CREATE DATABASE IF NOT EXISTS $PLAYER_DATABASE_NAME; + +CREATE USER '$DATABASE_USER'@'%' IDENTIFIED BY '$DATABASE_USER_PASSWORD'; +GRANT ALL PRIVILEGES ON $DATABASE_NAME.* TO '$DATABASE_USER'@'%'; +GRANT ALL PRIVILEGES ON $PLAYER_DATABASE_NAME.* TO '$DATABASE_USER'@'%'; +FLUSH PRIVILEGES; + +END diff --git a/KST-ASD-BI-101/cts/install-reqs.sh b/KST-ASD-BI-101/cts/install-reqs.sh new file mode 100755 index 0000000..3ad0184 --- /dev/null +++ b/KST-ASD-BI-101/cts/install-reqs.sh @@ -0,0 +1,68 @@ +#!/bin/bash + +# Simple script to install the PERLS architecture requirements +function announce() { + echo "" + echo "#====================================================#" + echo "#" + echo "# Installing $1" + echo "#" + echo "#====================================================#" +} + +# Curl +# +announce "Curl" + +if ! [ -x "$(command -v curl)" ]; then + + # Curl is easy + apt-get install curl + +else + echo "Skipping, Curl already installed!" +fi + +# Docker +# +announce "Docker" + +if ! [ -x "$(command -v docker)" ]; then + + # Docker is a bit complicated + # + # Add the GPG Key + curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - + + # Add the Docker repository to our APT sources + add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" + + # With those added, update our packages + apt-get update + + # Since we're up to date, get docker + apt-get install -y docker-ce +else + echo "Skipping, docker already installed!" +fi + + +# Docker-Compose +# +announce "Docker-Compose" + +if ! [ -x "$(command -v docker-compose)" ]; then + + # Docker-Compose is also complicated + # + # Add the GPG Key + curl -L https://github.com/docker/compose/releases/download/1.18.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose + + # Make sure it's executable + chmod +x /usr/local/bin/docker-compose + +else + echo "Skipping, docker-compose already installed!" +fi + +echo "" diff --git a/KST-ASD-BI-101/cts/migrations/010-table-tenants.js b/KST-ASD-BI-101/cts/migrations/010-table-tenants.js new file mode 100644 index 0000000..ea0f641 --- /dev/null +++ b/KST-ASD-BI-101/cts/migrations/010-table-tenants.js @@ -0,0 +1,30 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +const tableName = "tenants"; + +exports.up = async (knex) => { + await knex.schema.createTable( + tableName, + (table) => { + table.increments("id"); + table.timestamp("created_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP")); + table.timestamp("updated_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP")); + table.string("code").notNullable().unique(); + table.integer("player_tenant_id").notNullable(); + } + ); +}; +exports.down = (knex) => knex.schema.dropTable(tableName); diff --git a/KST-ASD-BI-101/cts/migrations/020-table-users.js b/KST-ASD-BI-101/cts/migrations/020-table-users.js new file mode 100644 index 0000000..ec5305e --- /dev/null +++ b/KST-ASD-BI-101/cts/migrations/020-table-users.js @@ -0,0 +1,33 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +const tableName = "users"; + +exports.up = async (knex) => { + await knex.schema.createTable( + tableName, + (table) => { + table.increments("id"); + table.timestamp("created_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP")); + table.timestamp("updated_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP")); + table.integer("tenant_id").unsigned().notNullable().references("id").inTable("tenants").onUpdate("CASCADE").onDelete("RESTRICT"); + table.string("username").notNullable().unique(); + table.string("password").notNullable(); + table.text("player_api_token"); + table.json("roles").notNullable(); + } + ); +}; +exports.down = (knex) => knex.schema.dropTable(tableName); diff --git a/KST-ASD-BI-101/cts/migrations/030-table-courses.js b/KST-ASD-BI-101/cts/migrations/030-table-courses.js new file mode 100644 index 0000000..f69b242 --- /dev/null +++ b/KST-ASD-BI-101/cts/migrations/030-table-courses.js @@ -0,0 +1,29 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +const tableName = "courses"; + +exports.up = (knex) => knex.schema.createTable( + tableName, + (table) => { + table.increments("id"); + table.timestamp("created_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP")); + table.timestamp("updated_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP")); + table.integer("tenant_id").unsigned().notNullable().references("id").inTable("tenants").onUpdate("CASCADE").onDelete("RESTRICT"); + table.integer("player_id").unsigned().notNullable().unique(); + table.json("metadata").notNullable(); + } +); +exports.down = (knex) => knex.schema.dropTable(tableName); diff --git a/KST-ASD-BI-101/cts/migrations/040-table-registrations.js b/KST-ASD-BI-101/cts/migrations/040-table-registrations.js new file mode 100644 index 0000000..b17be3c --- /dev/null +++ b/KST-ASD-BI-101/cts/migrations/040-table-registrations.js @@ -0,0 +1,32 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +const tableName = "registrations"; + +exports.up = (knex) => knex.schema.createTable( + tableName, + (table) => { + table.increments("id"); + table.timestamp("created_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP")); + table.timestamp("updated_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP")); + table.integer("tenant_id").unsigned().notNullable().references("id").inTable("tenants").onUpdate("CASCADE").onDelete("RESTRICT"); + table.integer("player_id").unsigned().notNullable().unique(); + table.integer("course_id").unsigned().notNullable().references("id").inTable("courses").onUpdate("CASCADE").onDelete("CASCADE"); + table.string("code").notNullable().unique(); + + table.json("metadata").notNullable(); + } +); +exports.down = (knex) => knex.schema.dropTable(tableName); diff --git a/KST-ASD-BI-101/cts/migrations/045-table-registrations_logs.js b/KST-ASD-BI-101/cts/migrations/045-table-registrations_logs.js new file mode 100644 index 0000000..6cb8d37 --- /dev/null +++ b/KST-ASD-BI-101/cts/migrations/045-table-registrations_logs.js @@ -0,0 +1,30 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +const tableName = "registrations_logs"; + +exports.up = (knex) => knex.schema.createTable( + tableName, + (table) => { + table.increments("id"); + table.timestamp("created_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP")); + table.timestamp("updated_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP")); + table.integer("tenant_id").notNullable().unsigned().references("id").inTable("tenants").onUpdate("CASCADE").onDelete("RESTRICT"); + table.integer("registration_id").notNullable().unsigned().references("id").inTable("registrations").onUpdate("CASCADE").onDelete("CASCADE"); + + table.json("metadata").notNullable(); + } +); +exports.down = (knex) => knex.schema.dropTable(tableName); diff --git a/KST-ASD-BI-101/cts/migrations/050-table-sessions.js b/KST-ASD-BI-101/cts/migrations/050-table-sessions.js new file mode 100644 index 0000000..5104440 --- /dev/null +++ b/KST-ASD-BI-101/cts/migrations/050-table-sessions.js @@ -0,0 +1,36 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +const tableName = "sessions"; + +exports.up = (knex) => knex.schema.createTable( + tableName, + (table) => { + table.increments("id"); + table.timestamp("created_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP")); + table.timestamp("updated_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP")); + table.integer("tenant_id").unsigned().notNullable().references("id").inTable("tenants").onUpdate("CASCADE").onDelete("RESTRICT"); + table.integer("player_id").unsigned().notNullable().unique(); + table.integer("registration_id").unsigned().notNullable().references("id").inTable("registrations").onUpdate("CASCADE").onDelete("CASCADE"); + table.integer("au_index").unsigned().notNullable(); + + table.text("player_au_launch_url").notNullable(); + table.text("player_endpoint").notNullable(); + table.text("player_fetch").notNullable(); + + table.json("metadata").notNullable(); + } +); +exports.down = (knex) => knex.schema.dropTable(tableName); diff --git a/KST-ASD-BI-101/cts/migrations/055-table-sessions_logs.js b/KST-ASD-BI-101/cts/migrations/055-table-sessions_logs.js new file mode 100644 index 0000000..4930bd2 --- /dev/null +++ b/KST-ASD-BI-101/cts/migrations/055-table-sessions_logs.js @@ -0,0 +1,30 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +const tableName = "sessions_logs"; + +exports.up = (knex) => knex.schema.createTable( + tableName, + (table) => { + table.increments("id"); + table.timestamp("created_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP")); + table.timestamp("updated_at").notNullable().defaultTo(knex.raw("CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP")); + table.integer("tenant_id").notNullable().unsigned().references("id").inTable("tenants").onUpdate("CASCADE").onDelete("RESTRICT"); + table.integer("session_id").notNullable().unsigned().references("id").inTable("sessions").onUpdate("CASCADE").onDelete("CASCADE"); + + table.json("metadata").notNullable(); + } +); +exports.down = (knex) => knex.schema.dropTable(tableName); diff --git a/KST-ASD-BI-101/cts/nginx/Dockerfile b/KST-ASD-BI-101/cts/nginx/Dockerfile new file mode 100644 index 0000000..8612ab9 --- /dev/null +++ b/KST-ASD-BI-101/cts/nginx/Dockerfile @@ -0,0 +1,15 @@ +FROM nginx:alpine + +ARG HOSTNAME + +# Move our configuration into place +# +COPY default.conf /etc/nginx/nginx.conf +#COPY default.conf /etc/nginx/conf.d/default.conf +COPY proxy_headers.conf /etc/nginx/proxy_headers.conf + +# Swap our environment variables +# +RUN cat /etc/nginx/nginx.conf | envsubst '$HOSTNAME' | tee /tmp/nginx.conf +RUN mv /tmp/nginx.conf /etc/nginx/nginx.conf + diff --git a/KST-ASD-BI-101/cts/nginx/default.conf b/KST-ASD-BI-101/cts/nginx/default.conf new file mode 100644 index 0000000..3f12b3f --- /dev/null +++ b/KST-ASD-BI-101/cts/nginx/default.conf @@ -0,0 +1,48 @@ +worker_processes 5; + +events { + worker_connections 1024; +} + +http { + include mime.types; + default_type application/octet-stream; + sendfile on; + keepalive_timeout 65; + + proxy_buffer_size 128k; + proxy_buffers 4 256k; + proxy_busy_buffers_size 256k; + + client_body_in_file_only clean; + client_body_buffer_size 32; + + client_max_body_size 300M; + + server { + listen 80; + server_name $HOSTNAME; + + client_body_in_file_only clean; + client_body_buffer_size 32K; + + client_max_body_size 300M; + + sendfile on; + + send_timeout 300; + proxy_connect_timeout 300; + proxy_send_timeout 300; + proxy_read_timeout 300; + + location / { + include proxy_headers.conf; + proxy_pass http://webservice:3399; + } + + location /player { + include proxy_headers.conf; + proxy_pass http://player:3398/player; + } + } +} diff --git a/KST-ASD-BI-101/cts/nginx/proxy_headers.conf b/KST-ASD-BI-101/cts/nginx/proxy_headers.conf new file mode 100644 index 0000000..aba631c --- /dev/null +++ b/KST-ASD-BI-101/cts/nginx/proxy_headers.conf @@ -0,0 +1,8 @@ +proxy_set_header Host $server_name; +proxy_set_header X-Real-IP $remote_addr; +proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; +proxy_set_header X-Forwarded-Proto https; +proxy_set_header X-Forwarded-Port 443; +add_header Front-End-Https on; +proxy_pass_header Set-Cookie; +proxy_redirect off; diff --git a/KST-ASD-BI-101/cts/service/index.js b/KST-ASD-BI-101/cts/service/index.js new file mode 100644 index 0000000..dd4a448 --- /dev/null +++ b/KST-ASD-BI-101/cts/service/index.js @@ -0,0 +1,307 @@ +/* + Copyright 2020 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +"use strict"; + +const Hapi = require("@hapi/hapi"), + H2o2 = require("@hapi/h2o2"), + Inert = require("@hapi/inert"), + Vision = require("@hapi/vision"), + AuthBasic = require("@hapi/basic"), + AuthCookie = require("@hapi/cookie"), + Bcrypt = require("bcrypt"), + waitPort = require("wait-port"), + { AUTH_TTL_SECONDS } = require("./lib/consts"), + { + PLAYER_BASE_URL: PLAYER_BASE_URL = "http://player:3398", + PLAYER_KEY, + PLAYER_SECRET, + LRS_ENDPOINT, + LRS_USERNAME, + LRS_PASSWORD + } = process.env; + +const provision = async () => { + const server = Hapi.server( + { + host: process.argv[3], + port: process.argv[2] || 3399, + routes: { + cors: { + credentials: true + }, + response: { + emptyStatusCode: 204 + } + } + } + ), + sigHandler = async (signal) => { + try { + const db = server.app.db; + + await server.stop({timeout: 10000}); + + await db.destroy(); + + console.log(`Catapult CTS service stopped (${signal})`); + process.exit(0); + } + catch (ex) { + console.log(`Catapult CTS service failed to stop gracefully (${signal}): terminating the process`, ex); + process.exit(1); + } + }; + + const DB_HOST = (process.env.DB_HOST || "rdbms"); + await waitPort({host: DB_HOST, port: 3306}); + + const db = await require("./lib/db")(); + + server.app = { + player: { + baseUrl: PLAYER_BASE_URL, + key: PLAYER_KEY, + secret: PLAYER_SECRET + }, + db + }; + + server.ext( + "onPreResponse", + (req, h) => { + if (req.response.isBoom) { + if (req.response.output.statusCode === 500) { + req.response.output.payload.srcError = req.response.message; + } + } + + return h.continue; + } + ); + + await server.register(H2o2); + await server.register(Inert); + await server.register(AuthBasic); + await server.register(AuthCookie); + + await server.register( + [ + Vision, + { + plugin: require("hapi-swagger"), + options: { + basePath: "/api/v1", + pathPrefixSize: 3, + info: { + title: "Catapult CTS API" + } + } + } + ] + ); + + server.method( + "lrsWreckDefaults", + (req) => ({ + baseUrl: LRS_ENDPOINT.endsWith("/") ? LRS_ENDPOINT : LRS_ENDPOINT + "/", + headers: { + "X-Experience-API-Version": (process.env.LRS_XAPI_VERSION || "1.0.3"), + Authorization: `Basic ${Buffer.from(`${LRS_USERNAME}:${LRS_PASSWORD}`).toString("base64")}` + }, + json: true + }), + { + generateKey: (req) => `${LRS_ENDPOINT}-${LRS_USERNAME}-${LRS_PASSWORD}`, + cache: { + expiresIn: 60000, + generateTimeout: 1000 + } + } + ); + + server.method( + "getCredentials", + (user) => { + const expiresAt = new Date(); + + expiresAt.setSeconds(expiresAt.getSeconds() + AUTH_TTL_SECONDS); + + return { + id: user.id, + tenantId: user.tenantId, + username: user.username, + roles: user.roles, + expiresAt + }; + }, + { + generateKey: (user) => user.id.toString(), + cache: { + expiresIn: 60000, + generateTimeout: 1000 + } + } + ); + server.method( + "basicAuthValidate", + async (req, username, password) => { + const user = await req.server.app.db.first("*").from("users").queryContext({jsonCols: ["roles"]}).where({username}); + + if (! user) { + return {isValid: false, credentials: null}; + } + + if (! await Bcrypt.compare(password, user.password)) { + return {isValid: false, credentials: null}; + } + + return { + isValid: true, + credentials: await req.server.methods.getCredentials(user) + }; + }, + { + generateKey: (req, username, password) => `${username}-${password}`, + cache: { + expiresIn: 60000, + generateTimeout: 5000 + } + } + ); + server.method( + "cookieAuthValidateFunc", + async (req, session) => { + const user = await req.server.app.db.first("id").from("users").where({id: session.id, username: session.username}); + + if (! user) { + return {valid: false}; + } + + return {valid: true}; + }, + { + generateKey: (req, session) => session.id.toString(), + cache: { + expiresIn: 60000, + generateTimeout: 5000 + } + } + ); + server.method( + "playerBearerAuthHeader", + async (req) => { + const user = await req.server.app.db.first("player_api_token").from("users").where({id: req.auth.credentials.id}); + + if (! user) { + throw Boom.unauthorized(`Unrecognized user: ${req.auth.credentials.id}`); + } + + return `Bearer ${user.playerApiToken}`; + } + ); + server.method( + "playerBasicAuthHeader", + (req) => `Basic ${Buffer.from(`${req.server.app.player.key}:${req.server.app.player.secret}`).toString("base64")}`, + { + generateKey: (req) => `${req.server.app.player.key}-${req.server.app.player.secret}`, + cache: { + expiresIn: 60000, + generateTimeout: 1000 + } + } + ); + + server.auth.strategy( + "basic", + "basic", + { + validate: async (req, username, password) => await req.server.methods.basicAuthValidate(req, username, password) + } + ); + server.auth.strategy( + "session", + "cookie", + { + validateFunc: async (req, session) => await req.server.methods.cookieAuthValidateFunc(req, session), + cookie: { + password: Date.now() + process.env.CTS_SESSION_COOKIE_PASSWORD + Math.ceil(Math.random() * 10000000), + + // switch to use via https + isSecure: false, + + ttl: AUTH_TTL_SECONDS * 1000 + } + } + ); + + await server.register( + [ + require("./plugins/routes/client"), + ] + ); + server.route( + { + method: "GET", + path: "/", + handler: (req, h) => h.redirect("/client/"), + options: { + auth: false + } + } + ); + + // + // order matters here, specifying the default auth setup then applies to + // the rest of the routes registered from this point + // + server.auth.default( + { + strategies: ["basic", "session"] + } + ); + await server.register( + [ + require("./plugins/routes/v1/core"), + require("./plugins/routes/v1/mgmt"), + require("./plugins/routes/v1/courses"), + require("./plugins/routes/v1/tests"), + require("./plugins/routes/v1/sessions"), + require("./plugins/routes/v1/users") + ], + { + routes: { + prefix: "/api/v1" + } + } + ); + + await server.start(); + + process.on("SIGINT", sigHandler); + process.on("SIGTERM", sigHandler); + + console.log("Catapult CTS service running on %s", server.info.uri); +}; + +process.on( + "unhandledRejection", + (err) => { + console.log(err); + process.exit(1); + } +); + +provision(); diff --git a/KST-ASD-BI-101/cts/service/knexfile.js b/KST-ASD-BI-101/cts/service/knexfile.js new file mode 100644 index 0000000..e90945f --- /dev/null +++ b/KST-ASD-BI-101/cts/service/knexfile.js @@ -0,0 +1,101 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +const DB_HOST = (process.env.DB_HOST || "rdbms"); +const DB_NAME = (process.env.DB_NAME || "catapult_player"); +const DB_USERNAME = (process.env.DB_USERNAME || "catapult"); +const DB_PASSWORD = (process.env.DB_PASSWORD || "quartz"); + +const Hoek = require("@hapi/hoek"), + waitPort = require("wait-port"), + { + // MYSQL_HOST: HOST = "rdbms", + MYSQL_HOST_FILE: HOST_FILE, + // DATABASE_USER: USER = "catapult", + DATABASE_USER_FILE: USER_FILE, + // DATABASE_USER_PASSWORD: DB_PASSWORD, + DATABASE_USER_PASSWORD_FILE: PASSWORD_FILE, + // DATABASE_NAME: DB = "catapult_player", + DATABASE_NAME_FILE: DB_FILE, + } = process.env; + +module.exports = async () => { + // const host = HOST_FILE ? fs.readFileSync(HOST_FILE) : HOST, + // user = USER_FILE ? fs.readFileSync(USER_FILE) : USER, + // password = PASSWORD_FILE ? fs.readFileSync(PASSWORD_FILE) : PASSWORD, + // database = DB_FILE ? fs.readFileSync(DB_FILE) : DB; + const host = HOST_FILE ? fs.readFileSync(HOST_FILE) : DB_HOST, + user = USER_FILE ? fs.readFileSync(USER_FILE) : DB_USERNAME, + password = PASSWORD_FILE ? fs.readFileSync(PASSWORD_FILE) : DB_PASSWORD, + database = DB_FILE ? fs.readFileSync(DB_FILE) : DB_NAME; + + await waitPort({host, port: 3306}); + + return { + client: "mysql", + connection: {host, user, password, database}, + postProcessResponse: (result, queryContext) => { + if (result && queryContext && queryContext.jsonCols) { + if (Array.isArray(result)) { + result = result.map( + (row) => { + for (const k of queryContext.jsonCols) { + const parts = k.split("."); + let match = row, + field = k; + + if (parts.length > 1) { + field = parts[parts.length - 1]; + match = Hoek.reach(row, parts.slice(0, -1).join(".")); + } + + try { + match[field] = JSON.parse(match[field]); + } + catch (ex) { + throw new Error(`Failed to parse JSON in key ('${k}' in '${row}'): ${ex}`); + } + } + + return row; + } + ); + } + else { + for (const k of queryContext.jsonCols) { + const parts = k.split("."); + + let match = result, + field = k; + + if (parts.length > 1) { + field = parts[parts.length - 1]; + match = Hoek.reach(result, parts.slice(0, -1).join(".")); + } + + try { + match[field] = JSON.parse(match[field]); + } + catch (ex) { + throw new Error(`Failed to parse JSON in key ('${k}' in '${result}'): ${ex}`); + } + } + } + } + + return result; + } + }; +}; diff --git a/KST-ASD-BI-101/cts/service/lib/consts.js b/KST-ASD-BI-101/cts/service/lib/consts.js new file mode 100644 index 0000000..de2b937 --- /dev/null +++ b/KST-ASD-BI-101/cts/service/lib/consts.js @@ -0,0 +1,3 @@ +module.exports = { + AUTH_TTL_SECONDS: 8 * 60 * 60 +}; diff --git a/KST-ASD-BI-101/cts/service/lib/db.js b/KST-ASD-BI-101/cts/service/lib/db.js new file mode 100644 index 0000000..58a0eff --- /dev/null +++ b/KST-ASD-BI-101/cts/service/lib/db.js @@ -0,0 +1,24 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +const Knex = require("knex"), + KnexStringcase = require('knex-stringcase'), + KnexCfg = require("../knexfile"); + +module.exports = async () => { + const knexCfg = await KnexCfg(); + + return Knex(KnexStringcase["default"](knexCfg)); +}; diff --git a/KST-ASD-BI-101/cts/service/package-lock.json b/KST-ASD-BI-101/cts/service/package-lock.json new file mode 100644 index 0000000..85e457a --- /dev/null +++ b/KST-ASD-BI-101/cts/service/package-lock.json @@ -0,0 +1,1690 @@ +{ + "name": "catapult-cts-service", + "version": "1.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "catapult-cts-service", + "version": "1.0.0", + "license": "Apache-2.0", + "dependencies": { + "@cmi5/requirements": "^1.0.0", + "@hapi/basic": "^6.0.0", + "@hapi/boom": "^9.1.3", + "@hapi/cookie": "^11.0.2", + "@hapi/h2o2": "^9.1.0", + "@hapi/hapi": "^20.1.5", + "@hapi/hoek": "^9.2.0", + "@hapi/inert": "^6.0.3", + "@hapi/jwt": "^2.0.1", + "@hapi/vision": "^6.1.0", + "@hapi/wreck": "^17.1.0", + "axios": "^1.6.8", + "bcrypt": "^5.0.1", + "hapi-swagger": "^14.2.1", + "iri": "^1.3.0", + "joi": "^17.4.1", + "knex": "^0.95.7", + "knex-stringcase": "^1.4.5", + "mysql": "^2.18.1", + "uuid": "^8.3.2", + "wait-port": "^0.2.9" + }, + "devDependencies": { + "detect-secrets": "^1.0.6" + } + }, + "node_modules/@cmi5/requirements": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@cmi5/requirements/-/requirements-1.0.0.tgz", + "integrity": "sha512-zma/xICz33dNVgpDYFeEhVtX9jsPXw8c8GhX4eZdHLMyfqCowyZN16ESYSv/zQp8orOfWHVPdm2bojv4TYUY/w==" + }, + "node_modules/@hapi/accept": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/@hapi/accept/-/accept-5.0.2.tgz", + "integrity": "sha512-CmzBx/bXUR8451fnZRuZAJRlzgm0Jgu5dltTX/bszmR2lheb9BpyN47Q1RbaGTsvFzn0PXAEs+lXDKfshccYZw==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@hapi/ammo": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/@hapi/ammo/-/ammo-5.0.1.tgz", + "integrity": "sha512-FbCNwcTbnQP4VYYhLNGZmA76xb2aHg9AMPiy18NZyWMG310P5KdFGyA9v2rm5ujrIny77dEEIkMOwl0Xv+fSSA==", + "dependencies": { + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@hapi/b64": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/@hapi/b64/-/b64-5.0.0.tgz", + "integrity": "sha512-ngu0tSEmrezoiIaNGG6rRvKOUkUuDdf4XTPnONHGYfSGRmDqPZX5oJL6HAdKTo1UQHECbdB4OzhWrfgVppjHUw==", + "dependencies": { + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@hapi/basic": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/@hapi/basic/-/basic-6.0.0.tgz", + "integrity": "sha512-nWWSXNCq3WptnP3To2c8kfQiRFDUnd9FQOcMS0B85y1x/m12c0hhp+VdmK60BMe44k6WIog1n6g8f9gZOagqBg==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@hapi/boom": { + "version": "9.1.3", + "resolved": "https://registry.npmjs.org/@hapi/boom/-/boom-9.1.3.tgz", + "integrity": "sha512-RlrGyZ603hE/eRTZtTltocRm50HHmrmL3kGOP0SQ9MasazlW1mt/fkv4C5P/6rnpFXjwld/POFX1C8tMZE3ldg==", + "dependencies": { + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@hapi/bounce": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@hapi/bounce/-/bounce-2.0.0.tgz", + "integrity": "sha512-JesW92uyzOOyuzJKjoLHM1ThiOvHPOLDHw01YV8yh5nCso7sDwJho1h0Ad2N+E62bZyz46TG3xhAi/78Gsct6A==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@hapi/bourne": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@hapi/bourne/-/bourne-2.0.0.tgz", + "integrity": "sha512-WEezM1FWztfbzqIUbsDzFRVMxSoLy3HugVcux6KDDtTqzPsLE8NDRHfXvev66aH1i2oOKKar3/XDjbvh/OUBdg==" + }, + "node_modules/@hapi/call": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/@hapi/call/-/call-8.0.1.tgz", + "integrity": "sha512-bOff6GTdOnoe5b8oXRV3lwkQSb/LAWylvDMae6RgEWWntd0SHtkYbQukDHKlfaYtVnSAgIavJ0kqszF/AIBb6g==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@hapi/catbox": { + "version": "11.1.1", + "resolved": "https://registry.npmjs.org/@hapi/catbox/-/catbox-11.1.1.tgz", + "integrity": "sha512-u/8HvB7dD/6X8hsZIpskSDo4yMKpHxFd7NluoylhGrL6cUfYxdQPnvUp9YU2C6F9hsyBVLGulBd9vBN1ebfXOQ==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/hoek": "9.x.x", + "@hapi/podium": "4.x.x", + "@hapi/validate": "1.x.x" + } + }, + "node_modules/@hapi/catbox-memory": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/@hapi/catbox-memory/-/catbox-memory-5.0.1.tgz", + "integrity": "sha512-QWw9nOYJq5PlvChLWV8i6hQHJYfvdqiXdvTupJFh0eqLZ64Xir7mKNi96d5/ZMUAqXPursfNDIDxjFgoEDUqeQ==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@hapi/catbox-object": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@hapi/catbox-object/-/catbox-object-2.0.0.tgz", + "integrity": "sha512-tzTo5q9UVqwqtpNkIz0VNSmJTbaGyD9ZQmw4a91BBWB+YJWYa066KkxOTHGmmWJzjZEhG2CsNYKu34J25pA5aw==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@hapi/content": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/@hapi/content/-/content-5.0.2.tgz", + "integrity": "sha512-mre4dl1ygd4ZyOH3tiYBrOUBzV7Pu/EOs8VLGf58vtOEECWed8Uuw6B4iR9AN/8uQt42tB04qpVaMyoMQh0oMw==", + "dependencies": { + "@hapi/boom": "9.x.x" + } + }, + "node_modules/@hapi/cookie": { + "version": "11.0.2", + "resolved": "https://registry.npmjs.org/@hapi/cookie/-/cookie-11.0.2.tgz", + "integrity": "sha512-LRpSuHC53urzml83c5eUHSPPt7YtK1CaaPZU9KmnhZlacVVojrWJzOUIcwOADDvCZjDxowCO3zPMaOqzEm9kgg==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/bounce": "2.x.x", + "@hapi/hoek": "9.x.x", + "@hapi/validate": "1.x.x" + } + }, + "node_modules/@hapi/cryptiles": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/@hapi/cryptiles/-/cryptiles-5.1.0.tgz", + "integrity": "sha512-fo9+d1Ba5/FIoMySfMqPBR/7Pa29J2RsiPrl7bkwo5W5o+AN1dAYQRi4SPrPwwVxVGKjgLOEWrsvt1BonJSfLA==", + "dependencies": { + "@hapi/boom": "9.x.x" + }, + "engines": { + "node": ">=12.0.0" + } + }, + "node_modules/@hapi/file": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@hapi/file/-/file-2.0.0.tgz", + "integrity": "sha512-WSrlgpvEqgPWkI18kkGELEZfXr0bYLtr16iIN4Krh9sRnzBZN6nnWxHFxtsnP684wueEySBbXPDg/WfA9xJdBQ==" + }, + "node_modules/@hapi/h2o2": { + "version": "9.1.0", + "resolved": "https://registry.npmjs.org/@hapi/h2o2/-/h2o2-9.1.0.tgz", + "integrity": "sha512-B7E58bMhxmpiDI22clxTexoAaVShNBk1Ez6S8SQjQZu5FxxD6Tqa44sXeZQBtWrdJF7ZRbsY60/C8AHLRxagNA==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/hoek": "9.x.x", + "@hapi/validate": "1.x.x", + "@hapi/wreck": "17.x.x" + }, + "engines": { + "node": ">=12.0.0" + } + }, + "node_modules/@hapi/hapi": { + "version": "20.1.5", + "resolved": "https://registry.npmjs.org/@hapi/hapi/-/hapi-20.1.5.tgz", + "integrity": "sha512-BhJ5XFR9uWPUBj/z5pPqXSk8OnvQQU/EbQjwpmjZy0ymNEiq7kIhXkAmzXcntbBHta9o7zpW8XMeXnfV4wudXw==", + "dependencies": { + "@hapi/accept": "^5.0.1", + "@hapi/ammo": "^5.0.1", + "@hapi/boom": "^9.1.0", + "@hapi/bounce": "^2.0.0", + "@hapi/call": "^8.0.0", + "@hapi/catbox": "^11.1.1", + "@hapi/catbox-memory": "^5.0.0", + "@hapi/heavy": "^7.0.1", + "@hapi/hoek": "^9.0.4", + "@hapi/mimos": "^6.0.0", + "@hapi/podium": "^4.1.1", + "@hapi/shot": "^5.0.5", + "@hapi/somever": "^3.0.0", + "@hapi/statehood": "^7.0.3", + "@hapi/subtext": "^7.0.3", + "@hapi/teamwork": "^5.1.0", + "@hapi/topo": "^5.0.0", + "@hapi/validate": "^1.1.1" + }, + "engines": { + "node": ">=12.0.0" + } + }, + "node_modules/@hapi/heavy": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/@hapi/heavy/-/heavy-7.0.1.tgz", + "integrity": "sha512-vJ/vzRQ13MtRzz6Qd4zRHWS3FaUc/5uivV2TIuExGTM9Qk+7Zzqj0e2G7EpE6KztO9SalTbiIkTh7qFKj/33cA==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/hoek": "9.x.x", + "@hapi/validate": "1.x.x" + } + }, + "node_modules/@hapi/hoek": { + "version": "9.2.0", + "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-9.2.0.tgz", + "integrity": "sha512-sqKVVVOe5ivCaXDWivIJYVSaEgdQK9ul7a4Kity5Iw7u9+wBAPbX1RMSnLLmp7O4Vzj0WOWwMAJsTL00xwaNug==" + }, + "node_modules/@hapi/inert": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/@hapi/inert/-/inert-6.0.3.tgz", + "integrity": "sha512-Z6Pi0Wsn2pJex5CmBaq+Dky9q40LGzXLUIUFrYpDtReuMkmfy9UuUeYc4064jQ1Xe9uuw7kbwE6Fq6rqKAdjAg==", + "dependencies": { + "@hapi/ammo": "5.x.x", + "@hapi/boom": "9.x.x", + "@hapi/bounce": "2.x.x", + "@hapi/hoek": "9.x.x", + "@hapi/validate": "1.x.x", + "lru-cache": "^6.0.0" + } + }, + "node_modules/@hapi/iron": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/@hapi/iron/-/iron-6.0.0.tgz", + "integrity": "sha512-zvGvWDufiTGpTJPG1Y/McN8UqWBu0k/xs/7l++HVU535NLHXsHhy54cfEMdW7EjwKfbBfM9Xy25FmTiobb7Hvw==", + "dependencies": { + "@hapi/b64": "5.x.x", + "@hapi/boom": "9.x.x", + "@hapi/bourne": "2.x.x", + "@hapi/cryptiles": "5.x.x", + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@hapi/jwt": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@hapi/jwt/-/jwt-2.0.1.tgz", + "integrity": "sha512-6/nX/yOIk9mvs+r72LFhF177yOB4yVv3e0Nqn7cIx2CU+VruBHxMKkHraARXx6oUAtiwNuyhW+trO5QeGm9ESQ==", + "dependencies": { + "@hapi/b64": "5.x.x", + "@hapi/boom": "9.x.x", + "@hapi/bounce": "2.x.x", + "@hapi/bourne": "2.x.x", + "@hapi/catbox-object": "2.x.x", + "@hapi/cryptiles": "5.x.x", + "@hapi/hoek": "9.x.x", + "@hapi/wreck": "17.x.x", + "ecdsa-sig-formatter": "1.x.x", + "joi": "^17.2.1" + } + }, + "node_modules/@hapi/mimos": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/@hapi/mimos/-/mimos-6.0.0.tgz", + "integrity": "sha512-Op/67tr1I+JafN3R3XN5DucVSxKRT/Tc+tUszDwENoNpolxeXkhrJ2Czt6B6AAqrespHoivhgZBWYSuANN9QXg==", + "dependencies": { + "@hapi/hoek": "9.x.x", + "mime-db": "1.x.x" + } + }, + "node_modules/@hapi/nigel": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/@hapi/nigel/-/nigel-4.0.2.tgz", + "integrity": "sha512-ht2KoEsDW22BxQOEkLEJaqfpoKPXxi7tvabXy7B/77eFtOyG5ZEstfZwxHQcqAiZhp58Ae5vkhEqI03kawkYNw==", + "dependencies": { + "@hapi/hoek": "^9.0.4", + "@hapi/vise": "^4.0.0" + }, + "engines": { + "node": ">=12.0.0" + } + }, + "node_modules/@hapi/pez": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/@hapi/pez/-/pez-5.0.3.tgz", + "integrity": "sha512-mpikYRJjtrbJgdDHG/H9ySqYqwJ+QU/D7FXsYciS9P7NYBXE2ayKDAy3H0ou6CohOCaxPuTV4SZ0D936+VomHA==", + "dependencies": { + "@hapi/b64": "5.x.x", + "@hapi/boom": "9.x.x", + "@hapi/content": "^5.0.2", + "@hapi/hoek": "9.x.x", + "@hapi/nigel": "4.x.x" + } + }, + "node_modules/@hapi/podium": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/@hapi/podium/-/podium-4.1.3.tgz", + "integrity": "sha512-ljsKGQzLkFqnQxE7qeanvgGj4dejnciErYd30dbrYzUOF/FyS/DOF97qcrT3bhoVwCYmxa6PEMhxfCPlnUcD2g==", + "dependencies": { + "@hapi/hoek": "9.x.x", + "@hapi/teamwork": "5.x.x", + "@hapi/validate": "1.x.x" + } + }, + "node_modules/@hapi/shot": { + "version": "5.0.5", + "resolved": "https://registry.npmjs.org/@hapi/shot/-/shot-5.0.5.tgz", + "integrity": "sha512-x5AMSZ5+j+Paa8KdfCoKh+klB78otxF+vcJR/IoN91Vo2e5ulXIW6HUsFTCU+4W6P/Etaip9nmdAx2zWDimB2A==", + "dependencies": { + "@hapi/hoek": "9.x.x", + "@hapi/validate": "1.x.x" + } + }, + "node_modules/@hapi/somever": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@hapi/somever/-/somever-3.0.1.tgz", + "integrity": "sha512-4ZTSN3YAHtgpY/M4GOtHUXgi6uZtG9nEZfNI6QrArhK0XN/RDVgijlb9kOmXwCR5VclDSkBul9FBvhSuKXx9+w==", + "dependencies": { + "@hapi/bounce": "2.x.x", + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@hapi/statehood": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/@hapi/statehood/-/statehood-7.0.3.tgz", + "integrity": "sha512-pYB+pyCHkf2Amh67QAXz7e/DN9jcMplIL7Z6N8h0K+ZTy0b404JKPEYkbWHSnDtxLjJB/OtgElxocr2fMH4G7w==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/bounce": "2.x.x", + "@hapi/bourne": "2.x.x", + "@hapi/cryptiles": "5.x.x", + "@hapi/hoek": "9.x.x", + "@hapi/iron": "6.x.x", + "@hapi/validate": "1.x.x" + } + }, + "node_modules/@hapi/subtext": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/@hapi/subtext/-/subtext-7.0.3.tgz", + "integrity": "sha512-CekDizZkDGERJ01C0+TzHlKtqdXZxzSWTOaH6THBrbOHnsr3GY+yiMZC+AfNCypfE17RaIakGIAbpL2Tk1z2+A==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/bourne": "2.x.x", + "@hapi/content": "^5.0.2", + "@hapi/file": "2.x.x", + "@hapi/hoek": "9.x.x", + "@hapi/pez": "^5.0.1", + "@hapi/wreck": "17.x.x" + } + }, + "node_modules/@hapi/teamwork": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/@hapi/teamwork/-/teamwork-5.1.0.tgz", + "integrity": "sha512-llqoQTrAJDTXxG3c4Kz/uzhBS1TsmSBa/XG5SPcVXgmffHE1nFtyLIK0hNJHCB3EuBKT84adzd1hZNY9GJLWtg==", + "engines": { + "node": ">=12.0.0" + } + }, + "node_modules/@hapi/topo": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-5.0.0.tgz", + "integrity": "sha512-tFJlT47db0kMqVm3H4nQYgn6Pwg10GTZHb1pwmSiv1K4ks6drQOtfEF5ZnPjkvC+y4/bUPHK+bc87QvLcL+WMw==", + "dependencies": { + "@hapi/hoek": "^9.0.0" + } + }, + "node_modules/@hapi/validate": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@hapi/validate/-/validate-1.1.3.tgz", + "integrity": "sha512-/XMR0N0wjw0Twzq2pQOzPBZlDzkekGcoCtzO314BpIEsbXdYGthQUbxgkGDf4nhk1+IPDAsXqWjMohRQYO06UA==", + "dependencies": { + "@hapi/hoek": "^9.0.0", + "@hapi/topo": "^5.0.0" + } + }, + "node_modules/@hapi/vise": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/@hapi/vise/-/vise-4.0.0.tgz", + "integrity": "sha512-eYyLkuUiFZTer59h+SGy7hUm+qE9p+UemePTHLlIWppEd+wExn3Df5jO04bFQTm7nleF5V8CtuYQYb+VFpZ6Sg==", + "dependencies": { + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@hapi/vision": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/@hapi/vision/-/vision-6.1.0.tgz", + "integrity": "sha512-ll0zJ13xDxCYIWvC1aq/8srK0bTXfqZYGT+YoTi/fS42gYYJ3dnvmS35r8T8XXtJ6F6cmya8G2cRlMR/z11LQw==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/bounce": "2.x.x", + "@hapi/hoek": "9.x.x", + "@hapi/validate": "1.x.x" + } + }, + "node_modules/@hapi/wreck": { + "version": "17.1.0", + "resolved": "https://registry.npmjs.org/@hapi/wreck/-/wreck-17.1.0.tgz", + "integrity": "sha512-nx6sFyfqOpJ+EFrHX+XWwJAxs3ju4iHdbB/bwR8yTNZOiYmuhA8eCe7lYPtYmb4j7vyK/SlbaQsmTtUrMvPEBw==", + "dependencies": { + "@hapi/boom": "9.x.x", + "@hapi/bourne": "2.x.x", + "@hapi/hoek": "9.x.x" + } + }, + "node_modules/@mapbox/node-pre-gyp": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/@mapbox/node-pre-gyp/-/node-pre-gyp-1.0.3.tgz", + "integrity": "sha512-9dTIfQW8HVCxLku5QrJ/ysS/b2MdYngs9+/oPrOTLvp3TrggdANYVW2h8FGJGDf0J7MYfp44W+c90cVJx+ASuA==", + "dependencies": { + "detect-libc": "^1.0.3", + "https-proxy-agent": "^5.0.0", + "make-dir": "^3.1.0", + "node-fetch": "^2.6.1", + "nopt": "^5.0.0", + "npmlog": "^4.1.2", + "rimraf": "^3.0.2", + "semver": "^7.3.4", + "tar": "^6.1.0" + }, + "bin": { + "node-pre-gyp": "bin/node-pre-gyp" + } + }, + "node_modules/@sideway/address": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/@sideway/address/-/address-4.1.2.tgz", + "integrity": "sha512-idTz8ibqWFrPU8kMirL0CoPH/A29XOzzAzpyN3zQ4kAWnzmNfFmRaoMNN6VI8ske5M73HZyhIaW4OuSFIdM4oA==", + "dependencies": { + "@hapi/hoek": "^9.0.0" + } + }, + "node_modules/@sideway/formula": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@sideway/formula/-/formula-3.0.0.tgz", + "integrity": "sha512-vHe7wZ4NOXVfkoRb8T5otiENVlT7a3IAiw7H5M2+GO+9CDgcVUUsX1zalAztCmwyOr2RUTGJdgB+ZvSVqmdHmg==" + }, + "node_modules/@sideway/pinpoint": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@sideway/pinpoint/-/pinpoint-2.0.0.tgz", + "integrity": "sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ==" + }, + "node_modules/abbrev": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", + "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" + }, + "node_modules/agent-base": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", + "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", + "dependencies": { + "debug": "4" + }, + "engines": { + "node": ">= 6.0.0" + } + }, + "node_modules/ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/aproba": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", + "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" + }, + "node_modules/are-we-there-yet": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", + "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", + "dependencies": { + "delegates": "^1.0.0", + "readable-stream": "^2.0.6" + } + }, + "node_modules/argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dependencies": { + "sprintf-js": "~1.0.2" + } + }, + "node_modules/asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" + }, + "node_modules/axios": { + "version": "1.6.8", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.6.8.tgz", + "integrity": "sha512-v/ZHtJDU39mDpyBoFVkETcd/uNdxrWRrg3bKpOKzXFA6Bvqopts6ALSMU3y6ijYxbw2B+wPrIv46egTzJXCLGQ==", + "dependencies": { + "follow-redirects": "^1.15.6", + "form-data": "^4.0.0", + "proxy-from-env": "^1.1.0" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" + }, + "node_modules/bcrypt": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/bcrypt/-/bcrypt-5.0.1.tgz", + "integrity": "sha512-9BTgmrhZM2t1bNuDtrtIMVSmmxZBrJ71n8Wg+YgdjHuIWYF7SjjmCPZFB+/5i/o/PIeRpwVJR3P+NrpIItUjqw==", + "hasInstallScript": true, + "dependencies": { + "@mapbox/node-pre-gyp": "^1.0.0", + "node-addon-api": "^3.1.0" + }, + "engines": { + "node": ">= 10.0.0" + } + }, + "node_modules/bignumber.js": { + "version": "9.0.0", + "resolved": "https://registry.npmjs.org/bignumber.js/-/bignumber.js-9.0.0.tgz", + "integrity": "sha512-t/OYhhJ2SD+YGBQcjY8GzzDHEk9f3nerxjtfa6tlMXfe7frs/WozhvCNoGvpM0P3bNf3Gq5ZRMlGr5f3r4/N8A==", + "engines": { + "node": "*" + } + }, + "node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/call-me-maybe": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/call-me-maybe/-/call-me-maybe-1.0.1.tgz", + "integrity": "sha1-JtII6onje1y95gJQoV8DHBak1ms=" + }, + "node_modules/chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dependencies": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/chownr": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", + "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==", + "engines": { + "node": ">=10" + } + }, + "node_modules/code-point-at": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", + "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" + }, + "node_modules/colorette": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/colorette/-/colorette-1.2.1.tgz", + "integrity": "sha512-puCDz0CzydiSYOrnXpz/PKd69zRrribezjtE9yd4zvytoRc8+RY/KJPvtPFKZS3E3wP6neGyMe0vOTlHO5L3Pw==" + }, + "node_modules/combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/commander": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-7.2.0.tgz", + "integrity": "sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw==", + "engines": { + "node": ">= 10" + } + }, + "node_modules/concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" + }, + "node_modules/console-control-strings": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", + "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" + }, + "node_modules/core-js": { + "version": "2.6.12", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.6.12.tgz", + "integrity": "sha512-Kb2wC0fvsWfQrgk8HU5lW6U/Lcs8+9aaYcy4ZFc6DDlo4nZ7n70dEgE5rtR0oG6ufKDUnrwfWL1mXR5ljDatrQ==", + "deprecated": "core-js@<3.23.3 is no longer maintained and not recommended for usage due to the number of issues. Because of the V8 engine whims, feature detection in old core-js versions could cause a slowdown up to 100x even if nothing is polyfilled. Some versions have web compatibility issues. Please, upgrade your dependencies to the actual version of core-js.", + "hasInstallScript": true + }, + "node_modules/core-util-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" + }, + "node_modules/debug": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", + "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/delegates": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", + "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" + }, + "node_modules/detect-libc": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz", + "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=", + "bin": { + "detect-libc": "bin/detect-libc.js" + }, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/detect-secrets": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/detect-secrets/-/detect-secrets-1.0.6.tgz", + "integrity": "sha512-bAEmXtMJNS/By/TCg9uSW9Sp0V1Z0N+uwlQWFUMbCVri5Yq5rM8gVs+2zzNIjNOy36o5kANZRrMc+22Zf6eRFQ==", + "dev": true, + "dependencies": { + "debug": "^4.1.0", + "which": "^1.3.1" + }, + "bin": { + "detect-secrets-launcher": "bin/detect-secrets-launcher.js" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/ecdsa-sig-formatter": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", + "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", + "dependencies": { + "safe-buffer": "^5.0.1" + } + }, + "node_modules/escalade": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", + "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "engines": { + "node": ">=6" + } + }, + "node_modules/escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/esm": { + "version": "3.2.25", + "resolved": "https://registry.npmjs.org/esm/-/esm-3.2.25.tgz", + "integrity": "sha512-U1suiZ2oDVWv4zPO56S0NcR5QriEahGtdN2OR6FiOG4WJvcjBVFB0qI4+eKoWFH483PKGuLuu6V8Z4T5g63UVA==", + "engines": { + "node": ">=6" + } + }, + "node_modules/esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/follow-redirects": { + "version": "1.15.6", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.6.tgz", + "integrity": "sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA==", + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, + "node_modules/form-data": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", + "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/format-util": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/format-util/-/format-util-1.0.5.tgz", + "integrity": "sha512-varLbTj0e0yVyRpqQhuWV+8hlePAgaoFRhNFj50BNjEIrw1/DphHSObtqwskVCPWNgzwPoQrZAbfa/SBiicNeg==" + }, + "node_modules/fs-minipass": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz", + "integrity": "sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==", + "dependencies": { + "minipass": "^3.0.0" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" + }, + "node_modules/function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" + }, + "node_modules/gauge": { + "version": "2.7.4", + "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", + "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", + "dependencies": { + "aproba": "^1.0.3", + "console-control-strings": "^1.0.0", + "has-unicode": "^2.0.0", + "object-assign": "^4.1.0", + "signal-exit": "^3.0.0", + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1", + "wide-align": "^1.1.0" + } + }, + "node_modules/getopts": { + "version": "2.2.5", + "resolved": "https://registry.npmjs.org/getopts/-/getopts-2.2.5.tgz", + "integrity": "sha512-9jb7AW5p3in+IiJWhQiZmmwkpLaR/ccTWdWQCtZM66HJcHHLegowh4q4tSD7gouUyeNvFWRavfK9GXosQHDpFA==" + }, + "node_modules/glob": { + "version": "7.1.6", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", + "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/handlebars": { + "version": "4.7.7", + "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.7.7.tgz", + "integrity": "sha512-aAcXm5OAfE/8IXkcZvCepKU3VzW1/39Fb5ZuqMtgI/hT8X2YgoMvBY5dLhq/cpOvw7Lk1nK/UF71aLG/ZnVYRA==", + "dependencies": { + "minimist": "^1.2.5", + "neo-async": "^2.6.0", + "source-map": "^0.6.1", + "wordwrap": "^1.0.0" + }, + "bin": { + "handlebars": "bin/handlebars" + }, + "engines": { + "node": ">=0.4.7" + }, + "optionalDependencies": { + "uglify-js": "^3.1.4" + } + }, + "node_modules/handlebars/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/hapi-swagger": { + "version": "14.2.1", + "resolved": "https://registry.npmjs.org/hapi-swagger/-/hapi-swagger-14.2.1.tgz", + "integrity": "sha512-K1oN/88Jh4/Q6ZMKxrbQT6bYrFouA3PaE8Kh5F3loNyPm8dezAeGvx8vreeNWCzFLwqHNFjFbZcgBgKnYF1Dwg==", + "dependencies": { + "@hapi/boom": "^9.1.0", + "@hapi/hoek": "^9.0.2", + "handlebars": "^4.7.7", + "http-status": "^1.0.1", + "json-schema-ref-parser": "^6.1.0", + "swagger-parser": "4.0.2", + "swagger-ui-dist": "^3.47.1" + }, + "engines": { + "node": ">=12.0.0" + }, + "peerDependencies": { + "@hapi/hapi": "^20.0.0", + "joi": "17.x" + } + }, + "node_modules/has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "dependencies": { + "function-bind": "^1.1.1" + }, + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", + "engines": { + "node": ">=4" + } + }, + "node_modules/has-unicode": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", + "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" + }, + "node_modules/http-status": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/http-status/-/http-status-1.5.0.tgz", + "integrity": "sha512-wcGvY31MpFNHIkUcXHHnvrE4IKYlpvitJw5P/1u892gMBAM46muQ+RH7UN1d+Ntnfx5apnOnVY6vcLmrWHOLwg==", + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/https-proxy-agent": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", + "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", + "dependencies": { + "agent-base": "6", + "debug": "4" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "dependencies": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + }, + "node_modules/interpret": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/interpret/-/interpret-2.2.0.tgz", + "integrity": "sha512-Ju0Bz/cEia55xDwUWEa8+olFpCiQoypjnQySseKtmjNrnps3P+xfpUmGr90T7yjlVJmOtybRvPXhKMbHr+fWnw==", + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/iri": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/iri/-/iri-1.3.0.tgz", + "integrity": "sha512-1bPyBMoj15VLCxtPDPC7YREka60TTAp7FH+4cU7k/haISq4XyR4/GVMmX+J3TeIOlNYH7twHbpYO9QQyejBZMg==" + }, + "node_modules/is-core-module": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.5.0.tgz", + "integrity": "sha512-TXCMSDsEHMEEZ6eCA8rwRDbLu55MRGmrctljsBX/2v1d9/GzqHOxW5c5oPSgrUt2vBFXebu9rGqckXGPWOlYpg==", + "dependencies": { + "has": "^1.0.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-fullwidth-code-point": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", + "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", + "dependencies": { + "number-is-nan": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" + }, + "node_modules/isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true + }, + "node_modules/joi": { + "version": "17.4.1", + "resolved": "https://registry.npmjs.org/joi/-/joi-17.4.1.tgz", + "integrity": "sha512-gDPOwQ5sr+BUxXuPDGrC1pSNcVR/yGGcTI0aCnjYxZEa3za60K/iCQ+OFIkEHWZGVCUcUlXlFKvMmrlmxrG6UQ==", + "dependencies": { + "@hapi/hoek": "^9.0.0", + "@hapi/topo": "^5.0.0", + "@sideway/address": "^4.1.0", + "@sideway/formula": "^3.0.0", + "@sideway/pinpoint": "^2.0.0" + } + }, + "node_modules/js-yaml": { + "version": "3.14.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", + "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", + "dependencies": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/json-schema-ref-parser": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/json-schema-ref-parser/-/json-schema-ref-parser-6.1.0.tgz", + "integrity": "sha512-pXe9H1m6IgIpXmE5JSb8epilNTGsmTb2iPohAXpOdhqGFbQjNeHHsZxU+C8w6T81GZxSPFLeUoqDJmzxx5IGuw==", + "deprecated": "Please switch to @apidevtools/json-schema-ref-parser", + "dependencies": { + "call-me-maybe": "^1.0.1", + "js-yaml": "^3.12.1", + "ono": "^4.0.11" + } + }, + "node_modules/knex": { + "version": "0.95.7", + "resolved": "https://registry.npmjs.org/knex/-/knex-0.95.7.tgz", + "integrity": "sha512-J2X79td0NAcreTyWVmmHHretz5Ox705FHywddjkT3esTtmggphjcfDoaXym18xtsLdjzOvEb53WB/58lqcF14w==", + "dependencies": { + "colorette": "1.2.1", + "commander": "^7.1.0", + "debug": "4.3.2", + "escalade": "^3.1.1", + "esm": "^3.2.25", + "getopts": "2.2.5", + "interpret": "^2.2.0", + "lodash": "^4.17.21", + "pg-connection-string": "2.5.0", + "rechoir": "^0.7.0", + "resolve-from": "^5.0.0", + "tarn": "^3.0.1", + "tildify": "2.0.0" + }, + "bin": { + "knex": "bin/cli.js" + }, + "engines": { + "node": ">=10" + }, + "peerDependenciesMeta": { + "mysql": { + "optional": true + }, + "mysql2": { + "optional": true + }, + "pg": { + "optional": true + }, + "sqlite3": { + "optional": true + }, + "tedious": { + "optional": true + } + } + }, + "node_modules/knex-stringcase": { + "version": "1.4.5", + "resolved": "https://registry.npmjs.org/knex-stringcase/-/knex-stringcase-1.4.5.tgz", + "integrity": "sha512-dO8CzBAfxX6HeZ6BP+5KCMn3450MRoz3xsUascogE3OucUIyv/ki/W30YQz15EuAbHr03s9DfgiNlKfAvD+PvQ==", + "dependencies": { + "stringcase": "^4.3.1" + } + }, + "node_modules/knex/node_modules/debug": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", + "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" + }, + "node_modules/lodash.get": { + "version": "4.4.2", + "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", + "integrity": "sha1-LRd/ZS+jHpObRDjVNBSZ36OCXpk=" + }, + "node_modules/lodash.isequal": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.isequal/-/lodash.isequal-4.5.0.tgz", + "integrity": "sha1-QVxEePK8wwEgwizhDtMib30+GOA=" + }, + "node_modules/lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dependencies": { + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/make-dir": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", + "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", + "dependencies": { + "semver": "^6.0.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/make-dir/node_modules/semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/minimist": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", + "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" + }, + "node_modules/minipass": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.1.3.tgz", + "integrity": "sha512-Mgd2GdMVzY+x3IJ+oHnVM+KG3lA5c8tnabyJKmHSaG2kAGpudxuOf8ToDkhumF7UzME7DecbQE9uOZhNm7PuJg==", + "dependencies": { + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/minizlib": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", + "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", + "dependencies": { + "minipass": "^3.0.0", + "yallist": "^4.0.0" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/mkdirp": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", + "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", + "bin": { + "mkdirp": "bin/cmd.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" + }, + "node_modules/mysql": { + "version": "2.18.1", + "resolved": "https://registry.npmjs.org/mysql/-/mysql-2.18.1.tgz", + "integrity": "sha512-Bca+gk2YWmqp2Uf6k5NFEurwY/0td0cpebAucFpY/3jhrwrVGuxU2uQFCHjU19SJfje0yQvi+rVWdq78hR5lig==", + "dependencies": { + "bignumber.js": "9.0.0", + "readable-stream": "2.3.7", + "safe-buffer": "5.1.2", + "sqlstring": "2.3.1" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/neo-async": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz", + "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==" + }, + "node_modules/node-addon-api": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-3.1.0.tgz", + "integrity": "sha512-flmrDNB06LIl5lywUz7YlNGZH/5p0M7W28k8hzd9Lshtdh1wshD2Y+U4h9LD6KObOy1f+fEVdgprPrEymjM5uw==" + }, + "node_modules/node-fetch": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.1.tgz", + "integrity": "sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw==", + "engines": { + "node": "4.x || >=6.0.0" + } + }, + "node_modules/nopt": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz", + "integrity": "sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==", + "dependencies": { + "abbrev": "1" + }, + "bin": { + "nopt": "bin/nopt.js" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/npmlog": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", + "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", + "dependencies": { + "are-we-there-yet": "~1.1.2", + "console-control-strings": "~1.1.0", + "gauge": "~2.7.3", + "set-blocking": "~2.0.0" + } + }, + "node_modules/number-is-nan": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", + "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/ono": { + "version": "4.0.11", + "resolved": "https://registry.npmjs.org/ono/-/ono-4.0.11.tgz", + "integrity": "sha512-jQ31cORBFE6td25deYeD80wxKBMj+zBmHTrVxnc6CKhx8gho6ipmWM5zj/oeoqioZ99yqBls9Z/9Nss7J26G2g==", + "dependencies": { + "format-util": "^1.0.3" + } + }, + "node_modules/path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" + }, + "node_modules/pg-connection-string": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-2.5.0.tgz", + "integrity": "sha512-r5o/V/ORTA6TmUnyWZR9nCj1klXCO2CEKNRlVuJptZe85QuhFayC7WeMic7ndayT5IRIR0S0xFxFi2ousartlQ==" + }, + "node_modules/process-nextick-args": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", + "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" + }, + "node_modules/proxy-from-env": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", + "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" + }, + "node_modules/readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "dependencies": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "node_modules/rechoir": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.7.0.tgz", + "integrity": "sha512-ADsDEH2bvbjltXEP+hTIAmeFekTFK0V2BTxMkok6qILyAJEXV0AFfoWcAq4yfll5VdIMd/RVXq0lR+wQi5ZU3Q==", + "dependencies": { + "resolve": "^1.9.0" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/resolve": { + "version": "1.20.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.20.0.tgz", + "integrity": "sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==", + "dependencies": { + "is-core-module": "^2.2.0", + "path-parse": "^1.0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/resolve-from": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", + "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", + "engines": { + "node": ">=8" + } + }, + "node_modules/rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "node_modules/semver": { + "version": "7.3.5", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", + "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", + "dependencies": { + "lru-cache": "^6.0.0" + }, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/set-blocking": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", + "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" + }, + "node_modules/signal-exit": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", + "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==" + }, + "node_modules/sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" + }, + "node_modules/sqlstring": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/sqlstring/-/sqlstring-2.3.1.tgz", + "integrity": "sha1-R1OT/56RR5rqYtyvDKPRSYOn+0A=", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "dependencies": { + "safe-buffer": "~5.1.0" + } + }, + "node_modules/string-width": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", + "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", + "dependencies": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/stringcase": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/stringcase/-/stringcase-4.3.1.tgz", + "integrity": "sha512-Ov7McNX1sFaEX9NWijD1hIOVDDhKdnFzN9tvoa1N8xgrclouhsO4kBPVrTPhjO/zP5mn1Ww03uZ2SThNMXS7zg==", + "engines": { + "node": ">=8", + "npm": ">=5" + } + }, + "node_modules/strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "dependencies": { + "ansi-regex": "^2.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/swagger-methods": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/swagger-methods/-/swagger-methods-1.0.8.tgz", + "integrity": "sha512-G6baCwuHA+C5jf4FNOrosE4XlmGsdjbOjdBK4yuiDDj/ro9uR4Srj3OR84oQMT8F3qKp00tYNv0YN730oTHPZA==", + "deprecated": "This package is no longer being maintained." + }, + "node_modules/swagger-parser": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/swagger-parser/-/swagger-parser-4.0.2.tgz", + "integrity": "sha512-hKslog8LhsXICJ1sMLsA8b8hQ3oUEX0457aLCFJc4zz6m8drmnCtyjbVqS5HycaKFOKVolJc2wFoe8KDPWfp4g==", + "dependencies": { + "call-me-maybe": "^1.0.1", + "debug": "^3.1.0", + "json-schema-ref-parser": "^4.1.0", + "ono": "^4.0.3", + "swagger-methods": "^1.0.4", + "swagger-schema-official": "2.0.0-bab6bed", + "z-schema": "^3.19.0" + } + }, + "node_modules/swagger-parser/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/swagger-parser/node_modules/json-schema-ref-parser": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/json-schema-ref-parser/-/json-schema-ref-parser-4.1.1.tgz", + "integrity": "sha512-lByoCHZ6H2zgb6NtsXIqtzQ+6Ji7iVqnrhWxsXLhF+gXmgu6E8+ErpDxCMR439MUG1nfMjWI2HAoM8l0XgSNhw==", + "deprecated": "Please switch to @apidevtools/json-schema-ref-parser", + "dependencies": { + "call-me-maybe": "^1.0.1", + "debug": "^3.1.0", + "js-yaml": "^3.10.0", + "ono": "^4.0.3" + } + }, + "node_modules/swagger-schema-official": { + "version": "2.0.0-bab6bed", + "resolved": "https://registry.npmjs.org/swagger-schema-official/-/swagger-schema-official-2.0.0-bab6bed.tgz", + "integrity": "sha1-cAcEaNbSl3ylI3suUZyn0Gouo/0=" + }, + "node_modules/swagger-ui-dist": { + "version": "3.51.1", + "resolved": "https://registry.npmjs.org/swagger-ui-dist/-/swagger-ui-dist-3.51.1.tgz", + "integrity": "sha512-df2mEeVgnJp/FcXY3DRh3CsTfvHVTaO6g3FJP/kfwhxfOD1+YTXqBZrOIIsYTPtcRIFBkCAto0NFCxAV4XFRbw==" + }, + "node_modules/tar": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/tar/-/tar-6.1.0.tgz", + "integrity": "sha512-DUCttfhsnLCjwoDoFcI+B2iJgYa93vBnDUATYEeRx6sntCTdN01VnqsIuTlALXla/LWooNg0yEGeB+Y8WdFxGA==", + "dependencies": { + "chownr": "^2.0.0", + "fs-minipass": "^2.0.0", + "minipass": "^3.0.0", + "minizlib": "^2.1.1", + "mkdirp": "^1.0.3", + "yallist": "^4.0.0" + }, + "engines": { + "node": ">= 10" + } + }, + "node_modules/tarn": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/tarn/-/tarn-3.0.1.tgz", + "integrity": "sha512-6usSlV9KyHsspvwu2duKH+FMUhqJnAh6J5J/4MITl8s94iSUQTLkJggdiewKv4RyARQccnigV48Z+khiuVZDJw==", + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/tildify": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/tildify/-/tildify-2.0.0.tgz", + "integrity": "sha512-Cc+OraorugtXNfs50hU9KS369rFXCfgGLpfCfvlc+Ud5u6VWmUQsOAa9HbTvheQdYnrdJqqv1e5oIqXppMYnSw==", + "engines": { + "node": ">=8" + } + }, + "node_modules/uglify-js": { + "version": "3.13.10", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.13.10.tgz", + "integrity": "sha512-57H3ACYFXeo1IaZ1w02sfA71wI60MGco/IQFjOqK+WtKoprh7Go2/yvd2HPtoJILO2Or84ncLccI4xoHMTSbGg==", + "optional": true, + "bin": { + "uglifyjs": "bin/uglifyjs" + }, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" + }, + "node_modules/uuid": { + "version": "8.3.2", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", + "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", + "bin": { + "uuid": "dist/bin/uuid" + } + }, + "node_modules/validator": { + "version": "10.11.0", + "resolved": "https://registry.npmjs.org/validator/-/validator-10.11.0.tgz", + "integrity": "sha512-X/p3UZerAIsbBfN/IwahhYaBbY68EN/UQBWHtsbXGT5bfrH/p4NQzUCG1kF/rtKaNpnJ7jAu6NGTdSNtyNIXMw==", + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/wait-port": { + "version": "0.2.9", + "resolved": "https://registry.npmjs.org/wait-port/-/wait-port-0.2.9.tgz", + "integrity": "sha512-hQ/cVKsNqGZ/UbZB/oakOGFqic00YAMM5/PEj3Bt4vKarv2jWIWzDbqlwT94qMs/exAQAsvMOq99sZblV92zxQ==", + "dependencies": { + "chalk": "^2.4.2", + "commander": "^3.0.2", + "debug": "^4.1.1" + }, + "bin": { + "wait-port": "bin/wait-port.js" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/wait-port/node_modules/commander": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/commander/-/commander-3.0.2.tgz", + "integrity": "sha512-Gar0ASD4BDyKC4hl4DwHqDrmvjoxWKZigVnAbn5H1owvm4CxCPdb0HQDehwNYMJpla5+M2tPmPARzhtYuwpHow==" + }, + "node_modules/which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "which": "bin/which" + } + }, + "node_modules/wide-align": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", + "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", + "dependencies": { + "string-width": "^1.0.2 || 2" + } + }, + "node_modules/wordwrap": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", + "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=" + }, + "node_modules/wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" + }, + "node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" + }, + "node_modules/z-schema": { + "version": "3.25.1", + "resolved": "https://registry.npmjs.org/z-schema/-/z-schema-3.25.1.tgz", + "integrity": "sha512-7tDlwhrBG+oYFdXNOjILSurpfQyuVgkRe3hB2q8TEssamDHB7BbLWYkYO98nTn0FibfdFroFKDjndbgufAgS/Q==", + "dependencies": { + "core-js": "^2.5.7", + "lodash.get": "^4.0.0", + "lodash.isequal": "^4.0.0", + "validator": "^10.0.0" + }, + "bin": { + "z-schema": "bin/z-schema" + }, + "optionalDependencies": { + "commander": "^2.7.1" + } + }, + "node_modules/z-schema/node_modules/commander": { + "version": "2.20.3", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", + "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", + "optional": true + } + } +} diff --git a/KST-ASD-BI-101/cts/service/package.json b/KST-ASD-BI-101/cts/service/package.json new file mode 100644 index 0000000..535bb1e --- /dev/null +++ b/KST-ASD-BI-101/cts/service/package.json @@ -0,0 +1,42 @@ +{ + "name": "catapult-cts-service", + "version": "1.0.0", + "description": "Web service to support the Catapult CTS UI", + "main": "index.js", + "repository": { + "type": "git", + "url": "git+https://github.com/adlnet/CATAPULT.git" + }, + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1", + "secrets": "npx detect-secrets **/*.js" + }, + "author": "Rustici Software ", + "license": "Apache-2.0", + "dependencies": { + "@cmi5/requirements": "^1.0.0", + "@hapi/basic": "^6.0.0", + "@hapi/boom": "^9.1.3", + "@hapi/cookie": "^11.0.2", + "@hapi/h2o2": "^9.1.0", + "@hapi/hapi": "^20.1.5", + "@hapi/hoek": "^9.2.0", + "@hapi/inert": "^6.0.3", + "@hapi/jwt": "^2.0.1", + "@hapi/vision": "^6.1.0", + "@hapi/wreck": "^17.1.0", + "axios": "^1.6.8", + "bcrypt": "^5.0.1", + "hapi-swagger": "^14.2.1", + "iri": "^1.3.0", + "joi": "^17.4.1", + "knex": "^0.95.7", + "knex-stringcase": "^1.4.5", + "mysql": "^2.18.1", + "uuid": "^8.3.2", + "wait-port": "^0.2.9" + }, + "devDependencies": { + "detect-secrets": "^1.0.6" + } +} diff --git a/KST-ASD-BI-101/cts/service/plugins/routes/client.js b/KST-ASD-BI-101/cts/service/plugins/routes/client.js new file mode 100644 index 0000000..db71181 --- /dev/null +++ b/KST-ASD-BI-101/cts/service/plugins/routes/client.js @@ -0,0 +1,54 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +"use strict"; + +module.exports = { + name: "catapult-cts-api-routes-client", + register: (server, options) => { + server.route( + [ + // + // serve the static web client files + // + { + method: "GET", + path: "/client/{param*}", + handler: { + directory: { + path: `${__dirname}/../../client`, + listing: true + } + }, + options: { + auth: false + } + }, + + // + // Handle `/` to help web UI users get to `/client/` + // + { + method: "GET", + path: "/client", + handler: (req, h) => h.redirect("/client/"), + options: { + auth: false + } + } + ] + ); + } +}; diff --git a/KST-ASD-BI-101/cts/service/plugins/routes/v1/core.js b/KST-ASD-BI-101/cts/service/plugins/routes/v1/core.js new file mode 100644 index 0000000..06fc4a8 --- /dev/null +++ b/KST-ASD-BI-101/cts/service/plugins/routes/v1/core.js @@ -0,0 +1,221 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +"use strict"; + +const ALLOWED_ORIGIN = (process.env.HOSTNAME || "*"); + +const Bcrypt = require("bcrypt"), + Joi = require("joi"), + Boom = require("@hapi/boom"), + User = require("./lib/user"), + { AUTH_TTL_SECONDS } = require("../../../lib/consts"), + getClientSafeUser = (user) => { + delete user.password; + delete user.playerApiToken; + delete user.tenantId; + + return user; + }; + +let alreadyBootstrapped = false; + +module.exports = { + name: "catapult-cts-api-routes-v1-core", + register: (server, options) => { + server.route( + [ + // + // this route is mainly used to check whether or not a cookie provides for valid + // authentication, and in the case it does it will return information about the + // user which allows for automatic login in the web UI client + // + // it also acts as the initial request whenever the UI is loaded so use it to + // check to make sure the site has been initialized and that at least one user + // exists + // + { + method: "GET", + path: "/login", + options: { + auth: { + mode: "try" + }, + tags: ["api"], + security: true, + cors: { + origin: [ALLOWED_ORIGIN] + } + }, + handler: async (req, h) => { + const db = req.server.app.db, + responseBody = {}; + let responseStatus; + + if (req.auth.isAuthenticated) { + responseStatus = 200; + + let user; + + try { + user = await db.first("*").from("users").queryContext({jsonCols: ["roles"]}).where({id: req.auth.credentials.id}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed to retrieve user for id ${req.auth.credentials.id}: ${ex}`)); + } + + responseBody.isBootstrapped = true; + responseBody.user = getClientSafeUser(user); + + // Restore whatever the current cookie's expiration is at, for use in managing client side logged in state. + if (req.state.sid) { + responseBody.user.expiresAt = req.state.sid.expiresAt; + } + } + else { + responseStatus = 401; + + // + // check to make sure there is at least one user in the users table + // + const [query] = await db("users").count("id", {as: "count"}); + + responseBody.isBootstrapped = query.count > 0; + } + + return h.response(responseBody).code(responseStatus); + } + }, + + // + // this route allows authenticating by username/password and then optionally + // provides a cookie to prevent the need to continue to use basic auth + // + { + method: "POST", + path: "/login", + options: { + auth: false, + tags: ["api"], + validate: { + payload: Joi.object({ + username: Joi.string().required(), + password: Joi.string().required(), + storeCookie: Joi.boolean().optional() + }).label("Request-Login") + }, + security: true, + cors: { + origin: [ALLOWED_ORIGIN] + } + }, + handler: async (req, h) => { + let user; + + try { + user = await req.server.app.db.first("*").from("users").queryContext({jsonCols: ["roles"]}).where({username: req.payload.username}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed to retrieve user for username ${req.payload.username}: ${ex}`)); + } + + if (! user || ! await Bcrypt.compare(req.payload.password, user.password)) { + throw Boom.unauthorized(); + } + + const expiresAt = new Date(); + expiresAt.setSeconds(expiresAt.getSeconds() + AUTH_TTL_SECONDS) + user.expiresAt = expiresAt.toISOString(); + + if (req.payload.storeCookie) { + req.cookieAuth.set(await req.server.methods.getCredentials(user)); + } + + return getClientSafeUser(user); + } + }, + + // + // this route simply removes any previously stored auth cookie + // + { + method: "GET", + path: "/logout", + options: { + auth: false, + tags: ["api"] + }, + handler: async (req, h) => { + req.cookieAuth.clear(); + + return null; + } + }, + + // + // this route is used to establish the first user in the database and can't + // be accessed once users exist in the DB, it is intended to make it easy + // to establish deployments that are unique to few users + // + { + method: "POST", + path: "/bootstrap", + options: { + tags: ["api"], + auth: false, + validate: { + payload: Joi.object({ + firstUser: Joi.object({ + username: Joi.string().required(), + password: Joi.string().required() + }).required() + }).label("Request-Bootstrap") + } + }, + handler: async (req, h) => { + + if (!alreadyBootstrapped) { + + // + // checking that there aren't any users created yet is effectively + // the authorization for this resource + // + const db = req.server.app.db; + const [query] = await db("users").count("id", {as: "count"}); + + if (query.count > 0) { + alreadyBootstrapped = true; + } + } + + if (alreadyBootstrapped) { + throw Boom.badRequest(`This endpoint cannot be used once the system has been initialized.`); + } + + try { + // the first user has to be an admin so they can handle other users being created + await User.create(req.payload.firstUser.username, req.payload.firstUser.password, ["admin"], {req}); + } + catch (ex) { + throw Boom.internal(`Failed to create bootstrap user.`); + } + + return null; + } + } + ] + ); + } +}; diff --git a/KST-ASD-BI-101/cts/service/plugins/routes/v1/courses.js b/KST-ASD-BI-101/cts/service/plugins/routes/v1/courses.js new file mode 100644 index 0000000..f4e05ab --- /dev/null +++ b/KST-ASD-BI-101/cts/service/plugins/routes/v1/courses.js @@ -0,0 +1,260 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +"use strict"; + +const Boom = require("@hapi/boom"), + Wreck = require("@hapi/wreck"), + { v4: uuidv4 } = require("uuid"); + +module.exports = { + name: "catapult-cts-api-routes-v1-courses", + register: (server, options) => { + server.route( + [ + { + method: "POST", + path: "/courses", + options: { + tags: ["api"], + + // arbitrarily chosen large number (480 MB) + payload: { + maxBytes: 1024 * 1024 * 480, + }, + pre: [ + async (req, h) => { + req.headers.authorization = await req.server.methods.playerBearerAuthHeader(req); + + return null; + } + ] + }, + handler: { + proxy: { + passThrough: true, + xforward: true, + acceptEncoding: false, + + mapUri: (req) => ({ + uri: `${req.server.app.player.baseUrl}/api/v1/course` + }), + + onResponse: async (err, res, req, h, settings) => { + if (err !== null) { + throw Boom.internal(new Error(`Failed proxied import request: ${err}`)); + } + + let payload; + try { + payload = await Wreck.read(res, {json: true}); + } + catch (ex) { + // clean up the original response + res.destroy(); + + throw Boom.internal(new Error(`Failed to parse player request response: ${ex}`)); + } + + // clean up the original response + res.destroy(); + + if (res.statusCode !== 200) { + throw Boom.badRequest(new Error(`Failed request to player import: ${payload.message} (${payload.srcError})`), {statusCode: res.statusCode}); + } + + const db = req.server.app.db; + + let insertResult; + try { + insertResult = await db.insert( + { + tenant_id: req.auth.credentials.tenantId, + player_id: payload.id, + metadata: JSON.stringify({ + version: 1, + structure: payload.structure, + aus: payload.metadata.aus + }) + } + ).into("courses"); + } + catch (ex) { + throw Boom.internal(new Error(`Failed to insert course (${payload.id}): ${ex}`)); + } + + return db.first("*").from("courses").queryContext({jsonCols: ["metadata"]}).where({tenantId: req.auth.credentials.tenantId, id: insertResult}); + } + } + } + }, + + { + method: "GET", + path: "/courses", + options: { + tags: ["api"] + }, + handler: async (req, h) => { + const db = req.server.app.db, + items = await db + .select( + "*" + ) + .from("courses") + .leftJoin( + db + .select("course_id", db.max("created_at").as("tested_at")) + .from("registrations") + .where({"registrations.tenant_id": req.auth.credentials.tenantId}) + .groupBy("course_id") + .as("most_recent_test"), + "most_recent_test.course_id", + "courses.id" + ) + .leftJoin( + "registrations", + function () { + this.on("registrations.course_id", "most_recent_test.course_id"); + this.andOn("registrations.created_at", "most_recent_test.tested_at") + } + ) + .where({"courses.tenant_id": req.auth.credentials.tenantId}) + .orderBy("courses.created_at", "desc") + .options({nestTables: true}) + .queryContext({jsonCols: ["courses.metadata", "registrations.metadata"]}); + + return { + items: items.map( + (row) => ({ + id: row.courses.id, + createdAt: row.courses.created_at, + metadata: row.courses.metadata, + lastTested: row.mostRecentTest.tested_at, + testResult: row.registrations.metadata ? row.registrations.metadata.result : "not-started", + testId: row.registrations.id + }) + ) + }; + } + }, + + { + method: "GET", + path: "/courses/{id}", + options: { + tags: ["api"] + }, + handler: async (req, h) => { + const result = await req.server.app.db.first("*").from("courses").queryContext({jsonCols: ["metadata"]}).where({tenantId: req.auth.credentials.tenantId, id: req.params.id}); + + if (! result) { + return Boom.notFound(); + } + + return result; + } + }, + + { + method: "DELETE", + path: "/courses/{id}", + options: { + tags: ["api"], + pre: [ + async (req, h) => { + req.headers.authorization = await req.server.methods.playerBearerAuthHeader(req); + + return null; + } + ] + }, + handler: { + proxy: { + passThrough: true, + xforward: true, + + mapUri: async (req) => { + const result = await req.server.app.db.first("playerId").from("courses").where({tenantId: req.auth.credentials.tenantId, id: req.params.id}); + + if (! result) { + throw Boom.internal(new Error(`Failed to retrieve player id for course: ${req.params.id}`)); + } + + return { + uri: `${req.server.app.player.baseUrl}/api/v1/course/${result.playerId}` + }; + }, + + onResponse: async (err, res, req, h, settings) => { + if (err !== null) { + // clean up the original response + res.destroy(); + + throw Boom.internal(new Error(`Failed proxied delete request: ${err}`)); + } + + if (res.statusCode !== 204) { + let payload; + try { + payload = await Wreck.read(res, {json: true}); + } + catch (ex) { + // clean up the original response + res.destroy(); + + throw Boom.internal(new Error(`Failed to parse player request response (${res.statusCode}): ${ex}`)); + } + + // clean up the original response + res.destroy(); + + throw Boom.internal(new Error(`Failed request to player delete: ${payload.message} (${payload.srcError})`), {statusCode: res.statusCode}); + } + + + // clean up the original response + res.destroy(); + + const db = req.server.app.db; + + let deleteResult; + try { + deleteResult = await db("courses").where({tenantId: req.auth.credentials.tenantId, id: req.params.id}).delete(); + } + catch (ex) { + throw Boom.internal(new Error(`Failed to delete course from database: ${ex}`)); + } + + return null; + } + } + } + }, + + { + method: "GET", + path: "/courses/{id}/tests", + options: { + tags: ["api"] + }, + handler: async (req, h) => ({ + items: await req.server.app.db.select("*").queryContext({jsonCols: ["metadata"]}).from("registrations").where({tenantId: req.auth.credentials.tenantId, courseId: req.params.id}) + }) + } + ] + ); + } +}; diff --git a/KST-ASD-BI-101/cts/service/plugins/routes/v1/lib/helpers.js b/KST-ASD-BI-101/cts/service/plugins/routes/v1/lib/helpers.js new file mode 100644 index 0000000..a8984b9 --- /dev/null +++ b/KST-ASD-BI-101/cts/service/plugins/routes/v1/lib/helpers.js @@ -0,0 +1,11 @@ +module.exports = { + doesLRSResourceEnforceConcurrency: (resourcePath) => { + const concurrencyPaths = [ + "activities/state", + "activities/profile", + "agents/profile" + ]; + + return concurrencyPaths.includes(resourcePath); + } +} \ No newline at end of file diff --git a/KST-ASD-BI-101/cts/service/plugins/routes/v1/lib/user.js b/KST-ASD-BI-101/cts/service/plugins/routes/v1/lib/user.js new file mode 100644 index 0000000..9ff8d0d --- /dev/null +++ b/KST-ASD-BI-101/cts/service/plugins/routes/v1/lib/user.js @@ -0,0 +1,186 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +"use strict"; + +const Bcrypt = require("bcrypt"), + Boom = require("@hapi/boom"), + Wreck = require("@hapi/wreck"), + Jwt = require("@hapi/jwt"); + +module.exports = { + create: async (username, password, roles = [], {req}) => { + // + // need to create a tenant in the player + // + let createTenantResponse, + createTenantResponseBody; + + let auth = await req.server.methods.playerBasicAuthHeader(req); + let tenantURL = `${req.server.app.player.baseUrl}/api/v1/tenant`; + + try { + createTenantResponse = await Wreck.request( + "POST", + tenantURL, + { + headers: { + Authorization: auth + }, + payload: { + code: username + } + } + ); + createTenantResponseBody = await Wreck.read(createTenantResponse, {json: true}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed request to create player tenant: ${ex}`)); + } + + if (createTenantResponse.statusCode !== 200) { + throw Boom.internal(new Error(`Failed to create player tenant (${createTenantResponse.statusCode}): ${createTenantResponseBody.message}${createTenantResponseBody.srcError ? " (" + createTenantResponseBody.srcError + ")" : ""}`)); + } + + const playerTenantId = createTenantResponseBody.id; + + // + // with the tenant created get a token for this user to use + // to access the player API for that tenant + // + let createTokenResponse, + createTokenResponseBody; + + try { + createTokenResponse = await Wreck.request( + "POST", + `${req.server.app.player.baseUrl}/api/v1/auth`, + { + headers: { + Authorization: await req.server.methods.playerBasicAuthHeader(req) + }, + payload: { + tenantId: playerTenantId, + audience: `cts-${username}` + } + } + ); + createTokenResponseBody = await Wreck.read(createTokenResponse, {json: true}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed request to create player tenant: ${ex}`)); + } + + if (createTokenResponse.statusCode !== 200) { + throw Boom.internal(new Error(`Failed to retrieve player token (${createTokenResponse.statusCode}): ${createTokenResponseBody.message}${createTokenResponseBody.srcError ? " (" + createTokenResponseBody.srcError + ")" : ""}`)); + } + + const playerApiToken = createTokenResponseBody.token; + + let userId, + tenantId; + + await req.server.app.db.transaction( + async (txn) => { + // + // create a tenant for this user + // + try { + const insertResult = await txn.insert( + { + code: `user-${username}`, + playerTenantId + } + ).into("tenants"); + + tenantId = insertResult[0]; + } + catch (ex) { + throw new Error(`Failed to insert tenant: ${ex}`); + } + + // + // finally create the user which contains the token needed to access + // the player API + // + try { + const insertResult = await txn.insert( + { + tenantId, + username: username, + password: await Bcrypt.hash(password, 8), + playerApiToken, + roles: JSON.stringify([ + "user", + ...roles + ]) + } + ).into("users"); + + userId = insertResult[0]; + } + catch (ex) { + throw Boom.internal(new Error(`Failed to insert into users: ${ex}`)); + } + } + ); + + return {userId, tenantId}; + }, + + delete: async (id, {req}) => { + const db = req.server.app.db, + user = await db.first("*").from("users").where({id}), + token = Jwt.token.decode(user.playerApiToken), + playerTenantId = token.decoded.payload.sub; + + let deleteTenantResponse; + + try { + deleteTenantResponse = await Wreck.request( + "DELETE", + `${req.server.app.player.baseUrl}/api/v1/tenant/${playerTenantId}`, + { + headers: { + Authorization: await req.server.methods.playerBasicAuthHeader(req) + } + } + ); + } + catch (ex) { + throw Boom.internal(new Error(`Failed request to delete player tenant: ${ex}`)); + } + + if (deleteTenantResponse.statusCode !== 204) { + const deleteTenantResponseBody = await Wreck.read(deleteTenantResponse, {json: true}); + + throw Boom.internal(new Error(`Failed to delete player tenant (${deleteTenantResponse.statusCode}): ${deleteTenantResponseBody.message}${deleteTenantResponseBody.srcError ? " (" + deleteTenantResponseBody.srcError + ")" : ""}`)); + } + + try { + await db("users").where({id: req.params.id}).delete(); + } + catch (ex) { + throw Boom.internal(new Error(`Failed to delete user from database: ${ex}`)); + } + + try { + await db("tenants").where({playerTenantId}).delete(); + } + catch (ex) { + throw Boom.internal(new Error(`Failed to delete tenant from database: ${ex}`)); + } + } +}; diff --git a/KST-ASD-BI-101/cts/service/plugins/routes/v1/mgmt.js b/KST-ASD-BI-101/cts/service/plugins/routes/v1/mgmt.js new file mode 100644 index 0000000..95a45b0 --- /dev/null +++ b/KST-ASD-BI-101/cts/service/plugins/routes/v1/mgmt.js @@ -0,0 +1,44 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +"use strict"; + +module.exports = { + name: "catapult-cts-api-routes-v1-mgmt", + register: (server, options) => { + server.route( + { + method: "GET", + path: "/ping", + options: { + tags: ["api"] + }, + handler: (req, h) => ({ + ok: true + }) + }, + { + method: "GET", + path: "/about", + options: { + tags: ["api"] + }, + handler: (req, h) => ({ + description: "catapult-cts-service" + }) + } + ); + } +}; diff --git a/KST-ASD-BI-101/cts/service/plugins/routes/v1/sessions.js b/KST-ASD-BI-101/cts/service/plugins/routes/v1/sessions.js new file mode 100644 index 0000000..349420f --- /dev/null +++ b/KST-ASD-BI-101/cts/service/plugins/routes/v1/sessions.js @@ -0,0 +1,647 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +"use strict"; + +const stream = require("stream"), + Boom = require("@hapi/boom"), + Wreck = require("@hapi/wreck"), + Hoek = require("@hapi/hoek"), + Joi = require("joi"), + { v4: uuidv4 } = require("uuid"), + Requirements = require("@cmi5/requirements"), + sessions = {}, + getClientSafeSession = (session) => { + delete session.playerId; + delete session.playerAuLaunchUrl; + delete session.playerEndpoint; + delete session.playerFetch; + + return session; + }; + +const helpers = require("./lib/helpers"); + +module.exports = { + name: "catapult-cts-api-routes-v1-sessions", + register: (server, options) => { + server.decorate( + "toolkit", + "sessionEvent", + async (sessionId, tenantId, db, rawData) => { + const metadata = { + version: 1, + ...rawData + }, + log = { + tenantId, + sessionId, + metadata: JSON.stringify(metadata) + }; + + try { + const insertResult = await db.insert(log).into("sessions_logs"); + + log.id = insertResult[0]; + } + catch (ex) { + console.error(`Failed to write to sessions_logs(${sessionId}): ${ex}`); + } + + log.metadata = metadata; + + if (sessions[sessionId]) { + sessions[sessionId].write(JSON.stringify(log) + "\n"); + } + } + ); + + server.route( + [ + // + // not proxying this request because have to alter the body based on + // converting the CTS course id to the stored Player course id + // + { + method: "POST", + path: "/sessions", + options: { + tags: ["api"], + validate: { + payload: Joi.object({ + testId: Joi.number().integer().min(0).required(), + auIndex: Joi.number().integer().min(0).required(), + alternateEntitlementKey: Joi.string().optional(), + launchMode: Joi.any().allow("Normal", "Browse", "Review").optional(), + launchMethod: Joi.any().allow("iframe", "newWindow").optional(), + contextTemplateAdditions: Joi.object().optional(), + launchParameters: Joi.string().optional(), + masteryScore: Joi.number().positive().min(0).max(1).optional(), + moveOn: Joi.any().allow("Passed", "Completed", "CompletedAndPassed", "CompletedOrPassed", "NotApplicable").optional() + }).required().label("Request-PostSession") + } + }, + handler: async (req, h) => { + const db = req.server.app.db, + tenantId = req.auth.credentials.tenantId, + testId = req.payload.testId, + auIndex = req.payload.auIndex, + baseUrl = (req.headers["x-forwarded-proto"] ? `${req.headers["x-forwarded-proto"]}:` : req.url.protocol) + `//${req.info.host}`; + + let queryResult; + + try { + queryResult = await db + .first("*") + .queryContext({jsonCols: ["registrations.metadata", "courses.metadata"]}) + .from("registrations") + .leftJoin("courses", "registrations.course_id", "courses.id") + .where({"registrations.tenantId": tenantId, "registrations.id": testId}) + .options({nestTables: true}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed to retrieve registration for id ${testId}: ${ex}`)); + } + + if (! queryResult) { + throw Boom.notFound(`registration: ${testId}`); + } + + let createResponse, + createResponseBody; + + try { + createResponse = await Wreck.request( + "POST", + `${req.server.app.player.baseUrl}/api/v1/course/${queryResult.courses.player_id}/launch-url/${auIndex}`, + { + headers: { + Authorization: await req.server.methods.playerBearerAuthHeader(req) + }, + payload: { + actor: queryResult.registrations.metadata.actor, + reg: queryResult.registrations.code, + contextTemplateAdditions: req.payload.contextTemplateAdditions, + launchMode: req.payload.launchMode, + launchParameters: req.payload.launchParameters, + masteryScore: req.payload.masteryScore, + moveOn: req.payload.moveOn, + alternateEntitlementKey: req.payload.alternateEntitlementKey, + returnUrl: `${baseUrl}/api/v1/sessions/__sessionId__/return-url` + } + } + ); + createResponseBody = await Wreck.read(createResponse, {json: true}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed to request AU launch url from player: ${ex}`)); + } + + if (createResponse.statusCode !== 200) { + throw Boom.internal(new Error(`Failed to retrieve AU launch URL from player (${createResponse.statusCode}): ${createResponseBody.message}${createResponseBody.srcError ? " (" + createResponseBody.srcError + ")" : ""}`)); + } + + const playerAuLaunchUrl = createResponseBody.url, + playerAuLaunchUrlParsed = new URL(playerAuLaunchUrl), + playerEndpoint = playerAuLaunchUrlParsed.searchParams.get("endpoint"), + playerFetch = playerAuLaunchUrlParsed.searchParams.get("fetch"); + let sessionId; + + console.log("PLAYER FETCH:", playerFetch); + + try { + const sessionInsert = await db.insert( + { + tenant_id: tenantId, + player_id: createResponseBody.id, + registration_id: testId, + au_index: auIndex, + player_au_launch_url: playerAuLaunchUrl, + player_endpoint: playerEndpoint, + player_fetch: playerFetch, + metadata: JSON.stringify( + { + version: 1, + launchMethod: createResponseBody.launchMethod, + violatedReqIds: [] + } + ) + } + ).into("sessions"); + + sessionId = sessionInsert[0]; + } + catch (ex) { + throw Boom.internal(new Error(`Failed to insert into sessions: ${ex}`)); + } + + const auTitle = queryResult.courses.metadata.aus[auIndex].title[0].text; + + await h.registrationEvent(testId, tenantId, db, {kind: "api", resource: "sessions:create", sessionId, auIndex, summary: `Launched AU: ${auTitle}`}); + await h.sessionEvent(sessionId, tenantId, db, {kind: "api", resource: "create", summary: `AU ${auTitle} session initiated`}); + + // + // swap endpoint, fetch for proxied versions + // + playerAuLaunchUrlParsed.searchParams.set("endpoint", `${baseUrl}/api/v1/sessions/${sessionId}/lrs`); + playerAuLaunchUrlParsed.searchParams.set("fetch", `${baseUrl}/api/v1/sessions/${sessionId}/fetch`); + + const ctsLaunchUrl = playerAuLaunchUrlParsed.href; + const result = await db.first("*").from("sessions").queryContext({jsonCols: ["metadata"]}).where({tenantId, id: sessionId}); + + result.launchUrl = ctsLaunchUrl; + result.launchMethod = createResponseBody.launchMethod === "OwnWindow" ? "newWindow" : "iframe"; + + return getClientSafeSession(result); + } + }, + + { + method: "GET", + path: "/sessions/{id}", + options: { + tags: ["api"] + }, + handler: async (req, h) => { + const result = await req.server.app.db.first("*").from("sessions").queryContext({jsonCols: ["metadata"]}).where({tenantId: req.auth.credentials.tenantId, id: req.params.id}); + + if (! result) { + return Boom.notFound(); + } + + return getClientSafeSession(result); + } + }, + + { + method: "GET", + path: "/sessions/{id}/return-url", + options: { + tags: ["api"] + }, + handler: async (req, h) => { + const tenantId = req.auth.credentials.tenantId, + db = req.server.app.db, + result = await db.first("*").from("sessions").queryContext({jsonCols: ["metadata"]}).where({tenantId, id: req.params.id}); + + if (! result) { + return Boom.notFound(); + } + + await h.sessionEvent(req.params.id, tenantId, db, {kind: "spec", resource: "return-url", summary: "Return URL loaded"}); + + return "Session has ended, use "Close" button to return to test details page."; + } + }, + + { + method: "GET", + path: "/sessions/{id}/logs", + options: { + tags: ["api"], + validate: { + query: Joi.object({ + listen: Joi.any().optional().description("Switches the response to be a stream that will provide additional logs as they are created") + }).optional().label("RequestParams-SessionLogs") + } + }, + handler: async (req, h) => { + const tenantId = req.auth.credentials.tenantId, + db = req.server.app.db, + result = await db.first("id").from("sessions").where({tenantId, id: req.params.id}); + + if (! result) { + return Boom.notFound(); + } + + const logs = await db.select("*").queryContext({jsonCols: ["metadata"]}).from("sessions_logs").where({tenantId, sessionId: result.id}).orderBy("created_at", "desc"); + + if (! req.query.listen) { + return logs; + } + + const channel = new stream.PassThrough, + response = h.response(channel); + + sessions[req.params.id] = channel; + + for (const log of logs) { + channel.write(JSON.stringify(log) + "\n"); + } + + req.raw.req.on( + "close", + () => { + delete sessions[req.params.id]; + } + ); + + return response; + } + }, + + { + method: "POST", + path: "/sessions/{id}/abandon", + options: { + tags: ["api"] + }, + handler: async (req, h) => { + const db = req.server.app.db, + sessionId = req.params.id, + tenantId = req.auth.credentials.tenantId, + result = await db.first("*").from("sessions").where({tenantId, id: sessionId }); + + if (! result) { + return Boom.notFound(); + } + + let abandonResponse, + abandonResponseBody; + + try { + abandonResponse = await Wreck.request( + "POST", + `${req.server.app.player.baseUrl}/api/v1/session/${result.playerId}/abandon`, + { + headers: { + Authorization: await req.server.methods.playerBearerAuthHeader(req) + } + } + ); + abandonResponseBody = await Wreck.read(abandonResponse, {json: true}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed request to player to abandon session: ${ex}`)); + } + + if (abandonResponse.statusCode !== 204) { + throw Boom.internal(new Error(`Failed to abandon session in player (${abandonResponse.statusCode}): ${abandonResponseBody.message}${abandonResponseBody.srcError ? " (" + abandonResponseBody.srcError + ")" : ""}`)); + } + + await h.sessionEvent(sessionId, tenantId, db, {kind: "spec", resource: "abandon", summary: "Session abandoned"}); + + return null; + } + }, + + { + method: "POST", + path: "/sessions/{id}/fetch", + options: { + // turn off auth because this is effectively an auth request + auth: false + }, + handler: async (req, h) => { + const db = req.server.app.db; + + try { + let session; + + try { + session = await db.first("*").from("sessions").queryContext({jsonCols: ["metadata"]}).where({id: req.params.id}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed to select session data: ${ex}`)); + } + + if (! session) { + throw Boom.notFound(`session: ${req.params.id}`); + } + + let fetchResponse, + fetchResponseBody; + + console.log("POSTING FETCH:", session.playerFetch); + + try { + fetchResponse = await Wreck.request( + "POST", + session.playerFetch + ); + fetchResponseBody = await Wreck.read(fetchResponse, {json: true}); + } + catch (ex) { + console.error(ex); + throw Boom.internal(new Error(`Failed to request fetch url from player: ${ex}`)); + } + + await h.sessionEvent(req.params.id, session.tenantId, db, {kind: "spec", resource: "fetch", playerResponseStatusCode: fetchResponse.statusCode, summary: "Fetch URL used"}); + + return h.response(fetchResponseBody).code(fetchResponse.statusCode); + } + catch (ex) { + return h.response( + { + "error-code": "3", + "error-text": `General Application Error: ${ex}` + } + ).code(400); + } + } + }, + + // OPTIONS requests don't provide an authorization header, so set this up + // as a separate route without auth + { + method: [ + "OPTIONS" + ], + path: "/sessions/{id}/lrs/{resource*}", + options: { + auth: false, + + // + // turn off CORS for this handler because the LRS will provide back the right headers + // this just needs to pass them through, enabling CORS for this route means they get + // overwritten by the Hapi handling + // + cors: false + }, + handler: { + proxy: { + passThrough: true, + xforward: true, + + // + // map the requested resource (i.e. "statements" or "activities/state") from the + // provided LRS endpoint to the resource at the underlying LRS endpoint, while + // maintaining any query string parameters + // + mapUri: (req) => ({ + uri: `${req.server.app.player.baseUrl}/lrs/${req.params.resource}${req.url.search}` + }) + } + } + }, + + // + // proxy the LRS based on the session identifier so that the service + // knows what session to log information for + // + { + method: [ + "GET", + "POST", + "PUT", + "DELETE" + ], + path: "/sessions/{id}/lrs/{resource*}", + options: { + // + // since this is effectively acting as a proxy this route doesn't use + // direct authorization, it instead relies on the player's underlying + // handling to handle invalid authorization attempts + // + auth: false, + cors: false + }, + // + // not using h2o2 to proxy these resources because there needs to be validation + // of the incoming payload which means it needs to be loaded into memory and parsed, + // etc. which h2o2 won't do with proxied requests because of the performance overhead + // so this code is nearly the same as what the handler for h2o2 does, but with fewer + // settings that weren't being used anyways + // + handler: async (req, h) => { + const db = req.server.app.db, + id = req.params.id; + let session; + + try { + session = await db.first("*").from("sessions").where({id}).queryContext({jsonCols: ["metadata"]}); + } + catch (ex) { + // console.error(0, "CAN'T SELECT SESSION", ex); + throw Boom.internal(new Error(`Failed to select session data: ${ex}`)); + } + + if (! session) { + // console.error(1, "NO SESSION", ex); + throw Boom.notFound(`session: ${id}`); + } + + const tenantId = session.tenantId; + let proxyResponse, + rawProxyResponsePayload, + response; + + try { + // + // map the requested resource (i.e. "statements" or "activities/state") from the + // provided LRS endpoint to the resource at the underlying LRS endpoint, while + // maintaining any query string parameters + // + const uri = `${req.server.app.player.baseUrl}/lrs/${req.params.resource}${req.url.search}`, + protocol = uri.split(":", 1)[0], + options = { + headers: Hoek.clone(req.headers), + payload: req.payload + }; + + delete options.headers.host; + delete options.headers["content-length"]; + + if (req.info.remotePort) { + options.headers["x-forwarded-for"] = (options.headers["x-forwarded-for"] ? options.headers["x-forwarded-for"] + "," : "") + req.info.remoteAddress; + options.headers["x-forwarded-port"] = options.headers["x-forwarded-port"] || req.info.remotePort; + options.headers["x-forwarded-proto"] = options.headers["x-forwarded-proto"] || req.server.info.protocol; + options.headers["x-forwarded-host"] = options.headers["x-forwarded-host"] || req.info.host; + } + + // The cmi5 JS stuff won't know what the configured LRS's xAPI version is + // between 1.0.3 and 2.0, so replace that here if it was specified. + // + let configuredXAPIVersion = process.env.LRS_XAPI_VERSION; + if (configuredXAPIVersion != undefined) + options.headers["x-experience-api-version"] = configuredXAPIVersion; + + // Concurrency check required or xAPI 2.0 + // + if (req.method == "post" || req.method == "put") { + + let lrsResourcePath = req.params.resource; + + let requiresConcurrency = helpers.doesLRSResourceEnforceConcurrency(lrsResourcePath); + let isMissingEtagHeader = options.headers["if-match"] == undefined; + + if (requiresConcurrency && isMissingEtagHeader) { + let etagResponse = await Wreck.request("get", uri, { headers: options.headers }); + if (etagResponse.statusCode < 400) { + let etag = etagResponse.headers["etag"]; + options.headers["if-match"] = etag; + } + + etagResponse.destroy(); + } + } + + proxyResponse = await Wreck.request(req.method, uri, options); + rawProxyResponsePayload = await Wreck.read(proxyResponse, {gunzip: true}); + + let responsePayload = rawProxyResponsePayload; + + + + if (req.method === "get" && req.params.resource === "activities/state") { + if (req.query.stateId === "LMS.LaunchData") { + const parsedPayload = JSON.parse(rawProxyResponsePayload.toString()); + + if (typeof parsedPayload.returnURL !== "undefined") { + parsedPayload.returnURL = parsedPayload.returnURL.replace("__sessionId__", id); + } + + responsePayload = parsedPayload; + } + } + + response = h.response(responsePayload).passThrough(true); + + response.code(proxyResponse.statusCode); + response.message(proxyResponse.statusMessage); + + + const skipHeaders = { + "content-encoding": true, + "content-length": true, + "transfer-encoding": true + }; + for (const [k, v] of Object.entries(proxyResponse.headers)) { + if (! skipHeaders[k.toLowerCase()]) { + response.header(k, v); + } + } + + // clean up the original response + proxyResponse.destroy(); + } + catch (ex) { + // console.error(2, ex); + throw ex; + } + + if (proxyResponse.statusCode !== 200 && proxyResponse.statusCode !== 204 && proxyResponse.headers["content-type"].startsWith("application/json")) { + const proxyResponsePayloadAsString = rawProxyResponsePayload.toString(); + let proxyResponsePayload; + + try { + proxyResponsePayload = JSON.parse(proxyResponsePayloadAsString); + } + catch (ex) { + // console.error("BAD RESPONSE DATA", ex); + console.log(`Failed JSON parse of LRS response error: ${ex} (${proxyResponsePayloadAsString})`); + } + + if (proxyResponsePayload && typeof proxyResponsePayload.violatedReqId !== "undefined") { + session.metadata.violatedReqIds.push(proxyResponsePayload.violatedReqId); + + try { + await db("sessions").update({metadata: JSON.stringify(session.metadata)}).where({id, tenantId}); + } + catch (ex) { + // console.error("CAN'T UPDATE SESSION", ex); + console.log(`Failed to update session for violated spec requirement (${proxyResponsePayload.violatedReqId}): ${ex}`); + } + + await h.sessionEvent(id, tenantId, db, {kind: "lrs", violatedReqId: proxyResponsePayload.violatedReqId, summary: `Spec requirement violated`}); + } + } + + if (req.method === "get") { + if (req.params.resource === "activities/state") { + if (req.query.stateId === "LMS.LaunchData") { + await h.sessionEvent(id, tenantId, db, {kind: "lrs", method: req.method, resource: req.params.resource, summary: "LMS Launch Data retrieved"}); + } + } + else if (req.params.resource === "activities") { + if (req.query.activityId !== null) { + await h.sessionEvent(id, tenantId, db, {kind: "lrs", method: req.method, resource: req.params.resource, summary: "Activity " + req.query.activityId + " retrieved"}); + } + } + else if (req.params.resource === "agents/profile") { + if (req.query.profileId === "cmi5LearnerPreferences") { + await h.sessionEvent(id, tenantId, db, {kind: "lrs", method: req.method, resource: req.params.resource, summary: "Learner Preferences Agent Profile Retrieved"}); + } + } + else { + await h.sessionEvent(id, tenantId, db, {kind: "lrs", method: req.method, resource: req.params.resource, summary: "Unknown"}); + } + } + else if (req.method === "put" || req.method === "post") { + if (req.params.resource === "statements") { + if (proxyResponse.statusCode === 200 || proxyResponse.statusCode === 204) { + let statements = req.payload; + + if (! Array.isArray(statements)) { + statements = [statements]; + } + + for (const st of statements) { + await h.sessionEvent(id, tenantId, db, {kind: "lrs", method: req.method, resource: req.params.resource, summary: `Statement recorded: ${st.verb.id}`}); + } + } + else { + await h.sessionEvent(id, tenantId, db, {kind: "lrs", method: req.method, resource: req.params.resource, summary: `Statement(s) rejected: ${proxyResponse.statusCode}`}); + } + } + } + + return response; + } + } + ] + ); + } +}; diff --git a/KST-ASD-BI-101/cts/service/plugins/routes/v1/tests.js b/KST-ASD-BI-101/cts/service/plugins/routes/v1/tests.js new file mode 100644 index 0000000..7f08120 --- /dev/null +++ b/KST-ASD-BI-101/cts/service/plugins/routes/v1/tests.js @@ -0,0 +1,566 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +"use strict"; + +const Boom = require("@hapi/boom"), + Wreck = require("@hapi/wreck"), + Hoek = require("@hapi/hoek"), + Joi = require("joi"), + { v4: uuidv4 } = require("uuid"), + iri = require("iri"), + + // sessions is optional because we know calling this from registration creation + // will never have any sessions + getClientSafeReg = (registration, playerResponseBody, sessionsByAu = []) => { + const result = Hoek.clone(registration); + + delete result.playerId; + + result.metadata.actor = playerResponseBody.actor; + result.metadata.isSatisfied = playerResponseBody.isSatisfied; + result.metadata.moveOn = playerResponseBody.metadata.moveOn; + result.metadata.aus = playerResponseBody.aus; + + let pending = 0, + notStarted = 0, + conformant = 0, + nonConformant = 0; + + result.metadata.aus.forEach( + (au, index) => { + if (sessionsByAu[index] && sessionsByAu[index].some((session) => session.metadata.violatedReqIds.length > 0)) { + au.result = "non-conformant"; + nonConformant += 1; + } + else if (au.hasBeenAttempted && au.isSatisfied && ! au.isWaived) { + au.result = "conformant"; + conformant += 1; + } + else if (au.hasBeenAttempted) { + au.result = "pending"; + pending += 1; + } + else { + au.result = "not-started"; + notStarted += 1; + } + } + ); + + if (! pending && ! notStarted && ! nonConformant) { + result.metadata.result = "conformant"; + } + else if (nonConformant) { + result.metadata.result = "non-conformant"; + } + else if (pending || conformant) { + result.metadata.result = "pending"; + } + else { + result.metadata.result = "not-started"; + } + + return result; + }; + +module.exports = { + name: "catapult-cts-api-routes-v1-tests", + register: (server, options) => { + server.decorate( + "toolkit", + "registrationEvent", + async (registrationId, tenantId, db, rawData) => { + try { + await db.insert( + { + tenantId, + registrationId, + metadata: JSON.stringify({ + version: 1, + ...rawData + }) + } + ).into("registrations_logs"); + } + catch (ex) { + console.log(`Failed to write to registrations_logs (${registrationId}): ${ex}`); + } + } + ); + + server.route( + [ + // + // not proxying this request because have to alter the body based on + // converting the CTS course id to the stored Player course id + // + { + method: "POST", + path: "/tests", + options: { + tags: ["api"], + validate: { + payload: Joi.object({ + courseId: Joi.number().min(0).required(), + actor: Joi.object({ + account: Joi.object({ + name: Joi.string().required(), + homePage: Joi.string().required().custom((value, helpers) => { + try { + new iri.IRI(value).toAbsolute(); + } + catch (ex) { + throw new Error("account homepage must be a valid IRI"); + } + + return value; + }) + }).required(), + objectType: Joi.any().allow("Agent").optional(), + name: Joi.string().optional() + }).required() + }).required().label("Request-PostTest") + } + }, + handler: async (req, h) => { + const db = req.server.app.db, + tenantId = req.auth.credentials.tenantId; + + let course; + + try { + course = await db.first("*").from("courses").queryContext({jsonCols: ["metadata"]}).where({tenantId, id: req.payload.courseId}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed to retrieve course for id ${req.payload.courseId}: ${ex}`)); + } + + if (! course) { + throw Boom.notFound(`course: ${req.payload.courseId}`); + } + + let createResponse, + createResponseBody; + + try { + createResponse = await Wreck.request( + "POST", + `${req.server.app.player.baseUrl}/api/v1/registration`, + { + headers: { + Authorization: await req.server.methods.playerBearerAuthHeader(req) + }, + payload: { + courseId: course.playerId, + actor: req.payload.actor + } + } + ); + createResponseBody = await Wreck.read(createResponse, {json: true}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed request to create player registration: ${ex}`)); + } + + if (createResponse.statusCode !== 200) { + throw Boom.internal(new Error(`Failed to create player registration (${createResponse.statusCode}): ${createResponseBody.message}${createResponseBody.srcError ? " (" + createResponseBody.srcError + ")" : ""}`)); + } + + // Create an Agent Profile for this new user. + // + let lrsWreck = Wreck.defaults(await req.server.methods.lrsWreckDefaults(req)); + let profileCreationRes = await lrsWreck.request( + "POST", + "agents/profile?" + new URLSearchParams( + { + profileId: "cmi5LearnerPreferences", + agent: JSON.stringify(req.payload.actor) + } + ).toString(), + { + payload: { + languagePreference: "en-US,fr-FR,fr-BE", + audiePreference: "on" + } + } + ) + .catch(err => console.error("Failed to Create Agent Profile", profileCreationRes.statusCode, err)); + + const txn = await db.transaction(); + let registrationId; + + try { + const insertResult = await txn.insert( + { + tenantId, + playerId: createResponseBody.id, + code: createResponseBody.code, + courseId: req.payload.courseId, + metadata: JSON.stringify({ + version: 1, + + // storing these locally because they are used to build + // the list of tests + actor: createResponseBody.actor, + result: "not-started" + }) + } + ).into("registrations"); + + registrationId = insertResult[0]; + } + catch (ex) { + await txn.rollback(); + throw Boom.internal(new Error(`Failed to insert into registrations: ${ex}`)); + } + + await h.registrationEvent( + registrationId, + tenantId, + txn, + { + kind: "api", + resource: "registration:create", + registrationId, + registrationCode: createResponseBody.code, + summary: `Registration Created` + } + ); + + const result = await txn.first("*").from("registrations").where({id: registrationId, tenantId}).queryContext({jsonCols: ["metadata"]}); + + await txn.commit(); + + return getClientSafeReg(result, createResponseBody); + } + }, + + { + method: "GET", + path: "/tests/{id}", + options: { + tags: ["api"] + }, + handler: async (req, h) => { + const db = req.server.app.db, + id = req.params.id, + tenantId = req.auth.credentials.tenantId, + registrationFromSelect = await db.first("*").from("registrations").where({id, tenantId}).queryContext({jsonCols: ["metadata"]}); + + if (! registrationFromSelect) { + return Boom.notFound(); + } + + let response, + responseBody; + + try { + response = await Wreck.request( + "GET", + `${req.server.app.player.baseUrl}/api/v1/registration/${registrationFromSelect.playerId}`, + { + headers: { + Authorization: await req.server.methods.playerBearerAuthHeader(req) + } + } + ); + responseBody = await Wreck.read(response, {json: true}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed request to player to get registration details: ${ex}`)); + } + + if (response.statusCode !== 200) { + throw Boom.internal(new Error(`Failed to get player registration details (${response.statusCode}): ${responseBody.message}${responseBody.srcError ? " (" + responseBody.srcError + ")" : ""}`)); + } + + const sessions = await db.select("id", "au_index", "metadata").from("sessions").where({registrationId: id, tenantId}).queryContext({jsonCols: ["metadata"]}).orderBy("au_index"), + sessionsByAu = []; + + for (const session of sessions) { + sessionsByAu[session.auIndex] = sessionsByAu[session.auIndex] || []; + sessionsByAu[session.auIndex].push(session); + } + + const currentCachedResult = registrationFromSelect.metadata.result, + registration = getClientSafeReg(registrationFromSelect, responseBody, sessionsByAu); + + // + // check to see if the test result determined from the newly updated player + // response is different than the one currently cached in the metadata, if it + // it then update it + // + if (registration.metadata.result !== registrationFromSelect.metadata.result) { + try { + await db("registrations").update({metadata: JSON.stringify(registration.metadata)}).where({id, tenantId}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed to update registration metadata: ${ex}`)); + } + } + + return registration; + } + }, + + { + method: "GET", + path: "/tests/{id}/logs", + options: { + tags: ["api"] + }, + handler: async (req, h) => { + const tenantId = req.auth.credentials.tenantId, + db = req.server.app.db; + + let registrationLogs; + + try { + registrationLogs = await db + .select("*") + .from("registrations_logs") + .queryContext({jsonCols: ["metadata"]}) + .where({tenantId, registrationId: req.params.id}) + .orderBy("created_at"); + } + catch (ex) { + throw Boom.internal(`Failed to select registration logs: ${ex}`); + } + + return registrationLogs; + } + }, + + { + method: "POST", + path: "/tests/{id}/waive-au/{auIndex}", + options: { + tags: ["api"], + payload: { + parse: true + }, + validate: { + payload: Joi.object({ + reason: Joi.string().required() + }).label("Request-WaiveAU") + } + }, + handler: async (req, h) => { + const db = req.server.app.db, + registrationId = req.params.id, + auIndex = req.params.auIndex, + tenantId = req.auth.credentials.tenantId, + reason = req.payload.reason, + result = await db.first("*").from("registrations").where({tenantId, id: registrationId}); + + if (! result) { + return Boom.notFound(); + } + + let waiveResponse, + waiveResponseBody; + + try { + waiveResponse = await Wreck.request( + "POST", + `${req.server.app.player.baseUrl}/api/v1/registration/${result.playerId}/waive-au/${auIndex}`, + { + headers: { + Authorization: await req.server.methods.playerBearerAuthHeader(req) + }, + payload: { + reason + } + } + ); + waiveResponseBody = await Wreck.read(waiveResponse, {json: true}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed request to player to waive AU: ${ex}`)); + } + + if (waiveResponse.statusCode !== 204) { + throw Boom.internal(new Error(`Failed to waive AU in player registration (${waiveResponse.statusCode}): ${waiveResponseBody.message}${waiveResponseBody.srcError ? " (" + waiveResponseBody.srcError + ")" : ""}`)); + } + + await h.registrationEvent(registrationId, tenantId, db, {kind: "spec", auIndex, reason, resource: "registration:waive-au", summary: `Waived (${auIndex})`}); + + return null; + } + }, + + { + method: "GET", + path: "/tests/{id}/learner-prefs", + options: { + tags: ["api"], + cors: { + additionalExposedHeaders: ["Etag"] + } + }, + handler: async (req, h) => { + const db = req.server.app.db, + registrationId = req.params.id, + tenantId = req.auth.credentials.tenantId, + registration = await db.first("*").from("registrations").where({tenantId, id: registrationId}); + + if (! registration) { + return Boom.notFound(); + } + + let response, + responseBody; + + try { + response = await Wreck.request( + "GET", + `${req.server.app.player.baseUrl}/api/v1/registration/${registration.playerId}/learner-prefs`, + { + headers: { + Authorization: await req.server.methods.playerBearerAuthHeader(req) + } + } + ); + responseBody = await Wreck.read(response, {json: true}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed request to player to get learner preferences: ${ex}`)); + } + + if (response.statusCode !== 200 && response.statusCode !== 404) { + throw Boom.internal(new Error(`Failed to request learner preferences from player (${response.statusCode}): ${responseBody.message}${responseBody.srcError ? " (" + responseBody.srcError + ")" : ""}`)); + } + + const result = h.response(responseBody); + + result.code(response.statusCode); + result.message(response.statusMessage); + result.header("Etag", response.headers.etag); + + return result; + } + }, + + { + method: "POST", + path: "/tests/{id}/learner-prefs", + options: { + tags: ["api"], + cors: { + additionalHeaders: ["If-Match"] + }, + payload: { + parse: true + }, + validate: { + payload: Joi.object({ + languagePreference: Joi.string().pattern(/^[-A-Za-z0-9]+(?:,[-A-Za-z0-9]+)*$/).required(), + audioPreference: Joi.string().allow("on", "off").required() + }).label("Request-PostLearnerPrefs") + } + }, + handler: async (req, h) => { + const db = req.server.app.db, + registrationId = req.params.id, + tenantId = req.auth.credentials.tenantId, + registration = await db.first("*").from("registrations").where({tenantId, id: registrationId}); + + if (! registration) { + return Boom.notFound(); + } + + let response, + responseBody; + + try { + response = await Wreck.request( + "POST", + `${req.server.app.player.baseUrl}/api/v1/registration/${registration.playerId}/learner-prefs`, + { + headers: { + Authorization: await req.server.methods.playerBearerAuthHeader(req), + "Content-Type": "application/json", + ...req.headers["if-match"] ? {"If-Match": req.headers["if-match"]} : {}, + ...req.headers["if-none-match"] ? {"If-None-Match": req.headers["if-none-match"]} : {} + }, + payload: req.payload + } + ); + responseBody = await Wreck.read(response, {json: true}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed request to player to save learner preferences: ${ex}`)); + } + + if (response.statusCode !== 204) { + throw Boom.internal(new Error(`Failed to save learner preferences in player (${response.statusCode}): ${responseBody.message}${responseBody.srcError ? " (" + responseBody.srcError + ")" : ""}`)); + } + + return null; + } + }, + + { + method: "DELETE", + path: "/tests/{id}/learner-prefs", + options: { + tags: ["api"], + cors: { + additionalHeaders: ["If-Match"] + } + }, + handler: async (req, h) => { + const db = req.server.app.db, + registrationId = req.params.id, + tenantId = req.auth.credentials.tenantId, + registration = await db.first("*").from("registrations").where({tenantId, id: registrationId}); + + if (! registration) { + return Boom.notFound(); + } + + let response, + responseBody; + + try { + response = await Wreck.request( + "DELETE", + `${req.server.app.player.baseUrl}/api/v1/registration/${registration.playerId}/learner-prefs`, + { + headers: { + Authorization: await req.server.methods.playerBearerAuthHeader(req), + ...req.headers["if-match"] ? {"If-Match": req.headers["if-match"]} : {} + // ...req.headers["if-none-match"] ? {"If-None-Match": req.headers["if-none-match"]} : {} + } + } + ); + responseBody = await Wreck.read(response, {json: true}); + } + catch (ex) { + throw Boom.internal(new Error(`Failed request to player to delete learner preferences: ${ex}`)); + } + + if (response.statusCode !== 204) { + throw Boom.internal(new Error(`Failed to delete learner preferences in player (${response.statusCode}): ${responseBody.message}${responseBody.srcError ? " (" + responseBody.srcError + ")" : ""}`)); + } + + return null; + } + } + ] + ); + } +}; diff --git a/KST-ASD-BI-101/cts/service/plugins/routes/v1/users.js b/KST-ASD-BI-101/cts/service/plugins/routes/v1/users.js new file mode 100644 index 0000000..0d41f51 --- /dev/null +++ b/KST-ASD-BI-101/cts/service/plugins/routes/v1/users.js @@ -0,0 +1,125 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +"use strict"; + +const Boom = require("@hapi/boom"), + Hoek = require("@hapi/hoek"), + Joi = require("joi"), + User = require("./lib/user"), + isAdmin = (req) => { + if (req.auth.credentials.roles.includes("admin")) { + return; + } + + throw Boom.forbidden("Not an admin"); + }, + getClientSafeUser = (user) => { + const safe = Hoek.clone(user); + + delete safe.tenantId; + delete safe.password; + delete safe.playerApiToken; + + return safe; + }; + +module.exports = { + name: "catapult-cts-api-routes-v1-users", + register: (server, options) => { + server.route( + [ + { + method: "POST", + path: "/users", + options: { + tags: ["api"], + validate: { + payload: Joi.object({ + username: Joi.string().required(), + password: Joi.string().required(), + roles: Joi.array().optional() + }).required().label("Request-PostUser") + } + }, + handler: async (req, h) => { + isAdmin(req); + + const {userId, tenantId} = await User.create(req.payload.username, req.payload.password, req.payload.roles, {req}), + result = await req.server.app.db.first("*").from("users").queryContext({jsonCols: ["roles"]}).where({id: userId}); + + return getClientSafeUser(result); + } + }, + + { + method: "GET", + path: "/users", + options: { + tags: ["api"] + }, + handler: async (req, h) => { + isAdmin(req); + + const db = req.server.app.db, + users = await db.select( "*").from("users").queryContext({jsonCols: ["roles"]}).orderBy("created_at", "desc"); + + return { + items: users.map(getClientSafeUser) + }; + } + }, + + { + method: "GET", + path: "/users/{id}", + options: { + tags: ["api"] + }, + handler: async (req, h) => { + isAdmin(req); + + const result = await req.server.app.db.first("*").from("users").queryContext({jsonCols: ["roles"]}).where({id: req.params.id}); + + if (! result) { + return Boom.notFound(); + } + + return getClientSafeUser(result); + } + }, + + { + method: "DELETE", + path: "/users/{id}", + options: { + tags: ["api"] + }, + handler: async (req, h) => { + isAdmin(req); + + if (Number.parseInt(req.params.id) === req.auth.credentials.id) { + throw Boom.forbidden("Can't delete self"); + } + + await User.delete(req.params.id, {req}); + + return null; + } + } + ] + ); + } +}; diff --git a/KST-ASD-BI-101/docker-compose.yaml b/KST-ASD-BI-101/docker-compose.yaml new file mode 100644 index 0000000..2bbc954 --- /dev/null +++ b/KST-ASD-BI-101/docker-compose.yaml @@ -0,0 +1,82 @@ +# Copyleft 2024 Kusala Tech +# +# Licensed under the GNU General Public License v3.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# +# https://www.gnu.org/licenses/gpl-3.0.en.html +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on +# an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +# Copyright 2021 Rustici Software +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +services: + webservice: + image: adlhub/player + ports: + - ${HOST_PORT}:3398 + depends_on: + - rdbms + volumes: + - ./migrations:/usr/src/app/migrations:ro + - ./seeds:/usr/src/app/seeds:ro + - ./:/usr/src/app/var/content + environment: + - CONTENT_URL + - API_KEY + - API_SECRET + - TOKEN_SECRET + - LRS_ENDPOINT + - LRS_USERNAME + - LRS_PASSWORD + - LRS_XAPI_VERSIONs + - DB_HOST + - DB_NAME + - DB_USERNAME + - DB_PASSWOD + # - DATABASE_USER=catapult + # - DATABASE_USER_PASSWORD=quartz + # - DATABASE_NAME=catapult_player + - FIRST_TENANT_NAME + - PLAYER_API_ROOT=${PLAYER_ROOT_PATH} + - PLAYER_STANDALONE_LAUNCH_URL_BASE + - HOST_PORT + rdbms: + image: mysql:8.0.27 # Deprecated but still available old auth method. + volumes: + - catapult-player-data:/var/lib/mysql + environment: + - MYSQL_RANDOM_ROOT_PASSWORD=yes + - MYSQL_USER=catapult + - MYSQL_PASSWORD=quartz + - MYSQL_DATABASE=catapult_player + command: [ + "mysqld", + # provide for full UTF-8 support + "--character-set-server=utf8mb4", + "--collation-server=utf8mb4_unicode_ci", + + # need the following because the mysql.js client lib doesn't yet support + # the newer default scheme used in MySQL 8.x + "--default-authentication-plugin=mysql_native_password" + ] + +volumes: + catapult-player-data: \ No newline at end of file diff --git a/KST-ASD-BI-101/img/cycle1.jpg b/KST-ASD-BI-101/img/cycle1.jpg new file mode 100644 index 0000000..409e1fc Binary files /dev/null and b/KST-ASD-BI-101/img/cycle1.jpg differ diff --git a/KST-ASD-BI-101/img/earth_timescale.png b/KST-ASD-BI-101/img/earth_timescale.png new file mode 100644 index 0000000..d607583 Binary files /dev/null and b/KST-ASD-BI-101/img/earth_timescale.png differ diff --git a/KST-ASD-BI-101/img/fault_types.svg b/KST-ASD-BI-101/img/fault_types.svg new file mode 100644 index 0000000..7041365 --- /dev/null +++ b/KST-ASD-BI-101/img/fault_types.svg @@ -0,0 +1,1590 @@ + + + + + + + + + + + + + +]> + + + + + + + + + + + + + + + + + + + + + + + 2014-09-19T14:38:01Z + 2014-09-19T14:38:01Z + Illustrator + + + + JPEG + 144 + 256 + /9j/4AAQSkZJRgABAgEASABIAAD/7QAsUGhvdG9zaG9wIDMuMAA4QklNA+0AAAAAABAASAAAAAEA AQBIAAAAAQAB/+4ADkFkb2JlAGTAAAAAAf/bAIQABgQEBAUEBgUFBgkGBQYJCwgGBggLDAoKCwoK DBAMDAwMDAwQDA4PEA8ODBMTFBQTExwbGxscHx8fHx8fHx8fHwEHBwcNDA0YEBAYGhURFRofHx8f Hx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8f/8AAEQgBAACQAwER AAIRAQMRAf/EAaIAAAAHAQEBAQEAAAAAAAAAAAQFAwIGAQAHCAkKCwEAAgIDAQEBAQEAAAAAAAAA AQACAwQFBgcICQoLEAACAQMDAgQCBgcDBAIGAnMBAgMRBAAFIRIxQVEGE2EicYEUMpGhBxWxQiPB UtHhMxZi8CRygvElQzRTkqKyY3PCNUQnk6OzNhdUZHTD0uIIJoMJChgZhJRFRqS0VtNVKBry4/PE 1OT0ZXWFlaW1xdXl9WZ2hpamtsbW5vY3R1dnd4eXp7fH1+f3OEhYaHiImKi4yNjo+Ck5SVlpeYmZ qbnJ2en5KjpKWmp6ipqqusra6voRAAICAQIDBQUEBQYECAMDbQEAAhEDBCESMUEFURNhIgZxgZEy obHwFMHR4SNCFVJicvEzJDRDghaSUyWiY7LCB3PSNeJEgxdUkwgJChgZJjZFGidkdFU38qOzwygp 0+PzhJSktMTU5PRldYWVpbXF1eX1RlZmdoaWprbG1ub2R1dnd4eXp7fH1+f3OEhYaHiImKi4yNjo +DlJWWl5iZmpucnZ6fkqOkpaanqKmqq6ytrq+v/aAAwDAQACEQMRAD8A9U4q7FXYq7FXYq8R/Prz 5518u6/pdro149hYSW/1gSIiH1J1kZWUs6tUIvCq9Pi3HTNX2hqMmMjh2DjZ5yB2eJ/4r8y/px9e Gp3A1iQkvfCRlkIIpxqKfDTYL9kDaman8xk4uK93G4jd9WVfl/8Amf5rsvN+mvqWvXU2mz3CRXy3 tw8sIilYKzH1WYJxry5ClPlmTpdXPxBxS2Pe2Y8hB3L6vR0dFdGDIwDKymoIO4IIzoXObxV2KuxV 2KuxV2KuxV2KuxV2KuxV2KuxV2KvHPz7/Lm91mN/NcOoRxQaTYMstlMGAYRs8haNhUc358aEdhvm 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 + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 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 + + + diff --git a/KST-ASD-BI-101/img/jordens_inre-numbers.svg b/KST-ASD-BI-101/img/jordens_inre-numbers.svg new file mode 100644 index 0000000..ff8a24a --- /dev/null +++ b/KST-ASD-BI-101/img/jordens_inre-numbers.svg @@ -0,0 +1,551 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 1 + + + + 2 + + + + 3 + + + + 4 + + + + 5 + + + + 6 + + diff --git a/KST-ASD-BI-101/img/quartz1.jpg b/KST-ASD-BI-101/img/quartz1.jpg new file mode 100644 index 0000000..ee618c3 Binary files /dev/null and b/KST-ASD-BI-101/img/quartz1.jpg differ diff --git a/KST-ASD-BI-101/img/strata1.jpg b/KST-ASD-BI-101/img/strata1.jpg new file mode 100644 index 0000000..eea96a0 Binary files /dev/null and b/KST-ASD-BI-101/img/strata1.jpg differ diff --git a/KST-ASD-BI-101/img/utahstrat.jpg b/KST-ASD-BI-101/img/utahstrat.jpg new file mode 100644 index 0000000..0fbe4fd Binary files /dev/null and b/KST-ASD-BI-101/img/utahstrat.jpg differ diff --git a/KST-ASD-BI-101/index.html b/KST-ASD-BI-101/index.html new file mode 100644 index 0000000..329aec1 --- /dev/null +++ b/KST-ASD-BI-101/index.html @@ -0,0 +1,221 @@ + + + + + + + + + Applied Software Development for Buddhist Innovation + + + +
+
+ Read-only mode, no data will be saved. +
+ +
+ +
+ + +
+
+
+
+
+ +
+
+
Your final score is:
+
You achieved a passing score.
+
You did not achieve a passing score.
+ +
+ Licensed under the GNU General Public License v3.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + + https://www.gnu.org/licenses/gpl-3.0.en.html + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on + an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +
+
+
+
Would you like to resume from your bookmark?
+
+ + +
+
+
+
+
+
One or more errors occurred. Most recent error:
+
+
+ +
+
+
+
+ + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/KST-ASD-BI-101/js/cmi5.min.js b/KST-ASD-BI-101/js/cmi5.min.js new file mode 100644 index 0000000..1720475 --- /dev/null +++ b/KST-ASD-BI-101/js/cmi5.min.js @@ -0,0 +1,21 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ +/* + https://www.npmjs.com/package/@rusticisoftware/cmi5 + 3.1.0 + */ +!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.Cmi5=e():t.Cmi5=e()}(self,(function(){return(()=>{"use strict";var t={d:(e,n)=>{for(var r in n)t.o(n,r)&&!t.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:n[r]})},o:(t,e)=>Object.prototype.hasOwnProperty.call(t,e)},e={};t.d(e,{default:()=>v});const n="3.1.0",r="@rusticisoftware/cmi5",i="1.0.3",o="cmi5LearnerPreferences",a="Normal",s={id:"https://w3id.org/xapi/cmi5/context/categories/cmi5"},c={id:"https://w3id.org/xapi/cmi5/context/categories/moveon"},l={id:`http://id.tincanapi.com/activity/software/${r}/3.1.0`,definition:{name:{und:`${r} (3.1.0)`},description:{en:"A JavaScript library implementing the cmi5 specification for AUs during runtime."},type:"http://id.tincanapi.com/activitytype/source"}},h="https://w3id.org/xapi/cmi5/context/extensions/masteryscore",u="http://adlnet.gov/expapi/verbs/initialized",d="http://adlnet.gov/expapi/verbs/terminated",f="http://adlnet.gov/expapi/verbs/completed",m="http://adlnet.gov/expapi/verbs/passed",p="http://adlnet.gov/expapi/verbs/failed",w={[u]:{en:"initialized"},[d]:{en:"terminated"},[f]:{en:"completed"},[m]:{en:"passed"},[p]:{en:"failed"}},g=["endpoint","fetch","actor","activityId","registration"];function v(t){if(this.log("constructor",t),void 0!==t){const e=new URL(t).searchParams;this.log("params");for(let t=0;t{v.DEBUG=!0},v.disableDebug=()=>{v.DEBUG=!1},v.uuidv4=()=>([1e7]+-1e3+-4e3+-8e3+-1e11).replace(/[018]/g,(t=>(t^crypto.getRandomValues(new Uint8Array(1))[0]&15>>t/4).toString(16))),v.convertISO8601DurationToMilliseconds=t=>{const e=t.indexOf("-")>=0,n=t.indexOf("T"),r=t.indexOf("S");let i,o,a=t.indexOf("H"),s=t.indexOf("M");if(-1===n||-1!==s&&s{const e=parseInt(t,10);let n="PT",r=Math.round(e/10);r<0&&(n="-"+n,r*=-1);const i=parseInt(r/36e4,10),o=parseInt(r%36e4/6e3,10);return i>0&&(n+=i+"H"),o>0&&(n+=o+"M"),n+=r%36e4%6e3/100+"S",n},v.prototype={_fetch:null,_endpoint:null,_actor:null,_registration:null,_activityId:null,_auth:null,_fetchContent:null,_lmsLaunchData:null,_contextTemplate:null,_learnerPrefs:null,_isActive:!1,_initialized:null,_passed:null,_failed:null,_completed:null,_terminated:null,_durationStart:null,_progress:null,_includeSourceActivity:!0,start:async function(t={},e){this.log("start");try{await this.postFetch(),void 0!==t.postFetch&&await t.postFetch.apply(this),await this.loadLMSLaunchData(),void 0!==t.launchData&&await t.launchData.apply(this),await this.loadLearnerPrefs(),void 0!==t.learnerPrefs&&await t.learnerPrefs.apply(this),await this.initialize(e),void 0!==t.initializeStatement&&await t.initializeStatement.apply(this)}catch(t){throw new Error(`Failed to start AU: ${t}`)}},postFetch:async function(){if(this.log("postFetch"),null===this._fetch)throw new Error("Can't POST to fetch URL without setFetch");let t;try{t=await fetch(this._fetch,{mode:"cors",method:"POST"})}catch(t){throw new Error(`Failed to make fetch request: ${t}`)}if(!t.ok)throw new Error(`Post fetch response returned error: ${t.status}`);if(200===t.status){const e=await t.json();if(void 0!==e["auth-token"])return this._fetchContent=e,void this.setAuth(`Basic ${e["auth-token"]}`);throw new Error(`Post fetch response indicated LMS error: ${e["error-code"]}`)}throw new Error(`Post fetch response status code unexpected: ${t.status}`)},loadLMSLaunchData:async function(){if(this.log("loadLMSLaunchData"),null===this._fetchContent)throw new Error("Can't retrieve LMS Launch Data without successful postFetch");let t;try{t=await fetch(`${this._endpoint}/activities/state?`+new URLSearchParams({stateId:"LMS.LaunchData",activityId:this._activityId,agent:JSON.stringify(this._actor),registration:this._registration}),{mode:"cors",method:"get",headers:{"X-Experience-API-Version":i,Authorization:this._auth}})}catch(t){throw new Error(`Failed to GET LMS launch data: ${t}`)}this._lmsLaunchData=await t.json(),this._contextTemplate=JSON.stringify(this._lmsLaunchData.contextTemplate)},loadLearnerPrefs:async function(){if(this.log("loadLearnerPrefs"),null===this._lmsLaunchData)throw new Error("Can't retrieve Learner Preferences without successful loadLMSLaunchData");let t;try{t=await fetch(`${this._endpoint}/agents/profile?`+new URLSearchParams({profileId:o,agent:JSON.stringify(this._actor)}),{mode:"cors",method:"get",headers:{"X-Experience-API-Version":i,Authorization:this._auth}})}catch(t){throw new Error(`Failed request to retrieve learner preferences: ${t}`)}if(200!==t.status){if(404===t.status)return this.log("Learner Preferences request returned not found (expected)"),void(this._learnerPrefs={contents:{}});throw new Error("Failed to get learner preferences: unrecognized response status")}this._learnerPrefs={contents:await t.json(),etag:t.headers.ETag}},saveLearnerPrefs:async function(){if(this.log("saveLearnerPrefs"),null===this._learnerPrefs)throw new Error("Can't save Learner Preferences without first loading them");let t;try{t=await fetch(`${this._endpoint}/agents/profile?`+new URLSearchParams({profileId:o,agent:JSON.stringify(this._actor)}),{mode:"cors",method:"put",headers:{"X-Experience-API-Version":i,Authorization:this._auth,"Content-Type":"application/json",...this._learnerPrefs.etag?{"If-Match":this._learnerPrefs.etag}:{"If-None-Match":"*"}},body:JSON.stringify(this._learnerPrefs.contents)})}catch(t){throw new Error(`Failed request to save learner preferences: ${t}`)}if(403===t.status)return this.log("Save of learner preferences denied by LMS"),void(this._learnerPrefs.saveDisallowed=!0);if(204!==t.status)throw new Error(`Failed to save learner preferences: ${t.status}`);this._learnerPrefs.etag=t.headers.ETag},initialize:async function(t={}){if(this.log("initialize"),null===this._lmsLaunchData)throw new Error("Failed to initialize: can't send initialized statement without successful loadLMSLaunchData");if(null===this._learnerPrefs)throw new Error("Failed to initialize: can't send initialized statement without successful loadLearnerPrefs");if(this._initialized)throw new Error("Failed to initialize: AU already initialized");const e=this.initializedStatement();this._appendProvidedProperties(e,t);try{await this.sendStatement(e)}catch(t){throw new Error(`Failed to initialize: exception sending initialized statement (${t})`)}this._initialized=!0,this._isActive=!0,this._durationStart=(new Date).getTime()},terminate:async function(t={}){if(this.log("terminate"),!this._initialized)throw new Error("AU not initialized");if(this._terminated)throw new Error("AU already terminated");const e=this.terminatedStatement();this._appendProvidedProperties(e,t);try{await this.sendStatement(e)}catch(t){throw new Error(`Failed to terminate: exception sending terminated statement (${t})`)}this._terminated=!0,this._isActive=!1},completed:async function(t={}){if(this.log("completed"),!this.isActive())throw new Error("AU not active");if(this.getLaunchMode()!==a)throw new Error("AU not in Normal launch mode");if(this._completed)throw new Error("AU already completed");const e=this.completedStatement();this._appendProvidedProperties(e,t);try{await this.sendStatement(e)}catch(t){throw new Error(`Failed to send completed statement: ${t}`)}this.setProgress(null),this._completed=!0},passed:async function(t){if(this.log("passed"),!this.isActive())throw new Error("AU not active");if(this.getLaunchMode()!==a)throw new Error("AU not in Normal launch mode");if(null!==this._passed)throw new Error("AU already passed");let e;try{e=this.passedStatement(t)}catch(t){throw new Error(`Failed to create passed statement: ${t}`)}try{await this.sendStatement(e)}catch(t){throw new Error(`Failed to send passed statement: ${t}`)}this._passed=!0},failed:async function(t){if(this.log("failed"),!this.isActive())throw new Error("AU not active");if(this.getLaunchMode()!==a)throw new Error("AU not in Normal launch mode");if(null!==this._failed||null!==this._passed)throw new Error("AU already passed/failed");let e;try{e=this.failedStatement(t)}catch(t){throw new Error(`Failed to create failed statement: ${t}`)}try{await this.sendStatement(e)}catch(t){throw new Error(`Failed to send failed statement: ${t}`)}this._failed=!0},isActive:function(){return this.log("isActive"),this._isActive},log:function(){v.DEBUG&&"undefined"!=typeof console&&console.log&&(arguments[0]="cmi5.js:"+arguments[0],console.log.apply(console,arguments))},includeSourceActivity:function(t){this._includeSourceActivity=!!t},getLaunchMode:function(){if(this.log("getLaunchMode"),null===this._lmsLaunchData)throw new Error("Can't determine launchMode until LMS LaunchData has been loaded");return this._lmsLaunchData.launchMode},getLaunchParameters:function(){if(this.log("getLaunchParameters"),null===this._lmsLaunchData)throw new Error("Can't determine LaunchParameters until LMS LaunchData has been loaded");let t=null;return void 0!==this._lmsLaunchData.launchParameters&&(t=this._lmsLaunchData.launchParameters),t},getSessionId:function(){if(this.log("getSessionId"),null===this._lmsLaunchData)throw new Error("Can't determine session id until LMS LaunchData has been loaded");return this._lmsLaunchData.contextTemplate.extensions["https://w3id.org/xapi/cmi5/context/extensions/sessionid"]},getMoveOn:function(){if(this.log("getMoveOn"),null===this._lmsLaunchData)throw new Error("Can't determine moveOn until LMS LaunchData has been loaded");return this._lmsLaunchData.moveOn},getMasteryScore:function(){if(this.log("getMasteryScore"),null===this._lmsLaunchData)throw new Error("Can't determine masteryScore until LMS LaunchData has been loaded");let t=null;return void 0!==this._lmsLaunchData.masteryScore&&(t=this._lmsLaunchData.masteryScore),t},getReturnURL:function(){if(this.log("getReturnURL"),null===this._lmsLaunchData)throw new Error("Can't determine returnURL until LMS LaunchData has been loaded");let t=null;return void 0!==this._lmsLaunchData.returnURL&&(t=this._lmsLaunchData.returnURL),t},getEntitlementKey:function(){if(this.log("getEntitlementKey"),null===this._lmsLaunchData)throw new Error("Can't determine entitlementKey until LMS LaunchData has been loaded");let t=null;return void 0!==this._lmsLaunchData.entitlementKey&&(void 0!==this._lmsLaunchData.entitlementKey.alternate?t=this._lmsLaunchData.entitlementKey.alternate:void 0!==this._lmsLaunchData.entitlementKey.courseStructure&&(t=this._lmsLaunchData.entitlementKey.courseStructure)),t},getLanguagePreference:function(){if(this.log("getLanguagePreference"),null===this._learnerPrefs)throw new Error("Can't determine language preference until learner preferences have been loaded");let t=null;return void 0!==this._learnerPrefs.contents.languagePreference&&(t=this._learnerPrefs.contents.languagePreference),t},setLanguagePreference:function(t){if(this.log("setLanguagePreference"),null===this._learnerPrefs)throw new Error("Can't set language preference until learner preferences have been loaded");""===t&&(t=null),this._learnerPrefs.contents.languagePreference=t},getAudioPreference:function(){if(this.log("getAudioPreference"),null===this._learnerPrefs)throw new Error("Can't determine audio preference until learner preferences have been loaded");let t=null;return void 0!==this._learnerPrefs.contents.audioPreference&&(t=this._learnerPrefs.contents.audioPreference),t},setAudioPreference:function(t){if(this.log("setAudioPreference"),null===this._learnerPrefs)throw new Error("Can't set audio preference until learner preferences have been loaded");if("on"!==t&&"off"!==t&&null!==t)throw new Error(`Unrecognized value for audio preference: ${t}`);this._learnerPrefs.contents.audioPreference=t},getDuration:function(){return this.log("getDuration"),(new Date).getTime()-this._durationStart},setProgress:function(t){if(this.log("setProgress: ",t),null!==t){if(!Number.isInteger(t))throw new Error(`Invalid progress measure (not an integer): ${t}`);if(t<0||t>100)throw new Error(`Invalid progress measure must be greater than or equal to 0 and less than or equal to 100: ${t}`)}this._progress=t},getProgress:function(){return this.log("getProgress"),this._progress},setEndpoint:function(t){this.log("setEndpoint: ",t),this._endpoint=t},getEndpoint:function(){return this._endpoint},setAuth:function(t){this.log("setAuth: ",t),this._auth=t},getAuth:function(){return this._auth},setFetch:function(t){this.log("setFetch: ",t),this._fetch=t},getFetch:function(){return this._fetch},setActor:function(t){if(this.log("setActor",t),"string"==typeof t)try{t=JSON.parse(t)}catch(t){throw new Error(`Invalid actor: failed to parse string as JSON (${t})`)}if(void 0===t.account)throw new Error("Invalid actor: account is missing");if(void 0===t.account.name)throw new Error("Invalid actor: account name is missing");if(""===t.account.name)throw new Error("Invalid actor: account name is empty");if(void 0===t.account.homePage)throw new Error("Invalid actor: account homePage is missing");if(""===t.account.homePage)throw new Error("Invalid actor: account homePage is empty");this._actor=t},getActor:function(){return this._actor},setActivityId:function(t){if(this.log("setActivityId",t),void 0===t)throw new Error("Invalid activityId: argument missing");if(""===t)throw new Error("Invalid activityId: empty string");this._activityId=t},getActivityId:function(){return this._activityId},setRegistration:function(t){if(this.log("setRegistration",t),null===t)throw new Error("Invalid registration: null");if(""===t)throw new Error("Invalid registration: empty");this._registration=t},getRegistration:function(){return this._registration},validateScore:function(t){if(null==t)throw new Error(`cannot validate score (score not provided): ${t}`);if(void 0!==t.min&&!Number.isInteger(t.min))throw new Error("score.min is not an integer");if(void 0!==t.max&&!Number.isInteger(t.max))throw new Error("score.max is not an integer");if(void 0!==t.scaled){if(!/^(-|\+)?[01]+(\.[0-9]+)?$/.test(t.scaled))throw new Error(`scaled score not a recognized number: ${t.scaled}`);if(t.scaled<0)throw new Error("scaled score must be greater than or equal to 0");if(t.scaled>1)throw new Error("scaled score must be less than or equal to 1")}if(void 0!==t.raw){if(!Number.isInteger(t.raw))throw new Error("score.raw is not an integer");if(void 0===t.min)throw new Error("minimum score must be provided when including a raw score");if(void 0===t.max)throw new Error("maximum score must be provided when including a raw score");if(t.rawt.max)throw new Error("raw score must be less than or equal to maximum score")}return!0},prepareStatement:function(t){const e={id:v.uuidv4(),timestamp:(new Date).toISOString(),actor:this._actor,verb:{id:t},object:{id:this._activityId},context:this._prepareContext()},n=this.getProgress();return void 0!==w[t]&&(e.verb.display=w[t]),t!==f&&null!==n&&(e.result={extensions:{"https://w3id.org/xapi/cmi5/result/extensions/progress":n}}),e},sendStatement:async function(t){let e;this.log("sendStatement",t),void 0===t.id&&(t.id=v.uuidv4());try{e=await fetch(`${this._endpoint}/statements?`+new URLSearchParams({statementId:t.id}),{mode:"cors",method:"put",headers:{"X-Experience-API-Version":i,Authorization:this._auth,"Content-Type":"application/json"},body:JSON.stringify(t)})}catch(t){throw new Error(`Failed request to send statement: ${t}`)}if(204!==e.status)throw new Error(`Failed to send statement: status code ${e.status}`)},sendStatements:async function(t){let e;this.log("sendStatements",t),t.forEach((t=>{void 0===t.id&&(t.id=v.uuidv4())}));try{e=await fetch(`${this._endpoint}/statements`,{mode:"cors",method:"post",headers:{"X-Experience-API-Version":i,Authorization:this._auth,"Content-Type":"application/json"},body:JSON.stringify(t)})}catch(t){throw new Error(`Failed request to send statements: ${t}`)}if(204!==e.status)throw new Error(`Failed to send statements: status code ${e.status}`)},initializedStatement:function(){return this.log("initializedStatement"),this._prepareStatement(u)},terminatedStatement:function(){this.log("terminatedStatement");const t=this._prepareStatement(d);return t.result=t.result||{},t.result.duration=v.convertMillisecondsToISO8601Duration(this.getDuration()),t},passedStatement:function(t){this.log("passedStatement");const e=this._prepareStatement(m);if(e.result=e.result||{},e.result.success=!0,e.result.duration=v.convertMillisecondsToISO8601Duration(this.getDuration()),t){try{this.validateScore(t)}catch(t){throw new Error(`Invalid score: ${t}`)}const n=this.getMasteryScore();if(null!==n&&void 0!==t.scaled){if(t.scaled=n)throw new Error(`Invalid score: scaled score exceeds mastery score (${t.scaled} >= ${n})`);e.context.extensions=e.context.extensions||{},e.context.extensions[h]=n}e.result.score=t}return e.context.contextActivities.category.push(c),e},completedStatement:function(){this.log("completedStatement");const t=this._prepareStatement(f);return t.result=t.result||{},t.result.completion=!0,t.result.duration=v.convertMillisecondsToISO8601Duration(this.getDuration()),t.context.contextActivities.category.push(c),t},_prepareContext:function(){const t=JSON.parse(this._contextTemplate);return t.registration=this._registration,this._includeSourceActivity&&(t.contextActivities=t.contextActivities||{},t.contextActivities.other=t.contextActivities.other||[],t.contextActivities.other.push(l)),t},_prepareStatement:function(t){const e=this.prepareStatement(t);return e.context.contextActivities=e.context.contextActivities||{},e.context.contextActivities.category=e.context.contextActivities.category||[],e.context.contextActivities.category.push(s),e},_appendProvidedProperties:function(t,e){if(void 0!==e.context&&void 0!==e.context.extensions)for(const n in e.context.extensions)e.context.extensions.hasOwnProperty(n)&&(t.context.extensions[n]=e.context.extensions[n]);if(void 0!==e.result&&(t.result=t.result||{},t.result.extensions=t.result.extensions||{},void 0!==e.result.extensions))for(const n in e.result.extensions)e.result.extensions.hasOwnProperty(n)&&(t.result.extensions[n]=e.result.extensions[n]);void 0!==e.object&&void 0!==e.object.definition&&(t.object.definition=t.object.definition||{},void 0!==e.object.definition.type&&(t.object.definition.type=e.object.definition.type))}},e.default})()})); +//# sourceMappingURL=cmi5.min.js.map diff --git a/KST-ASD-BI-101/js/course.js b/KST-ASD-BI-101/js/course.js new file mode 100644 index 0000000..7e734cf --- /dev/null +++ b/KST-ASD-BI-101/js/course.js @@ -0,0 +1,755 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ + +/** + * Initialize a course player for display, navigation and learning capture behavior. + * + * @param {Object} opts Course configuration parameters. + * @param {Array} opts.pageList An array of page names that will be made available via navigation. + * @param {string} opts.pageListQueryParam A comma-delimited list of page names that will be made available via navigation. + * @param {Object} opts.trackingPlugin The learning standard plugin prototype containing methods for communicating with a learning standard. + * @param {boolean} opts.navigateOnLaunch When true, automatically take the learner to the first navigable content page at startup. + * @param {boolean} opts.navigationInjectIntoContent When true, add navigation markup as needed to content areas. + * @param {string} opts.completionBehavior Indicates what learner actions cause the course to trigger a learning completion. + * @param {boolean} opts.enableBookmarking When true, allow course to load and save bookmarks. + * @param {boolean} opts.trackInteractions When true, allow learning standard storage of interaction data. + */ +function Course(opts) { + // Make sure we know how to clean up correctly, even if we're being exited from a redirect or window closing event. + window.addEventListener("beforeunload", event => { + this.exit({isUnloading: true}); + }); + + this.pageList = []; + this.lastBookmark = ""; + if (opts.pageList) { + this.pageList = opts.pageList; + } else if (opts.pageListQueryParam) { + this.pageList = opts.pageListQueryParam.split(","); + } else { + let tempPages = document.getElementsByClassName("contentpage"); + this.pageList = []; + for (let i = 0; i < tempPages.length; i++) { + this.pageList.push(tempPages[i].id.substr(4)); + } + } + this.pageViewedState = Array(this.pageList.length).fill(false); + + this.trackingPlugin = null; + if (opts.trackingPlugin) { + this.trackingPlugin = opts.trackingPlugin; + } else { + alert("A tracking plugin is required, unable to proceed. Course cannot operate, no results will be recorded."); + return; + } + + this.navigateOnLaunch = false; + if (opts.hasOwnProperty("navigateOnLaunch")) { + this.navigateOnLaunch = opts.navigateOnLaunch; + } + + this.navigationInjectIntoContent = false; + if (opts.hasOwnProperty("navigationInjectIntoContent")) { + this.navigationInjectIntoContent = opts.navigationInjectIntoContent; + } + this.numQuestions = 0; + + this.completionBehavior = "launch"; + if (opts.completionBehavior) { + this.completionBehavior = opts.completionBehavior; + } + + this.enableBookmarking = false; + if (opts.hasOwnProperty("enableBookmarking")) { + this.enableBookmarking = opts.enableBookmarking; + } + + this.trackInteractions = true; + if (opts.hasOwnProperty("trackInteractions")) { + this.trackInteractions = opts.trackInteractions; + } + + this.currentPageIdx = 0; + this.exitAttempted = false; + this.passingScaledScore = 0.8; + this.videoTrackingData = {}; + // If true, don't save interactions while saving the passed/completed, delay until explicit flush. + this.trackingDelayInteractionSave = true; + this.renderNavTree(); + + this.trackingPlugin.initialize(this.postInit.bind(this), this.trackingActivityUpdate.bind(this)); +} + +/** + * Upon the learning standard plugin indicating that the course has been correctly initialized, control is returned + * to the course here to prepare for user engagement. Bookmarking and launch completion both occur at this point. + */ +Course.prototype.postInit = function () { + if (!this.trackingPlugin.canSave()) { + document.body.classList.add("info-bar-visible"); + } + + if (this.enableBookmarking) { + this.trackingPlugin.getBookmark().then(bookmark => { + this.lastBookmark = bookmark; + this.askBookmark(); + }).catch(() => { + if (this.navigateOnLaunch) { + this.gotoPage(0); + } + }); + } else if (this.navigateOnLaunch) { + this.gotoPage(0); + } + + if (this.completionBehavior === "launch") { + this.pass(); + } +} + +/** + * If bookmarking is available and a bookmark exists, present the learner with a request to resume. + * Otherwise, navigate the learner into the learning experience. + */ +Course.prototype.askBookmark = function () { + if (this.lastBookmark) { + document.querySelector("#bookmark-overlay .restart-button").addEventListener("click", _ => { + this.ignoreBookmark(); + }); + document.querySelector("#bookmark-overlay .resume-button").addEventListener("click", _ => { + this.followBookmark(); + }); + document.getElementById("bookmark-overlay").classList.add("full-overlay-visible"); + } else if (this.navigateOnLaunch) { + this.gotoPage(0); + } +} + +/** + * Navigate the learner to the course page represented by the bookmark from the tracking plugin. + */ +Course.prototype.followBookmark = function () { + this.gotoPage(this.pageList.indexOf(this.lastBookmark)); + this._resolveBookmark(); +} + +/** + * Perform no further bookmark actions, and start the course normally. + */ +Course.prototype.ignoreBookmark = function () { + if (this.navigateOnLaunch) { + this.gotoPage(0); + } + this._resolveBookmark(); +} + +Course.prototype._resolveBookmark = function () { + document.getElementById("bookmark-overlay").classList.remove("full-overlay-visible"); +} + +/** + * Helper method for generating (weak) v4 UUIDs. Only for use to establish non-cryptographic identifiers. + */ +Course.prototype.testUUID = function () { + return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) { + const r = Math.random() * 16 | 0, v = c === 'x' ? r : (r & 0x3 | 0x8); + return v.toString(16); + }); +} + +/** + * Whenever the tracking plugin has a change in transmitted data, this callback will be executed and any + * course-specific UI updates can occur. + * + * @param result Any successful tracking behaviors. + * @param error Any unsuccessful tracking behaviors. + * @param activeStatementCount The number of outstanding tracking behaviors yet to resolve. + */ +Course.prototype.trackingActivityUpdate = function (result, error, activeStatementCount) { + document.querySelectorAll(".exit-button").forEach(el => { + if (activeStatementCount > 0) { + el.disabled = "disabled"; + } else { + el.disabled = ""; + } + }); +} + +/** + * As part of preparing a page for learner engagement, sets up all useful page-specific event behaviors. + */ +Course.prototype.addPerPageListeners = function () { + // Waiting to make sure DOM has time to be correctly attached, even if all elements are not yet rendered. + setTimeout(() => { + // For every video on the page, bind a series of listeners and interaction trackers. + let videos = document.getElementsByTagName("video"); + for (let i = 0; i < videos.length; i++) { + let vid = videos[i]; + + (videoClosure => { + let vidName = videoClosure.dataset.name, + vidObject = videoClosure.dataset.objectid, + session = this.testUUID(); + + this.videoTrackingData[vidObject] = { + playedSegments: [], + lastSeen: -1, + initializedTime: new Date(), + finished: false, + session: session + }; + + this.trackingPlugin.videoInitialize({ + name: vidName, + objectId: vidObject, + currentTime: 0 + }).catch(e => { + this.trackingError("Unable to save video initialized statement: " + String(e)); + }); + + videoClosure.parentNode.querySelectorAll(".video-start-overlay").forEach(overlay => { + overlay.addEventListener("click", () => { + overlay.classList.add("hidden"); + videoClosure.play(); + }); + }); + + videoClosure.addEventListener("click", () => { + if (!this.videoTrackingData[vidObject].finished) { + if (videoClosure.paused) { + videoClosure.play(); + } else { + videoClosure.pause(); + } + } + }); + + videoClosure.addEventListener("play", e => { + this.videoTrackingData[vidObject].lastSeen = e.target.currentTime; + this.trackingPlugin.videoPlay({ + name: vidName, + objectId: vidObject, + currentTime: e.target.currentTime, + videoLength: e.target.duration, + session: session + }).catch(e => { + this.trackingError("Unable to save video played statement: " + String(e)); + }); + }); + + videoClosure.addEventListener("pause", e => { + if (e.target.currentTime !== e.target.duration) { + this.videoTrackingData[vidObject].playedSegments.push([ + this.videoTrackingData[vidObject].lastSeen, e.target.currentTime]); + this.trackingPlugin.videoPause({ + name: vidName, + objectId: vidObject, + currentTime: e.target.currentTime, + playedSegments: this.videoTrackingData[vidObject].playedSegments, + progress: +(e.target.currentTime / e.target.duration).toFixed(3), + videoLength: e.target.duration, + session: session + }).catch(e => { + this.trackingError("Unable to save video paused statement: " + String(e)); + }); + } + }); + + videoClosure.addEventListener("ended", e => { + this.videoTrackingData[vidObject].playedSegments.push([ + this.videoTrackingData[vidObject].lastSeen, e.target.currentTime]); + videoClosure.parentNode.querySelectorAll(".video-complete-overlay").forEach(overlay => { + overlay.classList.remove("hidden"); + }); + this.trackingPlugin.videoCompleted({ + name: vidName, + objectId: vidObject, + currentTime: e.target.currentTime, + progress: 1, + playedSegments: this.videoTrackingData[vidObject].playedSegments, + completion: true, + duration: "PT" + e.target.currentTime + "S", + completionThreshold: 1.0, + videoLength: e.target.duration, + session: session + }).catch(e => { + this.trackingError("Unable to save video completed statement: " + String(e)); + }); + }); + })(vid); + } + }, 1); +} + +/** + * Learner has failed the course material, perform appropriate tracking behaviors. + * + * @param {Object=} scoreObj The scored results of the learner's efforts, if relevant. + * @param {number} scoreObj.scaled The learner's scaled score, between -1.0 and 1.0. + * @param {number} scoreObj.raw The learner's raw score, between `min` and `max`. + * @param {number} scoreObj.min The lowest possible raw score that can be achieved in this course. + * @param {number} scoreObj.max The highest possible raw score that can be achieved in this course. + */ +Course.prototype.fail = function (scoreObj) { + this.trackingPlugin.fail(scoreObj).then(() => { + this.trackingPlugin.flushBatch(); + }).catch(e => { + this.trackingError("Unable to save failed statement: " + String(e)); + }); +} + +/** + * Learner has successfully completed the course material, perform appropriate tracking behaviors. + * + * @param {Object=} scoreObj The scored results of the learner's efforts, if relevant. + * @param {number} scoreObj.scaled The learner's scaled score, between -1.0 and 1.0. + * @param {number} scoreObj.raw The learner's raw score, between `min` and `max`. + * @param {number} scoreObj.min The lowest possible raw score that can be achieved in this course. + * @param {number} scoreObj.max The highest possible raw score that can be achieved in this course. + */ +Course.prototype.pass = function (scoreObj) { + this.trackingPlugin.passAndComplete(scoreObj).then(() => { + this.trackingPlugin.flushBatch(); + }).catch(e => { + this.trackingError("Unable to save passed/completed statement: " + String(e)); + }); +} + +/** + * Given a page name (not position in the page list), return the page's title. + * + * @param {string} pageName Page name (the id value without the "page" prefix). + * @returns {string} Page title. + */ +Course.prototype.getPageTitle = function (pageName) { + let el = document.getElementById("page" + pageName); + if (!el) { + return ""; + } + return el.dataset.title; +} + +/** + * Build the navigation menu from the existing list of pages. + */ +Course.prototype.renderNavTree = function () { + let s = ""; + for (let i = 0; i < this.pageList.length; i++) { + let title = this.getPageTitle(this.pageList[i]); + s += ''; + } + document.getElementById("navmenuitems").innerHTML = s; +} + +/** + * Do all the setup to inject the new page into the content DOM area, bind the appropriate events and do learning + * standards tracking. + * + * @param {number} pageIdx The current position in the page list to navigate to. + * @private + */ +Course.prototype._navigatePage = function (pageIdx) { + this.swapPageContents(pageIdx); + this.addPerPageListeners(); + + let lis = document.getElementById("navmenu").getElementsByTagName("li"); + for (let i = 0; i < lis.length; i++) { + lis[i].classList.remove("current"); + } + lis[pageIdx].classList.add("current"); + + this.numQuestions = document.getElementById("page" + this.pageList[pageIdx]).dataset.questions; + + // If we're using completion behavior of "visited last page", then perform any standard-specific completion actions. + if (this.completionBehavior === "last") { + if (pageIdx >= this.pageList.length - 1) { + this.pass(); + } + } + + // Set the bookmark + if (this.enableBookmarking) { + this.trackingPlugin.setBookmark(this.pageList[pageIdx]); + } + + // Control navigation visibility for views that require it. + if (document.getElementById("next")) { + if (pageIdx >= this.pageList.length - 1) { + document.getElementById("next").classList.add("navdisabled"); + document.getElementById("next").disabled = "disabled"; + } else { + document.getElementById("next").classList.remove("navdisabled"); + document.getElementById("next").disabled = undefined; + } + } + if (document.getElementById("prev")) { + if (pageIdx <= 0) { + document.getElementById("prev").classList.add("navdisabled"); + document.getElementById("prev").disabled = "disabled"; + } else { + document.getElementById("prev").classList.remove("navdisabled"); + document.getElementById("prev").disabled = undefined; + } + } +} + +/** + * Inject a page into the content area DOM. + * + * @param {number} pageIdx The current position in the page list to navigate to. + */ +Course.prototype.swapPageContents = function (pageIdx) { + let pageName = this.pageList[pageIdx]; + let page = document.getElementById("page" + pageName); + let s = ""; + if (this.navigationInjectIntoContent) { + if (pageIdx > 0) { + s += '
↑ Previous Section
'; + } + } + s += page.innerHTML; + if (this.navigationInjectIntoContent) { + if (pageIdx < this.pageList.length - 1) { + s += '
Next Section ↓
'; + } + } + document.getElementById("content").innerHTML = s; +} + +/** + * Calculate the learner's current navigated progress through the course. This is not related to scoring or status. + * + * @returns {number} A progress measure value from 0 to 100. + */ +Course.prototype.getCourseProgress = function () { + return Math.round((this.pageViewedState.filter(x => x === true).length / this.pageViewedState.length) * 100); +} + +/** + * Perform post-navigation actions before presenting the current page to the learner. + * @private + */ +Course.prototype._postNavigate = function () { + window.scrollTo(0, 0); + let content = document.getElementById("content"); + content.scrollTo(0, 0); + content.classList.remove("changePage"); + + this.pageViewedState[this.currentPageIdx] = true; + if (document.getElementById("footer-progress-value")) { + document.getElementById("footer-progress-value").innerHTML = String(this.getCourseProgress()); + } + document.querySelectorAll(".navmenuitem")[this.currentPageIdx].classList.add("seen"); + this.trackingPlugin.experienced( + this.currentPageIdx, + this.getPageTitle(this.pageList[this.currentPageIdx]), + this.getCourseProgress() + ).catch(e => { + this.trackingError("Unable to save experienced statement: " + String(e)); + }); +} + +/** + * Navigate directly to the specified page index in the page list. + * + * @param {number} pageIdx The page index in the page list. + */ +Course.prototype.gotoPage = function (pageIdx) { + this.currentPageIdx = pageIdx; + this._navigatePage(this.currentPageIdx); + this._postNavigate(); +} + +/** + * Navigate to the previous available page. + */ +Course.prototype.previousPage = function () { + this.currentPageIdx--; + this._navigatePage(this.currentPageIdx); + this._postNavigate(); +} + +/** + * Navigate to the next available page. + */ +Course.prototype.nextPage = function () { + this.currentPageIdx++; + this._navigatePage(this.currentPageIdx); + this._postNavigate(); +} + +/** + * With the current page's form, determine the success or failure of the interactions contained in it. + * Perform any related tracking behaviors surrounding interactions and completions. + */ +Course.prototype.submitAnswers = function () { + let correct = 0; + const pageName = this.pageList[this.currentPageIdx]; + const page = document.getElementById("page" + pageName); + + let interactionTrackingData = []; + for (let i = 0; i < this.numQuestions; i++) { + let statusAndData = this.checkAndPrepare(page.dataset.quizId, "q" + i); + if (statusAndData.data) { + interactionTrackingData.push(statusAndData.data); + } + if (statusAndData.isCorrect) { + correct += 1; + } + } + const scaledScore = correct / this.numQuestions; + const rawScore = Math.floor(scaledScore * 100); + const scoreObj = { + scaled: scaledScore, + raw: rawScore, + min: 0, + max: 100 + }; + + let actualPassingScaledScore = this.passingScaledScore; + let tmpPassingScaledScore = this.trackingPlugin.getOverridePassingScaledScore(); + if (!Number.isNaN(tmpPassingScaledScore)) { + actualPassingScaledScore = tmpPassingScaledScore; + } + + document.getElementById("score-panel-score").innerHTML = "" + Math.round(rawScore * 100.) / 100.; + document.getElementById("score-panel").classList.add("full-overlay-visible"); + if (scoreObj["scaled"] >= actualPassingScaledScore) { + document.getElementById("score-passed").classList.add("visible"); + this.pass(scoreObj); + } else { + document.getElementById("score-failed").classList.add("visible"); + this.fail(scoreObj); + } + + this.trackingPlugin.captureInteractions(interactionTrackingData, {queue: this.trackingDelayInteractionSave}); +} + +/** + * Given a single question/interaction on a page form, determine if it was answered correctly, and perform + * tracking behaviors around it if appropriate. + * @param {string} testId A unique identifier for the current page's test element, for tracking. + * @param {string} name The identifier of the current question. + * @returns {Object} isCorrect: Whether the question was answered correctly. + * interactionData: Any useful data about the interaction, null if none. + */ +Course.prototype.checkAndPrepare = function (testId, name) { + let nodes = document.getElementsByName(name); + let success = false; + let interactionData = null; + + if (nodes.length > 0) { + if (nodes[0].type === "text") { + let userAnswer = nodes[0].value; + let correctAnswer = nodes[0].dataset.answer; + if (userAnswer === correctAnswer) { + success = true; + } + + interactionData = { + testId: testId, + interactionType: "fill-in", + interactionId: name, + userAnswers: [userAnswer], + correctAnswers: [correctAnswer], + name: document.getElementById(name + "-question").innerHTML, + description: "", + success: success + }; + } else if (nodes[0].type === "radio") { + let failedMatch = false; + let userAnswers = []; + let correctAnswers = []; + let choices = []; + for (let i = 0; i < nodes.length; i++) { + choices.push({ + id: nodes[i].value, + description: { + "en-US": nodes[i].nextSibling.innerHTML + } + }) + if ((nodes[i].dataset.correct === "yes" && !nodes[i].checked) || + (nodes[i].dataset.correct !== "yes" && nodes[i].checked)) { + failedMatch = true; + } + if (nodes[i].checked) { + userAnswers.push(nodes[i].value); + } + if (nodes[i].dataset.correct === "yes") { + correctAnswers.push(nodes[i].value); + } + } + if (!failedMatch) { + success = true; + } + interactionData = { + testId: testId, + interactionType: "choice", + interactionId: name, + userAnswers: userAnswers, + correctAnswers: correctAnswers, + choices: choices, + name: document.getElementById(name + "-question").innerHTML, + description: "", + success: success + }; + } else if (nodes[0].tagName.toLowerCase() === "select") { + let failedMatch = false; + let userAnswers = []; + let correctAnswers = []; + let choices = []; + for (let option of nodes[0].options) { + choices.push({ + id: option.value, + description: { + "en-US": option.innerHTML + } + }) + if ((option.dataset.correct === "yes" && !option.selected) || + (option.dataset.correct !== "yes" && option.selected)) { + failedMatch = true; + } + if (option.selected) { + userAnswers.push(option.value); + } + if (option.dataset.correct === "yes") { + correctAnswers.push(option.value); + } + } + if (!failedMatch) { + success = true; + } + + interactionData = { + testId: testId, + interactionType: "choice", + interactionId: name, + userAnswers: userAnswers, + correctAnswers: correctAnswers, + choices: choices, + name: document.getElementById(name + "-question").innerHTML, + description: "", + success: success + }; + } + } + return {isCorrect: success, data: interactionData}; +} + +/** + * Fill in all answers on the current page's form correctly. + */ +Course.prototype.autopass = function () { + for (let i = 0; i < this.numQuestions; i++) { + let nm = "q" + i; + let nodes = document.getElementsByName(nm); + if (nodes.length > 0) { + if (nodes[0].type === "text") { + nodes[0].value = nodes[0].dataset.answer; + } else if (nodes[0].type === "radio") { + for (let node of nodes) { + node.checked = node.dataset.correct === "yes"; + } + } else if (nodes[0].tagName.toLowerCase() === "select") { + for (let option of nodes[0].options) { + option.selected = option.dataset.correct === "yes"; + } + } + } + } +} + +/** + * Fill in all answers on the current page's form incorrectly. + */ +Course.prototype.autofail = function () { + for (let questionIdx = 0; questionIdx < this.numQuestions; questionIdx++) { + let nm = "q" + questionIdx; + let nodes = document.getElementsByName(nm); + if (nodes.length > 0) { + if (nodes[0].type === "text") { + nodes[0].value = Math.floor(Math.random() * 199); + } else if (nodes[0].type === "radio") { + for (let node of nodes) { + if (node.dataset.correct !== "yes") { + node.checked = true; + break; + } else { + node.checked = false; + } + } + } else if (nodes[0].tagName.toLowerCase() === "select") { + for (let option of nodes[0].options) { + option.selected = option.dataset.correct !== "yes"; + } + } + } + } +} + +/** + * Hide the error overlay. + */ +Course.prototype.hideErrorPanel = function () { + document.getElementById("error-message-overlay").classList.remove("full-overlay-visible"); +} + +/** + * Show the error overlay. + */ +Course.prototype.showErrorPanel = function () { + document.getElementById("error-message-overlay").classList.add("full-overlay-visible"); +} + +/** + * If an error occurs while performing tracking behaviors, record it and make it available on the error panel. + * + * @param {string} errorMsg The text of the error retrieved from a tracking call that errored. + */ +Course.prototype.trackingError = function (errorMsg) { + if (document.getElementById("warning-icon")) { + document.getElementById("warning-icon").classList.add("warning-icon-visible"); + } + document.getElementById("error-content").innerHTML = errorMsg; +} + +/** + * Exit the course, performing any necessary exit tracking behaviors. + */ +Course.prototype.exit = function (opts) { + if (!opts) { + opts = {}; + } + if (!opts.hasOwnProperty("isUnloading")) { + opts.isUnloading = false; + } + + if (this.trackingPlugin) { + // If we've already done the exit procedure and the window is now unloading, don't do it again. + if (!this.exitAttempted || (this.exitAttempted && !opts.isUnloading)) { + const lastExitAttempted = this.exitAttempted; + this.exitAttempted = true; + this.trackingPlugin.exit(lastExitAttempted); + } + } else { + if (window.opener) { + try { + window.close(); + } catch (e) { + } + } + } +} diff --git a/KST-ASD-BI-101/js/course_cmi5.js b/KST-ASD-BI-101/js/course_cmi5.js new file mode 100644 index 0000000..aa39dd3 --- /dev/null +++ b/KST-ASD-BI-101/js/course_cmi5.js @@ -0,0 +1,693 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ + +const + XAPI_VERSION = "1.0.3", + SUSPEND_DATA_KEY = "suspendData", + VERB_ANSWERED = "http://adlnet.gov/expapi/verbs/answered", + VERB_EXPERIENCED_OBJ = { + id: "http://adlnet.gov/expapi/verbs/experienced", + display: { + "en-US": "experienced" + } + }, + VERB_VIDEO_COMPLETED_OBJ = { + "id": "http://adlnet.gov/expapi/verbs/completed", + "display": { + "en-US": "completed" + } + }, + VERB_VIDEO_INITIALIZED_OBJ = { + "id": "http://adlnet.gov/expapi/verbs/initialized", + "display": { + "en-US": "initialized" + } + }, + VERB_VIDEO_PAUSED_OBJ = { + "id": "https://w3id.org/xapi/video/verbs/paused", + "display": { + "en-US": "paused" + } + }, + VERB_VIDEO_PLAYED_OBJ = { + "id": "https://w3id.org/xapi/video/verbs/played", + "display": { + "en-US": "played" + } + }; + +/** + * Prepare the cmi5 tracking plugin. This does not begin a cmi5 session. + * @constructor + */ +function CourseCmi5Plugin() { + this.cmi5 = null; + this.passingScore = Number.NaN; + this.activeStatements = 0; + this.callbackOnStatementSend = null; + this.launchMode = ""; + this.statementBatch = []; +} + +/** + * Begin a cmi5 session and send a learner "initialized" statement. + * + * @param {Function} callbackOnInit Callback to call once initialization is complete. + * @param {Function} callbackOnStatementSend Callback to call whenever any xAPI or cmi5 statement is sent. + */ +CourseCmi5Plugin.prototype.initialize = function (callbackOnInit, callbackOnStatementSend) { + // Cmi5.enableDebug(); + + this.callbackOnStatementSend = callbackOnStatementSend; + this.cmi5 = new Cmi5(document.location.href); + if (!this.cmi5.getEndpoint()) { + this.cmi5 = null; + } else { + this.cmi5.start({ + launchData: err => { + if (err) { + console.log("error occurred fetching launchData", err); + alert("Unable to retrieve launch data, reason: " + err); + } + + this.launchMode = this.cmi5.getLaunchMode(); + let masteryScore = this.cmi5.getMasteryScore(); + if (masteryScore !== null) { + this.passingScore = parseFloat(masteryScore); + } + }, + initializeStatement: err => { + if (err) { + console.log("error occurred sending initialized statement", err); + alert("Unable to initialize, reason: " + err); + } else { + callbackOnInit(); + } + } + }); + } +} + +/** + * If we're running in a mode where saving anything meaningful is allowed (more than initialized/terminated), return true. + * + * @returns {boolean} true if we can save most learner information, false if we can only initialize/terminate. + */ +CourseCmi5Plugin.prototype.canSave = function () { + return this._shouldSendStatement(); +} + +/** + * Get the xAPI endpoint for the current session. + * + * @return {string} URL representing the xAPI root to send xAPI data to. + */ +CourseCmi5Plugin.prototype.getEndpoint = function () { + let endpoint = this.cmi5.getEndpoint(); + if (endpoint[endpoint.length - 1] !== "/") { + endpoint = endpoint + "/"; + } + return endpoint; +} + +/** + * Retrieve the activity state for this learner and registration at the given stateId. + * + * @param {string} stateId The xAPI Activity State "stateId" value for the API call. + * @return {Promise} The promise returned by the fetch call representing the xAPI request. + */ +CourseCmi5Plugin.prototype.getActivityState = function (stateId) { + return fetch( + this.getEndpoint() + "activities/state?" + new URLSearchParams( + { + stateId: stateId, + activityId: this.cmi5.getActivityId(), + agent: JSON.stringify(this.cmi5.getActor()), + registration: this.cmi5.getRegistration() + } + ), + { + mode: "cors", + method: "get", + headers: { + "X-Experience-API-Version": XAPI_VERSION, + Authorization: this.cmi5.getAuth() + } + } + ).then(response => { + if (response.status === 200) { + return response.json(); + } else { + return Promise.resolve(""); + } + }).catch(ex => { + throw new Error(`Failed to GET activity state: ${ex}`); + }); +} + +/** + * Store the data provided as an activity state for this learner and registration at the given stateId. + * + * @param {string} stateId The xAPI Activity State "stateId" value for the API call. + * @param data The data to store in this Activity State. + * @return {Promise} The promise returned by the fetch call representing the xAPI request. + */ +CourseCmi5Plugin.prototype.setActivityState = function (stateId, data) { + return fetch( + this.getEndpoint() + "activities/state?" + new URLSearchParams( + { + stateId: stateId, + activityId: this.cmi5.getActivityId(), + agent: JSON.stringify(this.cmi5.getActor()), + registration: this.cmi5.getRegistration() + } + ), + { + mode: "cors", + method: "put", + headers: { + "X-Experience-API-Version": XAPI_VERSION, + Authorization: this.cmi5.getAuth(), + Accept: "application/json", + "Content-Type": "application/json" + }, + body: JSON.stringify(data) + } + ).then(response => { + if (response.status === 200) { + return response.json(); + } + return Promise.resolve(""); + }).catch(ex => { + throw new Error(`Failed to GET activity state: ${ex}`); + }); +} + +/** + * Get the learner's bookmark if one exists. + * + * @return {Promise} The learner's bookmark, or an empty string if no bookmark exists. + */ +CourseCmi5Plugin.prototype.getBookmark = function () { + return this.getActivityState(SUSPEND_DATA_KEY).then(bookmarkObj => { + if (bookmarkObj && bookmarkObj["bookmark"]) { + return Promise.resolve(bookmarkObj["bookmark"]); + } else { + return Promise.resolve(""); + } + }); +} + +/** + * Save the learner's bookmark. + * + * @param {string} bookmark The learner's bookmark data. + * @return {Promise} The promise returned by the fetch call representing the xAPI request. + */ +CourseCmi5Plugin.prototype.setBookmark = function (bookmark) { + return this.setActivityState(SUSPEND_DATA_KEY, {"bookmark": bookmark}); +} + +/** + * Retrieve the AU's mastery score. + + * @return {number} The AU mastery score, or Number.NaN if one was not provided. + */ +CourseCmi5Plugin.prototype.getOverridePassingScaledScore = function () { + return this.passingScore; +} + +/** + * Learner has failed the course material, send a cmi5 defined statement indicating failure. + * + * @param {Object=} userScoreObj The scored results of the learner's efforts, if relevant. + * @param {number} userScoreObj.scaled The learner's scaled score, between -1.0 and 1.0. + * @param {number} userScoreObj.raw The learner's raw score, between `min` and `max`. + * @param {number} userScoreObj.min The lowest possible raw score that can be achieved in this course. + * @param {number} userScoreObj.max The highest possible raw score that can be achieved in this course. + */ +CourseCmi5Plugin.prototype.fail = function (userScoreObj) { + if (!this.cmi5) { + return Promise.resolve(null); + } + + if (this._shouldSendStatement()) { + return this.cmi5.failed(userScoreObj); + } + return Promise.resolve(null); +} + +/** + * Learner has passed the course material, send two cmi5 defined statements indicating passed and completed. + * + * @param {Object=} userScoreObj The scored results of the learner's efforts, if relevant. + * @param {number} userScoreObj.scaled The learner's scaled score, between -1.0 and 1.0. + * @param {number} userScoreObj.raw The learner's raw score, between `min` and `max`. + * @param {number} userScoreObj.min The lowest possible raw score that can be achieved in this course. + * @param {number} userScoreObj.max The highest possible raw score that can be achieved in this course. + */ +CourseCmi5Plugin.prototype.passAndComplete = function (userScoreObj) { + if (!this.cmi5) { + return Promise.resolve(null); + } + + if (this._shouldSendStatement()) { + return this._sendStatementViaLibFunction(() => { + return this.cmi5.passed(userScoreObj).then(() => this.cmi5.completed()); + }) + } + return Promise.resolve(null); +} + +/** + * Handle cmi5-specific exit redirect rules here around the return URL, if available. + * @private + */ +CourseCmi5Plugin.prototype._exitRedirect = function () { + if (this.cmi5 && this.cmi5.getReturnURL()) { + document.location.href = this.cmi5.getReturnURL(); + } +} + +/** + * Attempt to navigate the browser or close the current window relative to whatever way the course has been launched. + * @private + */ +CourseCmi5Plugin.prototype._exit = function () { + if (window.opener) { + try { + window.close(); + } catch (e) { + this._exitRedirect(); + } + } else { + this._exitRedirect(); + } +} + +/** + * Perform any tracking behaviors necessary to exit the course safely, and then navigate away from the course. + * + * @param {string} alreadyAttempted true if we've tried to exit before, to avoid doing tracking behaviors that should + * not be repeated. + */ +CourseCmi5Plugin.prototype.exit = function (alreadyAttempted) { + if (this.cmi5 && !alreadyAttempted) { + this.cmi5.terminate().finally(() => { + this._exit(); + }); + } else { + this._exit(); + } +} + +/** + * Generate an xAPI "experienced" statement, tagged with the current page information. + * + * @param {string} pageId The current page ID name the learner experienced. + * @param {string} name The current page name the learner experienced. + * @param {number} overallProgress Value from 0-100 representing percentage of the course viewed. + * @return {Promise} The promise from the statement network call. + */ +CourseCmi5Plugin.prototype.experienced = function (pageId, name, overallProgress) { + if (!this.cmi5) { + return Promise.resolve(null); + } + + let stmt = this.cmi5.prepareStatement(VERB_EXPERIENCED_OBJ.id); + stmt.verb.display = VERB_EXPERIENCED_OBJ.display; + stmt.object = { + objectType: "Activity", + id: this.cmi5.getActivityId() + "/slide/" + pageId, + definition: { + name: {"en-US": name}, + } + }; + // If we can, also save the progress value, ignore values that are out of range. + if (!Number.isNaN(overallProgress) && overallProgress > 0 && overallProgress < 100) { + if (!stmt.result) { + stmt.result = {}; + } + if (!stmt.result.extensions) { + stmt.result.extensions = {}; + } + stmt.result.extensions["https://w3id.org/xapi/cmi5/result/extensions/progress"] = Math.round(overallProgress); + } + return this.sendStatement(stmt); +} + +/** + * Generate an xAPI "answered" statement that represents the details of the learner's interaction, including success. + * + * @param {Array} interactionList A list of interaction details. + * @param {Object} opts Configuration around the storage and sending of the interaction. + * @return {Promise} The promise from the statement network call. + */ +CourseCmi5Plugin.prototype.captureInteractions = function (interactionList, opts) { + if (!this.cmi5) { + return Promise.resolve(null); + } + + if (!opts) { + opts = {} + } + if (!opts.hasOwnProperty("queue")) { + opts.queue = false; + } + + let stmts = []; + interactionList.forEach(interactionObj => { + let stmt = this.cmi5.prepareStatement(VERB_ANSWERED); + stmt.result = { + response: interactionObj.userAnswers.join("[,]") + } + if (typeof interactionObj.success !== "undefined") { + stmt.result.success = !!interactionObj.success; + } + stmt.object = { + objectType: "Activity", + id: this.cmi5.getActivityId() + "/test/" + interactionObj.testId + "/question/" + interactionObj.interactionId, + definition: { + type: "http://adlnet.gov/expapi/activities/cmi.interaction", + interactionType: interactionObj.interactionType, + name: {"en-US": interactionObj.name}, + correctResponsesPattern: [interactionObj.correctAnswers.join("[,]")] + } + }; + if (interactionObj.description) { + stmt.object.definition.description = {"en-US": interactionObj.description}; + } + if (interactionObj.choices) { + stmt.object.definition.choices = interactionObj.choices; + } + stmts.push(stmt); + }); + return this.sendStatements(stmts, opts); +} + +/** + * Build a cmi5 statement that matches the xAPI video profile. + * + * @param {Object} videoObj The learner details about the video element interaction. + * @param {Object} verb The video profile verb action the learner performed with the video. + * @return {Object} An xAPI video profile statement. + * @private + */ +CourseCmi5Plugin.prototype._videoMakeStatement = function (videoObj, verb) { + let stmt = this.cmi5.prepareStatement(verb.id); + if (verb.display) { + stmt.verb.display = verb.display; + } + stmt.object = { + "definition": { + "type": "https://w3id.org/xapi/video/activity-type/video", + "name": { + "en-US": videoObj.name + } + }, + "id": videoObj.objectId, + "objectType": "Activity" + }; + stmt.result = stmt.result || {}; + stmt.result.extensions = stmt.result.extensions || {}; + stmt.context.contextActivities = stmt.context.contextActivities || {}; + stmt.context.contextActivities.category = stmt.context.contextActivities.category || []; + stmt.context.contextActivities.category.push({"id": "https://w3id.org/xapi/video"}); + stmt.context.extensions = stmt.context.extensions || {}; + stmt.context.extensions["https://w3id.org/xapi/video/extensions/session-id"] = videoObj.session; + stmt.context.extensions["https://w3id.org/xapi/video/extensions/length"] = videoObj.videoLength; + + if (videoObj.hasOwnProperty("currentTime")) { + stmt["result"]["extensions"]["https://w3id.org/xapi/video/extensions/time"] = videoObj.currentTime; + } + if (videoObj.hasOwnProperty("progress")) { + stmt["result"]["extensions"]["https://w3id.org/xapi/video/extensions/progress"] = videoObj.progress; + } + if (videoObj.hasOwnProperty("completion")) { + stmt["result"]["completion"] = videoObj.completion; + } + if (videoObj.hasOwnProperty("duration")) { + stmt["result"]["duration"] = videoObj.duration; + } + if (videoObj.hasOwnProperty("playedSegments")) { + stmt["result"]["extensions"]["https://w3id.org/xapi/video/extensions/played-segments"] = + videoObj.playedSegments.map(segment => segment[0] + "[.]" + segment[1]).join("[,]"); + } + if (videoObj.hasOwnProperty("completionThreshold")) { + stmt["context"]["extensions"]["https://w3id.org/xapi/video/extensions/completion-threshold"] = videoObj.completionThreshold; + } + return stmt; +} + +/** + * Mark the current video being watched as completed. + * + * @param {Object} videoObj The learner details about the video element interaction. + * @return {Promise} The promise from the statement network call. + */ +CourseCmi5Plugin.prototype.videoCompleted = function (videoObj) { + if (!this.cmi5) { + return Promise.resolve(null); + } + + let stmt = this._videoMakeStatement(videoObj, VERB_VIDEO_COMPLETED_OBJ); + return this.sendStatement(stmt); +} + +/** + * Initialize the current video watching session. + * + * @param {Object} videoObj The learner details about the video element interaction. + * @return {Promise} The promise from the statement network call. + */ +CourseCmi5Plugin.prototype.videoInitialize = function (videoObj) { + if (!this.cmi5) { + return Promise.resolve(null); + } + + // A video that's been loaded must be marked as initialized for the (video) session, exactly once. + let stmt = this._videoMakeStatement(videoObj, VERB_VIDEO_INITIALIZED_OBJ); + return this.sendStatement(stmt); +} + +/** + * Mark the current video being watched as paused. + * + * @param {Object} videoObj The learner details about the video element interaction. + * @return {Promise} The promise from the statement network call. + */ +CourseCmi5Plugin.prototype.videoPause = function (videoObj) { + if (!this.cmi5) { + return Promise.resolve(null); + } + + let stmt = this._videoMakeStatement(videoObj, VERB_VIDEO_PAUSED_OBJ); + return this.sendStatement(stmt); +} + +/** + * Mark the current video being watched as played. + * + * @param {Object} videoObj The learner details about the video element interaction. + * @return {Promise} The promise from the statement network call. + */ +CourseCmi5Plugin.prototype.videoPlay = function (videoObj) { + if (!this.cmi5) { + return Promise.resolve(null); + } + + let stmt = this._videoMakeStatement(videoObj, VERB_VIDEO_PLAYED_OBJ); + return this.sendStatement(stmt); +} + +/** + * Answers if the current state of the course should save cmi5 statements to a backend in the general case. + * + * @param {Object=} opts + * @return {boolean} true if the tracking plugin should save statements, false otherwise. + * @private + */ +CourseCmi5Plugin.prototype._shouldSendStatement = function (opts) { + if (!opts) { + opts = {}; + } + if (!opts.forceSend) { + opts.forceSend = false; + } + return this.launchMode.toLowerCase() === "normal" || opts.forceSend; +} + +/** + * If there are buffered statements waiting to be sent, begin sending them. + */ +CourseCmi5Plugin.prototype.flushBatch = function () { + return this._sendStatements(this.statementBatch); +} + +/** + * Buffer a cmi5 statement to be sent in the future. + * + * @param {Object} statement A cmi5 statement to save. + * @param {Object=} opts + * @return {Promise} Does nothing, provided for matching interface with sendStatement. + */ +CourseCmi5Plugin.prototype.batchStatement = function (statement, opts) { + this.statementBatch.push(statement); + return Promise.resolve(null); +} + +/** + * Buffer cmi5 statements to be sent in the future. + * + * @param {Array} statements cmi5 statements to save. + * @param {Object=} opts + * @return {Promise} Does nothing, provided for matching interface with sendStatement. + */ +CourseCmi5Plugin.prototype.batchStatements = function (statements, opts) { + this.statementBatch = this.statementBatch.concat(statements); + return Promise.resolve(null); +} + +/** + * Send a cmi5 statement to the LRS. + * + * @param {Object} statement A cmi5 statement to save. + * @param {Object=} opts Configuration around the sending parameters of a cmi5 statement. + * @return {Promise} The network call attempting to save the cmi5 statement. + */ +CourseCmi5Plugin.prototype.sendStatement = function (statement, opts) { + if (!opts) { + opts = {}; + } + if (!opts.forceSend) { + opts.forceSend = false; + } + if (!opts.hasOwnProperty("queue")) { + opts.queue = false; + } + // forceSend sends the statement even if we're in browse/review mode. Normally should only be used + // for initialized/terminated statements. + if (this._shouldSendStatement(opts)) { + if (opts.queue) { + return this.batchStatement(statement, opts); + } else { + return this._sendStatement(statement); + } + } + return Promise.resolve(null); +} + +/** + * Send a list of cmi5 statements to the LRS. + * + * @param {Array} statements A cmi5 statement to save. + * @param {Object=} opts Configuration around the sending parameters of a cmi5 statement. + * @return {Promise} The network call attempting to save the cmi5 statement. + */ +CourseCmi5Plugin.prototype.sendStatements = function (statements, opts) { + if (!opts) { + opts = {}; + } + if (!opts.forceSend) { + opts.forceSend = false; + } + if (!opts.hasOwnProperty("queue")) { + opts.queue = false; + } + // forceSend sends the statement even if we're in browse/review mode. Normally should only be used + // for initialized/terminated statements. + if (this._shouldSendStatement(opts)) { + if (opts.queue) { + return this.batchStatements(statements, opts); + } else { + return this._sendStatements(statements); + } + } + return Promise.resolve(null); +} + +/** + * Statement tracker sending statements and waiting for statement network calls to end, responsible for updating the + * main course adapter whenever there's a state change. + * + * @param {Object} statement A cmi5 statement to save. + * @return {Promise} The network call attempting to save the cmi5 statement. + * @private + */ +CourseCmi5Plugin.prototype._sendStatement = function (statement) { + this.activeStatements += 1; + this.callbackOnStatementSend(null, null, this.activeStatements); + return this.cmi5.sendStatement(statement).then(result => { + this.activeStatements -= 1; + if (this.callbackOnStatementSend) { + this.callbackOnStatementSend(result, null, this.activeStatements); + } + }).catch(error => { + this.activeStatements -= 1; + if (this.callbackOnStatementSend) { + this.callbackOnStatementSend(null, error, this.activeStatements); + } + }) +} + +/** + * Statement tracker sending statements and waiting for statement network calls to end, responsible for updating the + * main course adapter whenever there's a state change. + * + * @param {Array} statements A list of cmi5 statements to save. + * @return {Promise} The network call attempting to save the cmi5 statement. + * @private + */ +CourseCmi5Plugin.prototype._sendStatements = function (statements) { + this.activeStatements += 1; + this.callbackOnStatementSend(null, null, this.activeStatements); + return this.cmi5.sendStatements(statements).then(result => { + this.activeStatements -= 1; + if (this.callbackOnStatementSend) { + this.callbackOnStatementSend(result, null, this.activeStatements); + } + }).catch(error => { + this.activeStatements -= 1; + if (this.callbackOnStatementSend) { + this.callbackOnStatementSend(null, error, this.activeStatements); + } + }) +} + +/** + * Some statements in the cmi5 library used by this tracking plugin are themselves function calls that manage their + * own sending state. Use these functions instead of directly sending statements here, but still manage the same + * callbacks and communications as done in `_sendStatement`. + * + * @param {Function} statementFn A function call that should trigger a statement save. + * @return {Promise} The network call attempting to save the cmi5 statement. + * @private + */ +CourseCmi5Plugin.prototype._sendStatementViaLibFunction = function (statementFn) { + this.activeStatements += 1; + this.callbackOnStatementSend(null, null, this.activeStatements); + return statementFn().then(result => { + this.activeStatements -= 1; + if (this.callbackOnStatementSend) { + this.callbackOnStatementSend(result, null, this.activeStatements); + } + }).catch(error => { + this.activeStatements -= 1; + if (this.callbackOnStatementSend) { + this.callbackOnStatementSend(null, error, this.activeStatements); + } + }) +} diff --git a/KST-ASD-BI-101/style/base.css b/KST-ASD-BI-101/style/base.css new file mode 100644 index 0000000..f89a3af --- /dev/null +++ b/KST-ASD-BI-101/style/base.css @@ -0,0 +1,436 @@ +/* + Copyright 2021 Rustici Software + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ + +html, body { + padding: 0; + margin: 0; + border: 0; + font-family: Arial, sans-serif; + font-size: 16px; + line-height: 1.5; +} + +main { + position: relative; +} + +.navigation { + position: fixed; + top: 0; + left: 0; + bottom: 0; + width: 225px; + background-color: #f6f6f6; + box-shadow: inset -2rem 0 2rem -2rem rgb(0 0 0 / 40%); + overflow-y: auto; + user-select: none; +} + +.navcorner { + background-size: cover; + background-position: 50% 50%; + background-repeat: no-repeat; + width: 100%; + height: 150px; + + color: white; + text-align: center; + font-size: 24px; + font-weight: bold; + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; +} + +.navtitle { + text-shadow: 3px 3px 6px #000000; +} + +.navtoggle { + display: none; + border: 1px solid black; + border-radius: 3px; + background-color: lightgray; + position: fixed; + top: 5px; + left: 10px; + z-index: 110; + cursor: pointer; +} + +.navmenu ul { + list-style: none; + padding: 0; +} + +.navmenu li { + margin: 0; + padding: 1em; +} + +.navmenu li.current { + border-left: 5px solid #ddb0b0 !important; + background-color: #ffd0d0 !important; + box-shadow: inset -2rem 0 2rem -2rem rgb(0 0 0 / 40%); +} + +.navmenu li.seen { + border-left: 5px solid #99ff99; +} + +.navmenu li:hover { + background-color: #e6e6e6; + box-shadow: inset -2rem 0 2rem -2rem rgb(0 0 0 / 40%); +} + +.navexit { + position: absolute; + top: 5px; + right: 10px; +} + +.footer-progress { + font-size: small; + color: #856404; + background-color: #fff3cd; + border: 1px solid #ffeeba; + text-align: center; + padding: 10px; +} + +.content { + padding-left: 225px; +} + +@media (max-width: 620px) { + .navtoggle { + display: block; + } + + .navigation { + display: none; + } + + .navigation.visible-narrow { + display: block; + } + + .content { + padding-left: 0; + } +} + +.homebar { + background-color: #eee; + text-align: center; + font-size: 16px; + font-weight: bold; + padding: 1em; + cursor: pointer; +} + +.footerbar { + background-color: #eee; + text-align: center; + font-size: 16px; + font-weight: bold; + padding: 1em; + cursor: pointer; +} + +.title { + font-size: 24px; + font-weight: bold; + padding: 2em 0 2em 4em; +} + +.titleunderbar { + background-color: #8b4513; + margin-top: 2em; + height: 5px; + width: 200px; +} + +.body-content { + margin: 2em 6em; +} + +.body-content2col { + margin: 2em 6em; + columns: 2; + column-gap: 3em; +} + +.bodyimg { + position: relative; + max-height: 60rem; + min-height: 15rem; + width: 100%; + overflow: hidden; + background-repeat: no-repeat; + background-position: 50%; + background-size: cover; +} + +.bodyimg img { + opacity: 0; + max-height: 100%; + max-width: 100%; +} + +.body-video { + margin: 2em 6em; +} + +@media (max-width: 620px) { + .title { + padding-left: 35px; + } + + .body-content { + margin: 2em 2em; + } + + .body-content2col { + margin: 2em 2em; + } + + .body-video { + margin: 2em 2em; + } +} + +.body-video video { + width: 100%; +} + +.changePage { + -webkit-animation: flash 0.5s ease 1; + -moz-animation: flash 0.5s ease 1; + -ms-animation: flash 0.5s ease 1; + -o-animation: flash 0.5s ease 1; + animation: flash 0.5s ease 1; +} + +@keyframes flash { + 100% { + opacity: 0; + } +} + +input, select { + vertical-align: middle; + padding: .375rem .75rem; + font-size: 1rem; + line-height: 1.5; + color: #495057; + background-color: #fff; + background-clip: padding-box; + border: 1px solid #ced4da; + border-radius: .25rem; + transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out; +} + +select { + min-width: 10rem; +} + +select:not([size]):not([multiple]) { + height: calc(2.25rem + 2px); +} + +input:focus, select:focus { + color: #495057; + background-color: #fff; + border-color: #80bdff; + outline: 0; + box-shadow: 0 0 0 0.2rem rgb(0 123 255 / 25%); +} + +.full-overlay { + position: fixed; + top: 0; + left: 0; + right: 0; + bottom: 0; + display: none; + background-color: #00000077; + justify-content: center; + align-items: center; +} + +.full-overlay.full-overlay-visible { + display: flex; +} + +.full-overlay .message-content { + width: 500px; + height: 200px; + border: 3px solid black; + background-color: white; + justify-content: center; + align-items: center; + display: flex; + flex-direction: column; + gap: 10px; +} + +.quiz .title-contents { + display: flex; +} + +.quiz .title-contents-heading { + flex: 1; +} + +.quiz .title-contents-buttons { + text-align: right; +} + +.quiz label { + display: block; +} + +.quiz .radiochoices label { + display: inline; + padding-top: 0.25em; +} + +.quiz .radiochoices .radiochoice { + display: flex; + align-items: center; +} + +.quiz .radiochoices input[type=radio] { + margin: 0 0.5em 0.02em 0; +} + +.text-attribution { + color: gray; +} + +.video-start-overlay { + position: absolute; + top: 0; + left: 0; + right: 0; + bottom: 0; + background-color: #00000077; + display: flex; + align-items: center; + justify-content: center; + cursor: pointer; +} + +.video-start-overlay .msg { + border: 4px solid #ffd0d0; + border-radius: 5px; + padding: 10px; + background-color: white; + font-weight: bold; +} + +.video-complete-overlay { + position: absolute; + top: 0; + left: 0; + right: 0; + bottom: 0; + background-color: #777777; + display: flex; + align-items: center; + justify-content: center; + cursor: default; +} + +.video-complete-overlay .msg { + border: 4px solid #ffd0d0; + border-radius: 5px; + padding: 10px; + background-color: white; + font-weight: bold; +} + +.video-start-overlay.hidden, .video-complete-overlay.hidden { + display: none; +} + +.video-attribution { + color: gray; + font-size: small; + text-align: center; + padding-bottom: 0.25em; +} + +.info-bar { + display: none; + position: fixed; + right: 0; + left: 0; + white-space: nowrap; + height: 25px; + z-index: 99; + color: #856404; + background-color: #fff3cd; + border: 1px solid #ffeeba; + text-align: center; +} + +body.info-bar-visible .info-bar { + display: block; +} + +body.info-bar-visible .navigation { + top: 27px; +} + +body.info-bar-visible .content { + padding-top: 27px; +} + +.score-passed, .score-failed { + display: none; +} + +.score-passed.visible, .score-failed.visible { + display: block; +} + +.warning-floater { + position: absolute; + top: 5px; + right: 5px; + z-index: 102; +} + +.warning-icon { + display: none; + cursor: pointer; +} + +.warning-icon.warning-icon-visible { + display: block; +} + +.warning-icon-container { + background-color: pink; + border: 1px solid red; + border-radius: 5px; + padding: 4px; + color: red; + font-weight: bold; +} diff --git a/KST-ASD-BI-101/video/mountains_31175.mp4 b/KST-ASD-BI-101/video/mountains_31175.mp4 new file mode 100644 index 0000000..4d2ceee Binary files /dev/null and b/KST-ASD-BI-101/video/mountains_31175.mp4 differ