├── README.md
├── backend
├── .gitignore
├── auth_site
│ ├── __init__.py
│ ├── asgi.py
│ ├── settings.py
│ ├── urls.py
│ └── wsgi.py
├── manage.py
├── requirements.txt
└── users
│ ├── __init__.py
│ ├── admin.py
│ ├── apps.py
│ ├── migrations
│ ├── 0001_initial.py
│ └── __init__.py
│ ├── models.py
│ ├── serializers.py
│ ├── tests.py
│ ├── urls.py
│ └── views.py
└── frontend
├── .env
├── .gitignore
├── client
├── .env
├── .gitignore
├── README.md
├── jsconfig.json
├── package-lock.json
├── package.json
├── public
│ ├── favicon.ico
│ ├── index.html
│ ├── logo192.png
│ ├── logo512.png
│ ├── manifest.json
│ └── robots.txt
└── src
│ ├── App.js
│ ├── App.test.js
│ ├── components
│ ├── Layout.js
│ └── Navbar.js
│ ├── config
│ └── index.js
│ ├── containers
│ ├── DashboardPage.js
│ ├── HomePage.js
│ ├── LoginPage.js
│ └── RegisterPage.js
│ ├── features
│ └── user.js
│ ├── index.js
│ ├── reportWebVitals.js
│ ├── setupProxy.js
│ ├── setupTests.js
│ └── store.js
├── index.js
├── package-lock.json
├── package.json
└── routes
└── auth
├── login.js
├── logout.js
├── me.js
├── register.js
└── verify.js
/README.md:
--------------------------------------------------------------------------------
1 | # Auth Site
2 |
3 | This is a project that demonstrates how to do JWT authentication using Django and React served by an Express server.
4 |
5 | The json web token credentials in this project are stored with cookies that have the httpOnly flag set to true to prevent JavaScript on the browser from accessing the values.
6 |
7 | To test the project, simply:
8 |
9 | - clone the repository
10 | - in the backend folder, create a virtual environment with: python3 -m venv venv
11 | - activate the virtual environment: source venv/bin/activate (MacOS), .\venv\Scripts\activate.bat (Windows)
12 | - then install the python packages: pip install -r requirements.txt
13 | - migrate to the Sqlite3 database: python manage.py migrate
14 | - run the server: python manage.py runserver
15 | - in the frontend/client folder, run: npm install
16 | - in the frontend/client folder, run: npm build
17 | - in the frontend folder, run: npm install
18 | - in the frontend folder, run: npm start
19 | - in the browser navigate to (Production): http://localhost:5000
20 | - optionally you can also navigate into fronend/client, then run: npm start
21 | - then from there in the browser navigate to (Development): http://localhost:3000
22 |
--------------------------------------------------------------------------------
/backend/.gitignore:
--------------------------------------------------------------------------------
1 | # Django #
2 | *.log
3 | *.pot
4 | *.pyc
5 | __pycache__
6 | db.sqlite3
7 | media
8 |
9 | # Backup files #
10 | *.bak
11 |
12 | # If you are using PyCharm #
13 | # User-specific stuff
14 | .idea/**/workspace.xml
15 | .idea/**/tasks.xml
16 | .idea/**/usage.statistics.xml
17 | .idea/**/dictionaries
18 | .idea/**/shelf
19 |
20 | # AWS User-specific
21 | .idea/**/aws.xml
22 |
23 | # Generated files
24 | .idea/**/contentModel.xml
25 |
26 | # Sensitive or high-churn files
27 | .idea/**/dataSources/
28 | .idea/**/dataSources.ids
29 | .idea/**/dataSources.local.xml
30 | .idea/**/sqlDataSources.xml
31 | .idea/**/dynamic.xml
32 | .idea/**/uiDesigner.xml
33 | .idea/**/dbnavigator.xml
34 |
35 | # Gradle
36 | .idea/**/gradle.xml
37 | .idea/**/libraries
38 |
39 | # File-based project format
40 | *.iws
41 |
42 | # IntelliJ
43 | out/
44 |
45 | # JIRA plugin
46 | atlassian-ide-plugin.xml
47 |
48 | # Python #
49 | *.py[cod]
50 | *$py.class
51 |
52 | # Distribution / packaging
53 | .Python build/
54 | develop-eggs/
55 | dist/
56 | downloads/
57 | eggs/
58 | .eggs/
59 | lib/
60 | lib64/
61 | parts/
62 | sdist/
63 | var/
64 | wheels/
65 | *.egg-info/
66 | .installed.cfg
67 | *.egg
68 | *.manifest
69 | *.spec
70 |
71 | # Installer logs
72 | pip-log.txt
73 | pip-delete-this-directory.txt
74 |
75 | # Unit test / coverage reports
76 | htmlcov/
77 | .tox/
78 | .coverage
79 | .coverage.*
80 | .cache
81 | .pytest_cache/
82 | nosetests.xml
83 | coverage.xml
84 | *.cover
85 | .hypothesis/
86 |
87 | # Jupyter Notebook
88 | .ipynb_checkpoints
89 |
90 | # pyenv
91 | .python-version
92 |
93 | # celery
94 | celerybeat-schedule.*
95 |
96 | # SageMath parsed files
97 | *.sage.py
98 |
99 | # Environments
100 | .env
101 | .venv
102 | env/
103 | venv/
104 | ENV/
105 | env.bak/
106 | venv.bak/
107 |
108 | # mkdocs documentation
109 | /site
110 |
111 | # mypy
112 | .mypy_cache/
113 |
114 | # Sublime Text #
115 | *.tmlanguage.cache
116 | *.tmPreferences.cache
117 | *.stTheme.cache
118 | *.sublime-workspace
119 | *.sublime-project
120 |
121 | # sftp configuration file
122 | sftp-config.json
123 |
124 | # Package control specific files Package
125 | Control.last-run
126 | Control.ca-list
127 | Control.ca-bundle
128 | Control.system-ca-bundle
129 | GitHub.sublime-settings
130 |
131 | # Visual Studio Code #
132 | .vscode/*
133 | !.vscode/settings.json
134 | !.vscode/tasks.json
135 | !.vscode/launch.json
136 | !.vscode/extensions.json
137 | .history
138 |
--------------------------------------------------------------------------------
/backend/auth_site/__init__.py:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/linkedweb/auth-site/62eddf13a7f974d5e240feca5d05815651b0c051/backend/auth_site/__init__.py
--------------------------------------------------------------------------------
/backend/auth_site/asgi.py:
--------------------------------------------------------------------------------
1 | """
2 | ASGI config for auth_site project.
3 |
4 | It exposes the ASGI callable as a module-level variable named ``application``.
5 |
6 | For more information on this file, see
7 | https://docs.djangoproject.com/en/4.0/howto/deployment/asgi/
8 | """
9 |
10 | import os
11 |
12 | from django.core.asgi import get_asgi_application
13 |
14 | os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'auth_site.settings')
15 |
16 | application = get_asgi_application()
17 |
--------------------------------------------------------------------------------
/backend/auth_site/settings.py:
--------------------------------------------------------------------------------
1 | """
2 | Django settings for auth_site project.
3 |
4 | Generated by 'django-admin startproject' using Django 4.0.5.
5 |
6 | For more information on this file, see
7 | https://docs.djangoproject.com/en/4.0/topics/settings/
8 |
9 | For the full list of settings and their values, see
10 | https://docs.djangoproject.com/en/4.0/ref/settings/
11 | """
12 |
13 | from datetime import timedelta
14 | from pathlib import Path
15 |
16 | # Build paths inside the project like this: BASE_DIR / 'subdir'.
17 | BASE_DIR = Path(__file__).resolve().parent.parent
18 |
19 |
20 | # Quick-start development settings - unsuitable for production
21 | # See https://docs.djangoproject.com/en/4.0/howto/deployment/checklist/
22 |
23 | # SECURITY WARNING: keep the secret key used in production secret!
24 | SECRET_KEY = 'django-insecure-&0xu%hz(6x7*p^c(uy5!9c)f8b=hb03xqed8d1_tkgy6z)_un6'
25 |
26 | # SECURITY WARNING: don't run with debug turned on in production!
27 | DEBUG = True
28 |
29 | ALLOWED_HOSTS = []
30 |
31 |
32 | # Application definition
33 |
34 | INSTALLED_APPS = [
35 | 'django.contrib.admin',
36 | 'django.contrib.auth',
37 | 'django.contrib.contenttypes',
38 | 'django.contrib.sessions',
39 | 'django.contrib.messages',
40 | 'django.contrib.staticfiles',
41 | 'rest_framework',
42 | 'users',
43 | ]
44 |
45 | MIDDLEWARE = [
46 | 'django.middleware.security.SecurityMiddleware',
47 | 'django.contrib.sessions.middleware.SessionMiddleware',
48 | 'django.middleware.common.CommonMiddleware',
49 | 'django.middleware.csrf.CsrfViewMiddleware',
50 | 'django.contrib.auth.middleware.AuthenticationMiddleware',
51 | 'django.contrib.messages.middleware.MessageMiddleware',
52 | 'django.middleware.clickjacking.XFrameOptionsMiddleware',
53 | ]
54 |
55 | ROOT_URLCONF = 'auth_site.urls'
56 |
57 | TEMPLATES = [
58 | {
59 | 'BACKEND': 'django.template.backends.django.DjangoTemplates',
60 | 'DIRS': [],
61 | 'APP_DIRS': True,
62 | 'OPTIONS': {
63 | 'context_processors': [
64 | 'django.template.context_processors.debug',
65 | 'django.template.context_processors.request',
66 | 'django.contrib.auth.context_processors.auth',
67 | 'django.contrib.messages.context_processors.messages',
68 | ],
69 | },
70 | },
71 | ]
72 |
73 | WSGI_APPLICATION = 'auth_site.wsgi.application'
74 |
75 |
76 | # Database
77 | # https://docs.djangoproject.com/en/4.0/ref/settings/#databases
78 |
79 | DATABASES = {
80 | 'default': {
81 | 'ENGINE': 'django.db.backends.sqlite3',
82 | 'NAME': BASE_DIR / 'db.sqlite3',
83 | }
84 | }
85 |
86 |
87 | # Password validation
88 | # https://docs.djangoproject.com/en/4.0/ref/settings/#auth-password-validators
89 |
90 | AUTH_PASSWORD_VALIDATORS = [
91 | {
92 | 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
93 | },
94 | {
95 | 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
96 | },
97 | {
98 | 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
99 | },
100 | {
101 | 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
102 | },
103 | ]
104 |
105 |
106 | # Internationalization
107 | # https://docs.djangoproject.com/en/4.0/topics/i18n/
108 |
109 | LANGUAGE_CODE = 'en-us'
110 |
111 | TIME_ZONE = 'UTC'
112 |
113 | USE_I18N = True
114 |
115 | USE_TZ = True
116 |
117 |
118 | # Static files (CSS, JavaScript, Images)
119 | # https://docs.djangoproject.com/en/4.0/howto/static-files/
120 |
121 | STATIC_URL = 'static/'
122 |
123 | # Default primary key field type
124 | # https://docs.djangoproject.com/en/4.0/ref/settings/#default-auto-field
125 |
126 | DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
127 |
128 | REST_FRAMEWORK = {
129 | 'DEFAULT_AUTHENTICATION_CLASSES': [
130 | 'rest_framework_simplejwt.authentication.JWTAuthentication',
131 | ]
132 | }
133 |
134 | SIMPLE_JWT = {
135 | 'ACCESS_TOKEN_LIFETIME': timedelta(minutes=30),
136 | }
137 |
138 | AUTH_USER_MODEL = 'users.UserAccount'
139 |
--------------------------------------------------------------------------------
/backend/auth_site/urls.py:
--------------------------------------------------------------------------------
1 | """auth_site URL Configuration
2 |
3 | The `urlpatterns` list routes URLs to views. For more information please see:
4 | https://docs.djangoproject.com/en/4.0/topics/http/urls/
5 | Examples:
6 | Function views
7 | 1. Add an import: from my_app import views
8 | 2. Add a URL to urlpatterns: path('', views.home, name='home')
9 | Class-based views
10 | 1. Add an import: from other_app.views import Home
11 | 2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')
12 | Including another URLconf
13 | 1. Import the include() function: from django.urls import include, path
14 | 2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
15 | """
16 | from django.contrib import admin
17 | from django.urls import path, include
18 | from rest_framework_simplejwt.views import TokenObtainPairView, TokenRefreshView, TokenVerifyView
19 |
20 | urlpatterns = [
21 | path('api/token/', TokenObtainPairView.as_view()),
22 | path('api/token/refresh/', TokenRefreshView.as_view()),
23 | path('api/token/verify/', TokenVerifyView.as_view()),
24 | path('api/users/', include('users.urls')),
25 | path('admin/', admin.site.urls),
26 | ]
27 |
--------------------------------------------------------------------------------
/backend/auth_site/wsgi.py:
--------------------------------------------------------------------------------
1 | """
2 | WSGI config for auth_site project.
3 |
4 | It exposes the WSGI callable as a module-level variable named ``application``.
5 |
6 | For more information on this file, see
7 | https://docs.djangoproject.com/en/4.0/howto/deployment/wsgi/
8 | """
9 |
10 | import os
11 |
12 | from django.core.wsgi import get_wsgi_application
13 |
14 | os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'auth_site.settings')
15 |
16 | application = get_wsgi_application()
17 |
--------------------------------------------------------------------------------
/backend/manage.py:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env python
2 | """Django's command-line utility for administrative tasks."""
3 | import os
4 | import sys
5 |
6 |
7 | def main():
8 | """Run administrative tasks."""
9 | os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'auth_site.settings')
10 | try:
11 | from django.core.management import execute_from_command_line
12 | except ImportError as exc:
13 | raise ImportError(
14 | "Couldn't import Django. Are you sure it's installed and "
15 | "available on your PYTHONPATH environment variable? Did you "
16 | "forget to activate a virtual environment?"
17 | ) from exc
18 | execute_from_command_line(sys.argv)
19 |
20 |
21 | if __name__ == '__main__':
22 | main()
23 |
--------------------------------------------------------------------------------
/backend/requirements.txt:
--------------------------------------------------------------------------------
1 | asgiref==3.5.2
2 | Django==4.0.5
3 | djangorestframework==3.13.1
4 | djangorestframework-simplejwt==5.2.0
5 | PyJWT==2.4.0
6 | pytz==2022.1
7 | sqlparse==0.4.2
8 |
--------------------------------------------------------------------------------
/backend/users/__init__.py:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/linkedweb/auth-site/62eddf13a7f974d5e240feca5d05815651b0c051/backend/users/__init__.py
--------------------------------------------------------------------------------
/backend/users/admin.py:
--------------------------------------------------------------------------------
1 | from django.contrib import admin
2 |
3 | # Register your models here.
4 |
--------------------------------------------------------------------------------
/backend/users/apps.py:
--------------------------------------------------------------------------------
1 | from django.apps import AppConfig
2 |
3 |
4 | class UsersConfig(AppConfig):
5 | default_auto_field = 'django.db.models.BigAutoField'
6 | name = 'users'
7 |
--------------------------------------------------------------------------------
/backend/users/migrations/0001_initial.py:
--------------------------------------------------------------------------------
1 | # Generated by Django 4.0.5 on 2022-06-17 18:27
2 |
3 | from django.db import migrations, models
4 |
5 |
6 | class Migration(migrations.Migration):
7 |
8 | initial = True
9 |
10 | dependencies = [
11 | ('auth', '0012_alter_user_first_name_max_length'),
12 | ]
13 |
14 | operations = [
15 | migrations.CreateModel(
16 | name='UserAccount',
17 | fields=[
18 | ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
19 | ('password', models.CharField(max_length=128, verbose_name='password')),
20 | ('last_login', models.DateTimeField(blank=True, null=True, verbose_name='last login')),
21 | ('is_superuser', models.BooleanField(default=False, help_text='Designates that this user has all permissions without explicitly assigning them.', verbose_name='superuser status')),
22 | ('first_name', models.CharField(max_length=255)),
23 | ('last_name', models.CharField(max_length=255)),
24 | ('email', models.EmailField(max_length=255, unique=True)),
25 | ('is_active', models.BooleanField(default=True)),
26 | ('is_staff', models.BooleanField(default=False)),
27 | ('groups', models.ManyToManyField(blank=True, help_text='The groups this user belongs to. A user will get all permissions granted to each of their groups.', related_name='user_set', related_query_name='user', to='auth.group', verbose_name='groups')),
28 | ('user_permissions', models.ManyToManyField(blank=True, help_text='Specific permissions for this user.', related_name='user_set', related_query_name='user', to='auth.permission', verbose_name='user permissions')),
29 | ],
30 | options={
31 | 'abstract': False,
32 | },
33 | ),
34 | ]
35 |
--------------------------------------------------------------------------------
/backend/users/migrations/__init__.py:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/linkedweb/auth-site/62eddf13a7f974d5e240feca5d05815651b0c051/backend/users/migrations/__init__.py
--------------------------------------------------------------------------------
/backend/users/models.py:
--------------------------------------------------------------------------------
1 | from django.db import models
2 | from django.contrib.auth.models import BaseUserManager, AbstractBaseUser, PermissionsMixin
3 |
4 |
5 | class UserAccountManager(BaseUserManager):
6 | def create_user(self, first_name, last_name, email, password=None):
7 | if not email:
8 | raise ValueError('Users must have an email address')
9 |
10 | email = self.normalize_email(email)
11 | email = email.lower()
12 |
13 | user = self.model(
14 | first_name=first_name,
15 | last_name=last_name,
16 | email=email,
17 | )
18 |
19 | user.set_password(password)
20 | user.save(using=self._db)
21 |
22 | return user
23 |
24 | def create_superuser(self, first_name, last_name, email, password=None):
25 | user = self.create_user(
26 | first_name,
27 | last_name,
28 | email,
29 | password=password,
30 | )
31 |
32 | user.is_staff = True
33 | user.is_superuser = True
34 | user.save(using=self._db)
35 |
36 | return user
37 |
38 |
39 | class UserAccount(AbstractBaseUser, PermissionsMixin):
40 | first_name = models.CharField(max_length=255)
41 | last_name = models.CharField(max_length=255)
42 | email = models.EmailField(unique=True, max_length=255)
43 | is_active = models.BooleanField(default=True)
44 | is_staff = models.BooleanField(default=False)
45 |
46 | objects = UserAccountManager()
47 |
48 | USERNAME_FIELD = 'email'
49 | REQUIRED_FIELDS = ['first_name', 'last_name']
50 |
51 | def __str__(self):
52 | return self.email
53 |
--------------------------------------------------------------------------------
/backend/users/serializers.py:
--------------------------------------------------------------------------------
1 | from django.contrib.auth.password_validation import validate_password
2 | from django.core import exceptions
3 | from rest_framework import serializers
4 | from django.contrib.auth import get_user_model
5 | User = get_user_model()
6 |
7 |
8 | class UserCreateSerializer(serializers.ModelSerializer):
9 | class Meta:
10 | model = User
11 | fields = ('first_name', 'last_name', 'email', 'password')
12 |
13 | def validate(self, data):
14 | user = User(**data)
15 | password = data.get('password')
16 |
17 | try:
18 | validate_password(password, user)
19 | except exceptions.ValidationError as e:
20 | serializer_errors = serializers.as_serializer_error(e)
21 | raise exceptions.ValidationError(
22 | {'password': serializer_errors['non_field_errors']}
23 | )
24 |
25 | return data
26 |
27 |
28 | def create(self, validated_data):
29 | user = User.objects.create_user(
30 | first_name=validated_data['first_name'],
31 | last_name=validated_data['last_name'],
32 | email=validated_data['email'],
33 | password=validated_data['password'],
34 | )
35 |
36 | return user
37 |
38 |
39 | class UserSerializer(serializers.ModelSerializer):
40 | class Meta:
41 | model = User
42 | fields = ('first_name', 'last_name', 'email',)
43 |
--------------------------------------------------------------------------------
/backend/users/tests.py:
--------------------------------------------------------------------------------
1 | from django.test import TestCase
2 |
3 | # Create your tests here.
4 |
--------------------------------------------------------------------------------
/backend/users/urls.py:
--------------------------------------------------------------------------------
1 | from django.urls import path
2 | from .views import RegisterView, RetrieveUserView
3 |
4 |
5 | urlpatterns = [
6 | path('register', RegisterView.as_view()),
7 | path('me', RetrieveUserView.as_view()),
8 | ]
9 |
--------------------------------------------------------------------------------
/backend/users/views.py:
--------------------------------------------------------------------------------
1 | from rest_framework.views import APIView
2 | from rest_framework.response import Response
3 | from rest_framework import permissions, status
4 | from .serializers import UserCreateSerializer, UserSerializer
5 |
6 |
7 | class RegisterView(APIView):
8 | def post(self, request):
9 | data = request.data
10 |
11 | serializer = UserCreateSerializer(data=data)
12 |
13 | if not serializer.is_valid():
14 | return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)
15 |
16 | user = serializer.create(serializer.validated_data)
17 | user = UserSerializer(user)
18 |
19 | return Response(user.data, status=status.HTTP_201_CREATED)
20 |
21 |
22 | class RetrieveUserView(APIView):
23 | permission_classes = [permissions.IsAuthenticated]
24 |
25 | def get(self, request):
26 | user = request.user
27 | user = UserSerializer(user)
28 |
29 | return Response(user.data, status=status.HTTP_200_OK)
30 |
--------------------------------------------------------------------------------
/frontend/.env:
--------------------------------------------------------------------------------
1 | NODE_ENV='development'
2 | API_URL='http://localhost:8000'
3 |
--------------------------------------------------------------------------------
/frontend/.gitignore:
--------------------------------------------------------------------------------
1 | /node_modules
2 |
3 | .DS_Store
4 |
--------------------------------------------------------------------------------
/frontend/client/.env:
--------------------------------------------------------------------------------
1 | NODE_ENV='development'
2 | REACT_APP_API_URL='http://localhost:8000'
3 |
--------------------------------------------------------------------------------
/frontend/client/.gitignore:
--------------------------------------------------------------------------------
1 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
2 |
3 | # dependencies
4 | /node_modules
5 | /.pnp
6 | .pnp.js
7 |
8 | # testing
9 | /coverage
10 |
11 | # production
12 | /build
13 |
14 | # misc
15 | .DS_Store
16 | .env.local
17 | .env.development.local
18 | .env.test.local
19 | .env.production.local
20 |
21 | npm-debug.log*
22 | yarn-debug.log*
23 | yarn-error.log*
24 |
--------------------------------------------------------------------------------
/frontend/client/README.md:
--------------------------------------------------------------------------------
1 | # Getting Started with Create React App
2 |
3 | This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app).
4 |
5 | ## Available Scripts
6 |
7 | In the project directory, you can run:
8 |
9 | ### `npm start`
10 |
11 | Runs the app in the development mode.\
12 | Open [http://localhost:3000](http://localhost:3000) to view it in your browser.
13 |
14 | The page will reload when you make changes.\
15 | You may also see any lint errors in the console.
16 |
17 | ### `npm test`
18 |
19 | Launches the test runner in the interactive watch mode.\
20 | See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information.
21 |
22 | ### `npm run build`
23 |
24 | Builds the app for production to the `build` folder.\
25 | It correctly bundles React in production mode and optimizes the build for the best performance.
26 |
27 | The build is minified and the filenames include the hashes.\
28 | Your app is ready to be deployed!
29 |
30 | See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information.
31 |
32 | ### `npm run eject`
33 |
34 | **Note: this is a one-way operation. Once you `eject`, you can't go back!**
35 |
36 | If you aren't satisfied with the build tool and configuration choices, you can `eject` at any time. This command will remove the single build dependency from your project.
37 |
38 | Instead, it will copy all the configuration files and the transitive dependencies (webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except `eject` will still work, but they will point to the copied scripts so you can tweak them. At this point you're on your own.
39 |
40 | You don't have to ever use `eject`. The curated feature set is suitable for small and middle deployments, and you shouldn't feel obligated to use this feature. However we understand that this tool wouldn't be useful if you couldn't customize it when you are ready for it.
41 |
42 | ## Learn More
43 |
44 | You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started).
45 |
46 | To learn React, check out the [React documentation](https://reactjs.org/).
47 |
48 | ### Code Splitting
49 |
50 | This section has moved here: [https://facebook.github.io/create-react-app/docs/code-splitting](https://facebook.github.io/create-react-app/docs/code-splitting)
51 |
52 | ### Analyzing the Bundle Size
53 |
54 | This section has moved here: [https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size](https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size)
55 |
56 | ### Making a Progressive Web App
57 |
58 | This section has moved here: [https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app](https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app)
59 |
60 | ### Advanced Configuration
61 |
62 | This section has moved here: [https://facebook.github.io/create-react-app/docs/advanced-configuration](https://facebook.github.io/create-react-app/docs/advanced-configuration)
63 |
64 | ### Deployment
65 |
66 | This section has moved here: [https://facebook.github.io/create-react-app/docs/deployment](https://facebook.github.io/create-react-app/docs/deployment)
67 |
68 | ### `npm run build` fails to minify
69 |
70 | This section has moved here: [https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify](https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify)
71 |
--------------------------------------------------------------------------------
/frontend/client/jsconfig.json:
--------------------------------------------------------------------------------
1 | {
2 | "compilerOptions": {
3 | "baseUrl": "src"
4 | },
5 | "include": ["src"]
6 | }
7 |
--------------------------------------------------------------------------------
/frontend/client/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "client",
3 | "version": "0.1.0",
4 | "private": true,
5 | "dependencies": {
6 | "@reduxjs/toolkit": "^1.8.2",
7 | "@testing-library/jest-dom": "^5.16.4",
8 | "@testing-library/react": "^13.3.0",
9 | "@testing-library/user-event": "^13.5.0",
10 | "cookie": "^0.5.0",
11 | "http-proxy-middleware": "^2.0.6",
12 | "react": "^18.2.0",
13 | "react-dom": "^18.2.0",
14 | "react-helmet": "^6.1.0",
15 | "react-redux": "^8.0.2",
16 | "react-router-dom": "^6.3.0",
17 | "web-vitals": "^2.1.4"
18 | },
19 | "devDependencies": {
20 | "react-scripts": "5.0.1"
21 | },
22 | "scripts": {
23 | "start": "react-scripts start",
24 | "build": "react-scripts build",
25 | "test": "react-scripts test",
26 | "eject": "react-scripts eject"
27 | },
28 | "eslintConfig": {
29 | "extends": [
30 | "react-app",
31 | "react-app/jest"
32 | ]
33 | },
34 | "browserslist": {
35 | "production": [
36 | ">0.2%",
37 | "not dead",
38 | "not op_mini all"
39 | ],
40 | "development": [
41 | "last 1 chrome version",
42 | "last 1 firefox version",
43 | "last 1 safari version"
44 | ]
45 | }
46 | }
47 |
--------------------------------------------------------------------------------
/frontend/client/public/favicon.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/linkedweb/auth-site/62eddf13a7f974d5e240feca5d05815651b0c051/frontend/client/public/favicon.ico
--------------------------------------------------------------------------------
/frontend/client/public/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
13 |
14 |
23 |
29 |
30 |
31 |
32 |
33 |
43 |
48 |
49 |
50 |
--------------------------------------------------------------------------------
/frontend/client/public/logo192.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/linkedweb/auth-site/62eddf13a7f974d5e240feca5d05815651b0c051/frontend/client/public/logo192.png
--------------------------------------------------------------------------------
/frontend/client/public/logo512.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/linkedweb/auth-site/62eddf13a7f974d5e240feca5d05815651b0c051/frontend/client/public/logo512.png
--------------------------------------------------------------------------------
/frontend/client/public/manifest.json:
--------------------------------------------------------------------------------
1 | {
2 | "short_name": "React App",
3 | "name": "Create React App Sample",
4 | "icons": [
5 | {
6 | "src": "favicon.ico",
7 | "sizes": "64x64 32x32 24x24 16x16",
8 | "type": "image/x-icon"
9 | },
10 | {
11 | "src": "logo192.png",
12 | "type": "image/png",
13 | "sizes": "192x192"
14 | },
15 | {
16 | "src": "logo512.png",
17 | "type": "image/png",
18 | "sizes": "512x512"
19 | }
20 | ],
21 | "start_url": ".",
22 | "display": "standalone",
23 | "theme_color": "#000000",
24 | "background_color": "#ffffff"
25 | }
26 |
--------------------------------------------------------------------------------
/frontend/client/public/robots.txt:
--------------------------------------------------------------------------------
1 | # https://www.robotstxt.org/robotstxt.html
2 | User-agent: *
3 | Disallow:
4 |
--------------------------------------------------------------------------------
/frontend/client/src/App.js:
--------------------------------------------------------------------------------
1 | import { useEffect } from 'react';
2 | import { useDispatch } from 'react-redux';
3 | import { BrowserRouter as Router, Routes, Route } from 'react-router-dom';
4 | import { checkAuth } from 'features/user';
5 |
6 | import HomePage from 'containers/HomePage';
7 | import DashboardPage from 'containers/DashboardPage';
8 | import LoginPage from 'containers/LoginPage';
9 | import RegisterPage from 'containers/RegisterPage';
10 |
11 | const App = () => {
12 | const dispatch = useDispatch();
13 |
14 | useEffect(() => {
15 | dispatch(checkAuth());
16 | }, []);
17 |
18 | return (
19 |
20 |
21 | } />
22 | } />
23 | } />
24 | } />
25 |
26 |
27 | );
28 | };
29 |
30 | export default App;
31 |
--------------------------------------------------------------------------------
/frontend/client/src/App.test.js:
--------------------------------------------------------------------------------
1 | import { render, screen } from '@testing-library/react';
2 | import App from './App';
3 |
4 | test('renders learn react link', () => {
5 | render();
6 | const linkElement = screen.getByText(/learn react/i);
7 | expect(linkElement).toBeInTheDocument();
8 | });
9 |
--------------------------------------------------------------------------------
/frontend/client/src/components/Layout.js:
--------------------------------------------------------------------------------
1 | import { Helmet } from 'react-helmet';
2 | import Navbar from 'components/Navbar';
3 |
4 | const Layout = ({ title, content, children }) => (
5 | <>
6 |
7 | {title}
8 |
9 |
10 |
11 | {children}
12 | >
13 | );
14 |
15 | export default Layout;
16 |
--------------------------------------------------------------------------------
/frontend/client/src/components/Navbar.js:
--------------------------------------------------------------------------------
1 | import { Link, NavLink } from 'react-router-dom';
2 | import { useSelector, useDispatch } from 'react-redux';
3 | import { logout } from 'features/user';
4 |
5 | const Navbar = () => {
6 | const dispatch = useDispatch();
7 | const { isAuthenticated } = useSelector(state => state.user);
8 |
9 | const authLinks = (
10 | <>
11 |
12 |
13 | Dashboard
14 |
15 |
16 |
17 | dispatch(logout())}>
18 | Logout
19 |
20 |
21 | >
22 | );
23 |
24 | const guestLinks = (
25 | <>
26 |
27 |
28 | Login
29 |
30 |
31 |
32 |
33 | Register
34 |
35 |
36 | >
37 | );
38 |
39 | return (
40 |
68 | );
69 | };
70 |
71 | export default Navbar;
72 |
--------------------------------------------------------------------------------
/frontend/client/src/config/index.js:
--------------------------------------------------------------------------------
1 | export const API_URL = process.env.REACT_APP_API_URL;
2 |
--------------------------------------------------------------------------------
/frontend/client/src/containers/DashboardPage.js:
--------------------------------------------------------------------------------
1 | import { useSelector } from 'react-redux';
2 | import { Navigate } from 'react-router-dom';
3 | import Layout from 'components/Layout';
4 |
5 | const DashboardPage = () => {
6 | const { isAuthenticated, user, loading } = useSelector(state => state.user);
7 |
8 | if (!isAuthenticated && !loading && user === null)
9 | return ;
10 |
11 | return (
12 |
13 | {loading || user === null ? (
14 |
15 | Loading...
16 |
17 | ) : (
18 | <>
19 | Dashboard
20 | User Details
21 |
22 | - First Name: {user.first_name}
23 | - Last Name: {user.last_name}
24 | - Email: {user.email}
25 |
26 | >
27 | )}
28 |
29 | );
30 | };
31 |
32 | export default DashboardPage;
33 |
--------------------------------------------------------------------------------
/frontend/client/src/containers/HomePage.js:
--------------------------------------------------------------------------------
1 | import Layout from 'components/Layout';
2 |
3 | const HomePage = () => {
4 | return (
5 |
6 | Auth Site
7 | Welcome to Auth Site!
8 |
9 | );
10 | };
11 |
12 | export default HomePage;
13 |
--------------------------------------------------------------------------------
/frontend/client/src/containers/LoginPage.js:
--------------------------------------------------------------------------------
1 | import { useState, useEffect } from 'react';
2 | import { useSelector, useDispatch } from 'react-redux';
3 | import { Navigate } from 'react-router-dom';
4 | import { resetRegistered, login } from 'features/user';
5 | import Layout from 'components/Layout';
6 |
7 | const LoginPage = () => {
8 | const dispatch = useDispatch();
9 | const { loading, isAuthenticated, registered } = useSelector(
10 | state => state.user
11 | );
12 |
13 | const [formData, setFormData] = useState({
14 | email: '',
15 | password: '',
16 | });
17 |
18 | useEffect(() => {
19 | if (registered) dispatch(resetRegistered());
20 | }, [registered]);
21 |
22 | const { email, password } = formData;
23 |
24 | const onChange = e => {
25 | setFormData({ ...formData, [e.target.name]: e.target.value });
26 | };
27 |
28 | const onSubmit = e => {
29 | e.preventDefault();
30 |
31 | dispatch(login({ email, password }));
32 | };
33 |
34 | if (isAuthenticated) return ;
35 |
36 | return (
37 |
38 | Log into your Account
39 |
74 |
75 | );
76 | };
77 |
78 | export default LoginPage;
79 |
--------------------------------------------------------------------------------
/frontend/client/src/containers/RegisterPage.js:
--------------------------------------------------------------------------------
1 | import { useState } from 'react';
2 | import Layout from 'components/Layout';
3 | import { Navigate } from 'react-router-dom';
4 | import { useSelector, useDispatch } from 'react-redux';
5 | import { register } from 'features/user';
6 |
7 | const RegisterPage = () => {
8 | const dispatch = useDispatch();
9 | const { registered, loading } = useSelector(state => state.user);
10 |
11 | const [formData, setFormData] = useState({
12 | first_name: '',
13 | last_name: '',
14 | email: '',
15 | password: '',
16 | });
17 |
18 | const { first_name, last_name, email, password } = formData;
19 |
20 | const onChange = e => {
21 | setFormData({ ...formData, [e.target.name]: e.target.value });
22 | };
23 |
24 | const onSubmit = e => {
25 | e.preventDefault();
26 |
27 | dispatch(register({ first_name, last_name, email, password }));
28 | };
29 |
30 | if (registered) return ;
31 |
32 | return (
33 |
34 | Register for an Account
35 |
96 |
97 | );
98 | };
99 |
100 | export default RegisterPage;
101 |
--------------------------------------------------------------------------------
/frontend/client/src/features/user.js:
--------------------------------------------------------------------------------
1 | import { createAsyncThunk, createSlice } from '@reduxjs/toolkit';
2 |
3 | export const register = createAsyncThunk(
4 | 'users/register',
5 | async ({ first_name, last_name, email, password }, thunkAPI) => {
6 | const body = JSON.stringify({
7 | first_name,
8 | last_name,
9 | email,
10 | password,
11 | });
12 |
13 | try {
14 | const res = await fetch('/api/users/register', {
15 | method: 'POST',
16 | headers: {
17 | Accept: 'application/json',
18 | 'Content-Type': 'application/json',
19 | },
20 | body,
21 | });
22 |
23 | const data = await res.json();
24 |
25 | if (res.status === 201) {
26 | return data;
27 | } else {
28 | return thunkAPI.rejectWithValue(data);
29 | }
30 | } catch (err) {
31 | return thunkAPI.rejectWithValue(err.response.data);
32 | }
33 | }
34 | );
35 |
36 | const getUser = createAsyncThunk('users/me', async (_, thunkAPI) => {
37 | try {
38 | const res = await fetch('/api/users/me', {
39 | method: 'GET',
40 | headers: {
41 | Accept: 'application/json',
42 | },
43 | });
44 |
45 | const data = await res.json();
46 |
47 | if (res.status === 200) {
48 | return data;
49 | } else {
50 | return thunkAPI.rejectWithValue(data);
51 | }
52 | } catch (err) {
53 | return thunkAPI.rejectWithValue(err.response.data);
54 | }
55 | });
56 |
57 | export const login = createAsyncThunk(
58 | 'users/login',
59 | async ({ email, password }, thunkAPI) => {
60 | const body = JSON.stringify({
61 | email,
62 | password,
63 | });
64 |
65 | try {
66 | const res = await fetch('/api/users/login', {
67 | method: 'POST',
68 | headers: {
69 | Accept: 'application/json',
70 | 'Content-Type': 'application/json',
71 | },
72 | body,
73 | });
74 |
75 | const data = await res.json();
76 |
77 | if (res.status === 200) {
78 | const { dispatch } = thunkAPI;
79 |
80 | dispatch(getUser());
81 |
82 | return data;
83 | } else {
84 | return thunkAPI.rejectWithValue(data);
85 | }
86 | } catch (err) {
87 | return thunkAPI.rejectWithValue(err.response.data);
88 | }
89 | }
90 | );
91 |
92 | export const checkAuth = createAsyncThunk(
93 | 'users/verify',
94 | async (_, thunkAPI) => {
95 | try {
96 | const res = await fetch('/api/users/verify', {
97 | method: 'GET',
98 | headers: {
99 | Accept: 'application/json',
100 | },
101 | });
102 |
103 | const data = await res.json();
104 |
105 | if (res.status === 200) {
106 | const { dispatch } = thunkAPI;
107 |
108 | dispatch(getUser());
109 |
110 | return data;
111 | } else {
112 | return thunkAPI.rejectWithValue(data);
113 | }
114 | } catch (err) {
115 | return thunkAPI.rejectWithValue(err.response.data);
116 | }
117 | }
118 | );
119 |
120 | export const logout = createAsyncThunk('users/logout', async (_, thunkAPI) => {
121 | try {
122 | const res = await fetch('/api/users/logout', {
123 | method: 'GET',
124 | headers: {
125 | Accept: 'application/json',
126 | },
127 | });
128 |
129 | const data = await res.json();
130 |
131 | if (res.status === 200) {
132 | return data;
133 | } else {
134 | return thunkAPI.rejectWithValue(data);
135 | }
136 | } catch (err) {
137 | return thunkAPI.rejectWithValue(err.response.data);
138 | }
139 | });
140 |
141 | const initialState = {
142 | isAuthenticated: false,
143 | user: null,
144 | loading: false,
145 | registered: false,
146 | };
147 |
148 | const userSlice = createSlice({
149 | name: 'user',
150 | initialState,
151 | reducers: {
152 | resetRegistered: state => {
153 | state.registered = false;
154 | },
155 | },
156 | extraReducers: builder => {
157 | builder
158 | .addCase(register.pending, state => {
159 | state.loading = true;
160 | })
161 | .addCase(register.fulfilled, state => {
162 | state.loading = false;
163 | state.registered = true;
164 | })
165 | .addCase(register.rejected, state => {
166 | state.loading = false;
167 | })
168 | .addCase(login.pending, state => {
169 | state.loading = true;
170 | })
171 | .addCase(login.fulfilled, state => {
172 | state.loading = false;
173 | state.isAuthenticated = true;
174 | })
175 | .addCase(login.rejected, state => {
176 | state.loading = false;
177 | })
178 | .addCase(getUser.pending, state => {
179 | state.loading = true;
180 | })
181 | .addCase(getUser.fulfilled, (state, action) => {
182 | state.loading = false;
183 | state.user = action.payload;
184 | })
185 | .addCase(getUser.rejected, state => {
186 | state.loading = false;
187 | })
188 | .addCase(checkAuth.pending, state => {
189 | state.loading = true;
190 | })
191 | .addCase(checkAuth.fulfilled, state => {
192 | state.loading = false;
193 | state.isAuthenticated = true;
194 | })
195 | .addCase(checkAuth.rejected, state => {
196 | state.loading = false;
197 | })
198 | .addCase(logout.pending, state => {
199 | state.loading = true;
200 | })
201 | .addCase(logout.fulfilled, state => {
202 | state.loading = false;
203 | state.isAuthenticated = false;
204 | state.user = null;
205 | })
206 | .addCase(logout.rejected, state => {
207 | state.loading = false;
208 | });
209 | },
210 | });
211 |
212 | export const { resetRegistered } = userSlice.actions;
213 | export default userSlice.reducer;
214 |
--------------------------------------------------------------------------------
/frontend/client/src/index.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import ReactDOM from 'react-dom/client';
3 | import { Provider } from 'react-redux';
4 | import App from './App';
5 | import reportWebVitals from './reportWebVitals';
6 |
7 | import { store } from 'store';
8 |
9 | const root = ReactDOM.createRoot(document.getElementById('root'));
10 | root.render(
11 |
12 |
13 |
14 |
15 |
16 | );
17 |
18 | // If you want to start measuring performance in your app, pass a function
19 | // to log results (for example: reportWebVitals(console.log))
20 | // or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals
21 | reportWebVitals();
22 |
--------------------------------------------------------------------------------
/frontend/client/src/reportWebVitals.js:
--------------------------------------------------------------------------------
1 | const reportWebVitals = onPerfEntry => {
2 | if (onPerfEntry && onPerfEntry instanceof Function) {
3 | import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {
4 | getCLS(onPerfEntry);
5 | getFID(onPerfEntry);
6 | getFCP(onPerfEntry);
7 | getLCP(onPerfEntry);
8 | getTTFB(onPerfEntry);
9 | });
10 | }
11 | };
12 |
13 | export default reportWebVitals;
14 |
--------------------------------------------------------------------------------
/frontend/client/src/setupProxy.js:
--------------------------------------------------------------------------------
1 | const { createProxyMiddleware } = require('http-proxy-middleware');
2 |
3 | module.exports = function (app) {
4 | app.use(
5 | '/api',
6 | createProxyMiddleware({
7 | target: 'http://localhost:5000',
8 | changeOrigin: true,
9 | })
10 | );
11 | };
12 |
--------------------------------------------------------------------------------
/frontend/client/src/setupTests.js:
--------------------------------------------------------------------------------
1 | // jest-dom adds custom jest matchers for asserting on DOM nodes.
2 | // allows you to do things like:
3 | // expect(element).toHaveTextContent(/react/i)
4 | // learn more: https://github.com/testing-library/jest-dom
5 | import '@testing-library/jest-dom';
6 |
--------------------------------------------------------------------------------
/frontend/client/src/store.js:
--------------------------------------------------------------------------------
1 | import { configureStore } from '@reduxjs/toolkit';
2 | import userReducer from 'features/user';
3 |
4 | export const store = configureStore({
5 | reducer: {
6 | user: userReducer,
7 | },
8 | devTools: process.env.NODE_ENV !== 'production',
9 | });
10 |
--------------------------------------------------------------------------------
/frontend/index.js:
--------------------------------------------------------------------------------
1 | const express = require('express');
2 | const cookieParser = require('cookie-parser');
3 | const path = require('path');
4 |
5 | require('dotenv').config();
6 |
7 | const loginRoute = require('./routes/auth/login');
8 | const logoutRoute = require('./routes/auth/logout');
9 | const meRoute = require('./routes/auth/me');
10 | const registerRoute = require('./routes/auth/register');
11 | const verifyRoute = require('./routes/auth/verify');
12 |
13 | const app = express();
14 |
15 | app.use(express.json());
16 | app.use(cookieParser());
17 |
18 | app.use(loginRoute);
19 | app.use(logoutRoute);
20 | app.use(meRoute);
21 | app.use(registerRoute);
22 | app.use(verifyRoute);
23 |
24 | app.use(express.static('client/build'));
25 | app.get('*', (req, res) => {
26 | return res.sendFile(path.resolve(__dirname, 'client', 'build', 'index.html'));
27 | });
28 |
29 | const PORT = process.env.PORT || 5000;
30 |
31 | app.listen(PORT, () => console.log(`Server listening on port ${PORT}`));
32 |
--------------------------------------------------------------------------------
/frontend/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "frontend",
3 | "version": "1.0.0",
4 | "lockfileVersion": 2,
5 | "requires": true,
6 | "packages": {
7 | "": {
8 | "name": "frontend",
9 | "version": "1.0.0",
10 | "license": "ISC",
11 | "dependencies": {
12 | "cookie-parser": "^1.4.6",
13 | "dotenv": "^16.0.1",
14 | "express": "^4.18.1",
15 | "node-fetch": "^3.2.6",
16 | "nodemon": "^2.0.16",
17 | "path": "^0.12.7"
18 | }
19 | },
20 | "node_modules/@sindresorhus/is": {
21 | "version": "0.14.0",
22 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz",
23 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==",
24 | "engines": {
25 | "node": ">=6"
26 | }
27 | },
28 | "node_modules/@szmarczak/http-timer": {
29 | "version": "1.1.2",
30 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz",
31 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==",
32 | "dependencies": {
33 | "defer-to-connect": "^1.0.1"
34 | },
35 | "engines": {
36 | "node": ">=6"
37 | }
38 | },
39 | "node_modules/abbrev": {
40 | "version": "1.1.1",
41 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz",
42 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q=="
43 | },
44 | "node_modules/accepts": {
45 | "version": "1.3.8",
46 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz",
47 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==",
48 | "dependencies": {
49 | "mime-types": "~2.1.34",
50 | "negotiator": "0.6.3"
51 | },
52 | "engines": {
53 | "node": ">= 0.6"
54 | }
55 | },
56 | "node_modules/ansi-align": {
57 | "version": "3.0.1",
58 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.1.tgz",
59 | "integrity": "sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w==",
60 | "dependencies": {
61 | "string-width": "^4.1.0"
62 | }
63 | },
64 | "node_modules/ansi-regex": {
65 | "version": "5.0.1",
66 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
67 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
68 | "engines": {
69 | "node": ">=8"
70 | }
71 | },
72 | "node_modules/ansi-styles": {
73 | "version": "4.3.0",
74 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
75 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
76 | "dependencies": {
77 | "color-convert": "^2.0.1"
78 | },
79 | "engines": {
80 | "node": ">=8"
81 | },
82 | "funding": {
83 | "url": "https://github.com/chalk/ansi-styles?sponsor=1"
84 | }
85 | },
86 | "node_modules/anymatch": {
87 | "version": "3.1.2",
88 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz",
89 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==",
90 | "dependencies": {
91 | "normalize-path": "^3.0.0",
92 | "picomatch": "^2.0.4"
93 | },
94 | "engines": {
95 | "node": ">= 8"
96 | }
97 | },
98 | "node_modules/array-flatten": {
99 | "version": "1.1.1",
100 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
101 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg=="
102 | },
103 | "node_modules/balanced-match": {
104 | "version": "1.0.2",
105 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
106 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw=="
107 | },
108 | "node_modules/binary-extensions": {
109 | "version": "2.2.0",
110 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
111 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
112 | "engines": {
113 | "node": ">=8"
114 | }
115 | },
116 | "node_modules/body-parser": {
117 | "version": "1.20.0",
118 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.0.tgz",
119 | "integrity": "sha512-DfJ+q6EPcGKZD1QWUjSpqp+Q7bDQTsQIF4zfUAtZ6qk+H/3/QRhg9CEp39ss+/T2vw0+HaidC0ecJj/DRLIaKg==",
120 | "dependencies": {
121 | "bytes": "3.1.2",
122 | "content-type": "~1.0.4",
123 | "debug": "2.6.9",
124 | "depd": "2.0.0",
125 | "destroy": "1.2.0",
126 | "http-errors": "2.0.0",
127 | "iconv-lite": "0.4.24",
128 | "on-finished": "2.4.1",
129 | "qs": "6.10.3",
130 | "raw-body": "2.5.1",
131 | "type-is": "~1.6.18",
132 | "unpipe": "1.0.0"
133 | },
134 | "engines": {
135 | "node": ">= 0.8",
136 | "npm": "1.2.8000 || >= 1.4.16"
137 | }
138 | },
139 | "node_modules/boxen": {
140 | "version": "5.1.2",
141 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-5.1.2.tgz",
142 | "integrity": "sha512-9gYgQKXx+1nP8mP7CzFyaUARhg7D3n1dF/FnErWmu9l6JvGpNUN278h0aSb+QjoiKSWG+iZ3uHrcqk0qrY9RQQ==",
143 | "dependencies": {
144 | "ansi-align": "^3.0.0",
145 | "camelcase": "^6.2.0",
146 | "chalk": "^4.1.0",
147 | "cli-boxes": "^2.2.1",
148 | "string-width": "^4.2.2",
149 | "type-fest": "^0.20.2",
150 | "widest-line": "^3.1.0",
151 | "wrap-ansi": "^7.0.0"
152 | },
153 | "engines": {
154 | "node": ">=10"
155 | },
156 | "funding": {
157 | "url": "https://github.com/sponsors/sindresorhus"
158 | }
159 | },
160 | "node_modules/brace-expansion": {
161 | "version": "1.1.11",
162 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
163 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
164 | "dependencies": {
165 | "balanced-match": "^1.0.0",
166 | "concat-map": "0.0.1"
167 | }
168 | },
169 | "node_modules/braces": {
170 | "version": "3.0.2",
171 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
172 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
173 | "dependencies": {
174 | "fill-range": "^7.0.1"
175 | },
176 | "engines": {
177 | "node": ">=8"
178 | }
179 | },
180 | "node_modules/bytes": {
181 | "version": "3.1.2",
182 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz",
183 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==",
184 | "engines": {
185 | "node": ">= 0.8"
186 | }
187 | },
188 | "node_modules/cacheable-request": {
189 | "version": "6.1.0",
190 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz",
191 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==",
192 | "dependencies": {
193 | "clone-response": "^1.0.2",
194 | "get-stream": "^5.1.0",
195 | "http-cache-semantics": "^4.0.0",
196 | "keyv": "^3.0.0",
197 | "lowercase-keys": "^2.0.0",
198 | "normalize-url": "^4.1.0",
199 | "responselike": "^1.0.2"
200 | },
201 | "engines": {
202 | "node": ">=8"
203 | }
204 | },
205 | "node_modules/cacheable-request/node_modules/get-stream": {
206 | "version": "5.2.0",
207 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz",
208 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==",
209 | "dependencies": {
210 | "pump": "^3.0.0"
211 | },
212 | "engines": {
213 | "node": ">=8"
214 | },
215 | "funding": {
216 | "url": "https://github.com/sponsors/sindresorhus"
217 | }
218 | },
219 | "node_modules/cacheable-request/node_modules/lowercase-keys": {
220 | "version": "2.0.0",
221 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz",
222 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==",
223 | "engines": {
224 | "node": ">=8"
225 | }
226 | },
227 | "node_modules/call-bind": {
228 | "version": "1.0.2",
229 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz",
230 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==",
231 | "dependencies": {
232 | "function-bind": "^1.1.1",
233 | "get-intrinsic": "^1.0.2"
234 | },
235 | "funding": {
236 | "url": "https://github.com/sponsors/ljharb"
237 | }
238 | },
239 | "node_modules/camelcase": {
240 | "version": "6.3.0",
241 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz",
242 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==",
243 | "engines": {
244 | "node": ">=10"
245 | },
246 | "funding": {
247 | "url": "https://github.com/sponsors/sindresorhus"
248 | }
249 | },
250 | "node_modules/chalk": {
251 | "version": "4.1.2",
252 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
253 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
254 | "dependencies": {
255 | "ansi-styles": "^4.1.0",
256 | "supports-color": "^7.1.0"
257 | },
258 | "engines": {
259 | "node": ">=10"
260 | },
261 | "funding": {
262 | "url": "https://github.com/chalk/chalk?sponsor=1"
263 | }
264 | },
265 | "node_modules/chalk/node_modules/has-flag": {
266 | "version": "4.0.0",
267 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
268 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
269 | "engines": {
270 | "node": ">=8"
271 | }
272 | },
273 | "node_modules/chalk/node_modules/supports-color": {
274 | "version": "7.2.0",
275 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
276 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
277 | "dependencies": {
278 | "has-flag": "^4.0.0"
279 | },
280 | "engines": {
281 | "node": ">=8"
282 | }
283 | },
284 | "node_modules/chokidar": {
285 | "version": "3.5.3",
286 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz",
287 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==",
288 | "funding": [
289 | {
290 | "type": "individual",
291 | "url": "https://paulmillr.com/funding/"
292 | }
293 | ],
294 | "dependencies": {
295 | "anymatch": "~3.1.2",
296 | "braces": "~3.0.2",
297 | "glob-parent": "~5.1.2",
298 | "is-binary-path": "~2.1.0",
299 | "is-glob": "~4.0.1",
300 | "normalize-path": "~3.0.0",
301 | "readdirp": "~3.6.0"
302 | },
303 | "engines": {
304 | "node": ">= 8.10.0"
305 | },
306 | "optionalDependencies": {
307 | "fsevents": "~2.3.2"
308 | }
309 | },
310 | "node_modules/ci-info": {
311 | "version": "2.0.0",
312 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz",
313 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ=="
314 | },
315 | "node_modules/cli-boxes": {
316 | "version": "2.2.1",
317 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz",
318 | "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==",
319 | "engines": {
320 | "node": ">=6"
321 | },
322 | "funding": {
323 | "url": "https://github.com/sponsors/sindresorhus"
324 | }
325 | },
326 | "node_modules/clone-response": {
327 | "version": "1.0.2",
328 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz",
329 | "integrity": "sha512-yjLXh88P599UOyPTFX0POsd7WxnbsVsGohcwzHOLspIhhpalPw1BcqED8NblyZLKcGrL8dTgMlcaZxV2jAD41Q==",
330 | "dependencies": {
331 | "mimic-response": "^1.0.0"
332 | }
333 | },
334 | "node_modules/color-convert": {
335 | "version": "2.0.1",
336 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
337 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
338 | "dependencies": {
339 | "color-name": "~1.1.4"
340 | },
341 | "engines": {
342 | "node": ">=7.0.0"
343 | }
344 | },
345 | "node_modules/color-name": {
346 | "version": "1.1.4",
347 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
348 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA=="
349 | },
350 | "node_modules/concat-map": {
351 | "version": "0.0.1",
352 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
353 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg=="
354 | },
355 | "node_modules/configstore": {
356 | "version": "5.0.1",
357 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz",
358 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==",
359 | "dependencies": {
360 | "dot-prop": "^5.2.0",
361 | "graceful-fs": "^4.1.2",
362 | "make-dir": "^3.0.0",
363 | "unique-string": "^2.0.0",
364 | "write-file-atomic": "^3.0.0",
365 | "xdg-basedir": "^4.0.0"
366 | },
367 | "engines": {
368 | "node": ">=8"
369 | }
370 | },
371 | "node_modules/content-disposition": {
372 | "version": "0.5.4",
373 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz",
374 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==",
375 | "dependencies": {
376 | "safe-buffer": "5.2.1"
377 | },
378 | "engines": {
379 | "node": ">= 0.6"
380 | }
381 | },
382 | "node_modules/content-type": {
383 | "version": "1.0.4",
384 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz",
385 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==",
386 | "engines": {
387 | "node": ">= 0.6"
388 | }
389 | },
390 | "node_modules/cookie": {
391 | "version": "0.5.0",
392 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz",
393 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==",
394 | "engines": {
395 | "node": ">= 0.6"
396 | }
397 | },
398 | "node_modules/cookie-parser": {
399 | "version": "1.4.6",
400 | "resolved": "https://registry.npmjs.org/cookie-parser/-/cookie-parser-1.4.6.tgz",
401 | "integrity": "sha512-z3IzaNjdwUC2olLIB5/ITd0/setiaFMLYiZJle7xg5Fe9KWAceil7xszYfHHBtDFYLSgJduS2Ty0P1uJdPDJeA==",
402 | "dependencies": {
403 | "cookie": "0.4.1",
404 | "cookie-signature": "1.0.6"
405 | },
406 | "engines": {
407 | "node": ">= 0.8.0"
408 | }
409 | },
410 | "node_modules/cookie-parser/node_modules/cookie": {
411 | "version": "0.4.1",
412 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz",
413 | "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA==",
414 | "engines": {
415 | "node": ">= 0.6"
416 | }
417 | },
418 | "node_modules/cookie-signature": {
419 | "version": "1.0.6",
420 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
421 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ=="
422 | },
423 | "node_modules/crypto-random-string": {
424 | "version": "2.0.0",
425 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz",
426 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==",
427 | "engines": {
428 | "node": ">=8"
429 | }
430 | },
431 | "node_modules/data-uri-to-buffer": {
432 | "version": "4.0.0",
433 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-4.0.0.tgz",
434 | "integrity": "sha512-Vr3mLBA8qWmcuschSLAOogKgQ/Jwxulv3RNE4FXnYWRGujzrRWQI4m12fQqRkwX06C0KanhLr4hK+GydchZsaA==",
435 | "engines": {
436 | "node": ">= 12"
437 | }
438 | },
439 | "node_modules/debug": {
440 | "version": "2.6.9",
441 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
442 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
443 | "dependencies": {
444 | "ms": "2.0.0"
445 | }
446 | },
447 | "node_modules/decompress-response": {
448 | "version": "3.3.0",
449 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz",
450 | "integrity": "sha512-BzRPQuY1ip+qDonAOz42gRm/pg9F768C+npV/4JOsxRC2sq+Rlk+Q4ZCAsOhnIaMrgarILY+RMUIvMmmX1qAEA==",
451 | "dependencies": {
452 | "mimic-response": "^1.0.0"
453 | },
454 | "engines": {
455 | "node": ">=4"
456 | }
457 | },
458 | "node_modules/deep-extend": {
459 | "version": "0.6.0",
460 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz",
461 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==",
462 | "engines": {
463 | "node": ">=4.0.0"
464 | }
465 | },
466 | "node_modules/defer-to-connect": {
467 | "version": "1.1.3",
468 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz",
469 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ=="
470 | },
471 | "node_modules/depd": {
472 | "version": "2.0.0",
473 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz",
474 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==",
475 | "engines": {
476 | "node": ">= 0.8"
477 | }
478 | },
479 | "node_modules/destroy": {
480 | "version": "1.2.0",
481 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz",
482 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==",
483 | "engines": {
484 | "node": ">= 0.8",
485 | "npm": "1.2.8000 || >= 1.4.16"
486 | }
487 | },
488 | "node_modules/dot-prop": {
489 | "version": "5.3.0",
490 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz",
491 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==",
492 | "dependencies": {
493 | "is-obj": "^2.0.0"
494 | },
495 | "engines": {
496 | "node": ">=8"
497 | }
498 | },
499 | "node_modules/dotenv": {
500 | "version": "16.0.1",
501 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.1.tgz",
502 | "integrity": "sha512-1K6hR6wtk2FviQ4kEiSjFiH5rpzEVi8WW0x96aztHVMhEspNpc4DVOUTEHtEva5VThQ8IaBX1Pe4gSzpVVUsKQ==",
503 | "engines": {
504 | "node": ">=12"
505 | }
506 | },
507 | "node_modules/duplexer3": {
508 | "version": "0.1.4",
509 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz",
510 | "integrity": "sha512-CEj8FwwNA4cVH2uFCoHUrmojhYh1vmCdOaneKJXwkeY1i9jnlslVo9dx+hQ5Hl9GnH/Bwy/IjxAyOePyPKYnzA=="
511 | },
512 | "node_modules/ee-first": {
513 | "version": "1.1.1",
514 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
515 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow=="
516 | },
517 | "node_modules/emoji-regex": {
518 | "version": "8.0.0",
519 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
520 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A=="
521 | },
522 | "node_modules/encodeurl": {
523 | "version": "1.0.2",
524 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
525 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==",
526 | "engines": {
527 | "node": ">= 0.8"
528 | }
529 | },
530 | "node_modules/end-of-stream": {
531 | "version": "1.4.4",
532 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz",
533 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==",
534 | "dependencies": {
535 | "once": "^1.4.0"
536 | }
537 | },
538 | "node_modules/escape-goat": {
539 | "version": "2.1.1",
540 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz",
541 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==",
542 | "engines": {
543 | "node": ">=8"
544 | }
545 | },
546 | "node_modules/escape-html": {
547 | "version": "1.0.3",
548 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
549 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow=="
550 | },
551 | "node_modules/etag": {
552 | "version": "1.8.1",
553 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
554 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==",
555 | "engines": {
556 | "node": ">= 0.6"
557 | }
558 | },
559 | "node_modules/express": {
560 | "version": "4.18.1",
561 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.1.tgz",
562 | "integrity": "sha512-zZBcOX9TfehHQhtupq57OF8lFZ3UZi08Y97dwFCkD8p9d/d2Y3M+ykKcwaMDEL+4qyUolgBDX6AblpR3fL212Q==",
563 | "dependencies": {
564 | "accepts": "~1.3.8",
565 | "array-flatten": "1.1.1",
566 | "body-parser": "1.20.0",
567 | "content-disposition": "0.5.4",
568 | "content-type": "~1.0.4",
569 | "cookie": "0.5.0",
570 | "cookie-signature": "1.0.6",
571 | "debug": "2.6.9",
572 | "depd": "2.0.0",
573 | "encodeurl": "~1.0.2",
574 | "escape-html": "~1.0.3",
575 | "etag": "~1.8.1",
576 | "finalhandler": "1.2.0",
577 | "fresh": "0.5.2",
578 | "http-errors": "2.0.0",
579 | "merge-descriptors": "1.0.1",
580 | "methods": "~1.1.2",
581 | "on-finished": "2.4.1",
582 | "parseurl": "~1.3.3",
583 | "path-to-regexp": "0.1.7",
584 | "proxy-addr": "~2.0.7",
585 | "qs": "6.10.3",
586 | "range-parser": "~1.2.1",
587 | "safe-buffer": "5.2.1",
588 | "send": "0.18.0",
589 | "serve-static": "1.15.0",
590 | "setprototypeof": "1.2.0",
591 | "statuses": "2.0.1",
592 | "type-is": "~1.6.18",
593 | "utils-merge": "1.0.1",
594 | "vary": "~1.1.2"
595 | },
596 | "engines": {
597 | "node": ">= 0.10.0"
598 | }
599 | },
600 | "node_modules/fetch-blob": {
601 | "version": "3.1.5",
602 | "resolved": "https://registry.npmjs.org/fetch-blob/-/fetch-blob-3.1.5.tgz",
603 | "integrity": "sha512-N64ZpKqoLejlrwkIAnb9iLSA3Vx/kjgzpcDhygcqJ2KKjky8nCgUQ+dzXtbrLaWZGZNmNfQTsiQ0weZ1svglHg==",
604 | "funding": [
605 | {
606 | "type": "github",
607 | "url": "https://github.com/sponsors/jimmywarting"
608 | },
609 | {
610 | "type": "paypal",
611 | "url": "https://paypal.me/jimmywarting"
612 | }
613 | ],
614 | "dependencies": {
615 | "node-domexception": "^1.0.0",
616 | "web-streams-polyfill": "^3.0.3"
617 | },
618 | "engines": {
619 | "node": "^12.20 || >= 14.13"
620 | }
621 | },
622 | "node_modules/fill-range": {
623 | "version": "7.0.1",
624 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
625 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
626 | "dependencies": {
627 | "to-regex-range": "^5.0.1"
628 | },
629 | "engines": {
630 | "node": ">=8"
631 | }
632 | },
633 | "node_modules/finalhandler": {
634 | "version": "1.2.0",
635 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz",
636 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==",
637 | "dependencies": {
638 | "debug": "2.6.9",
639 | "encodeurl": "~1.0.2",
640 | "escape-html": "~1.0.3",
641 | "on-finished": "2.4.1",
642 | "parseurl": "~1.3.3",
643 | "statuses": "2.0.1",
644 | "unpipe": "~1.0.0"
645 | },
646 | "engines": {
647 | "node": ">= 0.8"
648 | }
649 | },
650 | "node_modules/formdata-polyfill": {
651 | "version": "4.0.10",
652 | "resolved": "https://registry.npmjs.org/formdata-polyfill/-/formdata-polyfill-4.0.10.tgz",
653 | "integrity": "sha512-buewHzMvYL29jdeQTVILecSaZKnt/RJWjoZCF5OW60Z67/GmSLBkOFM7qh1PI3zFNtJbaZL5eQu1vLfazOwj4g==",
654 | "dependencies": {
655 | "fetch-blob": "^3.1.2"
656 | },
657 | "engines": {
658 | "node": ">=12.20.0"
659 | }
660 | },
661 | "node_modules/forwarded": {
662 | "version": "0.2.0",
663 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz",
664 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==",
665 | "engines": {
666 | "node": ">= 0.6"
667 | }
668 | },
669 | "node_modules/fresh": {
670 | "version": "0.5.2",
671 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
672 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==",
673 | "engines": {
674 | "node": ">= 0.6"
675 | }
676 | },
677 | "node_modules/fsevents": {
678 | "version": "2.3.2",
679 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
680 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
681 | "hasInstallScript": true,
682 | "optional": true,
683 | "os": [
684 | "darwin"
685 | ],
686 | "engines": {
687 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
688 | }
689 | },
690 | "node_modules/function-bind": {
691 | "version": "1.1.1",
692 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
693 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A=="
694 | },
695 | "node_modules/get-intrinsic": {
696 | "version": "1.1.2",
697 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.2.tgz",
698 | "integrity": "sha512-Jfm3OyCxHh9DJyc28qGk+JmfkpO41A4XkneDSujN9MDXrm4oDKdHvndhZ2dN94+ERNfkYJWDclW6k2L/ZGHjXA==",
699 | "dependencies": {
700 | "function-bind": "^1.1.1",
701 | "has": "^1.0.3",
702 | "has-symbols": "^1.0.3"
703 | },
704 | "funding": {
705 | "url": "https://github.com/sponsors/ljharb"
706 | }
707 | },
708 | "node_modules/get-stream": {
709 | "version": "4.1.0",
710 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz",
711 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==",
712 | "dependencies": {
713 | "pump": "^3.0.0"
714 | },
715 | "engines": {
716 | "node": ">=6"
717 | }
718 | },
719 | "node_modules/glob-parent": {
720 | "version": "5.1.2",
721 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
722 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
723 | "dependencies": {
724 | "is-glob": "^4.0.1"
725 | },
726 | "engines": {
727 | "node": ">= 6"
728 | }
729 | },
730 | "node_modules/global-dirs": {
731 | "version": "3.0.0",
732 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-3.0.0.tgz",
733 | "integrity": "sha512-v8ho2DS5RiCjftj1nD9NmnfaOzTdud7RRnVd9kFNOjqZbISlx5DQ+OrTkywgd0dIt7oFCvKetZSHoHcP3sDdiA==",
734 | "dependencies": {
735 | "ini": "2.0.0"
736 | },
737 | "engines": {
738 | "node": ">=10"
739 | },
740 | "funding": {
741 | "url": "https://github.com/sponsors/sindresorhus"
742 | }
743 | },
744 | "node_modules/got": {
745 | "version": "9.6.0",
746 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz",
747 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==",
748 | "dependencies": {
749 | "@sindresorhus/is": "^0.14.0",
750 | "@szmarczak/http-timer": "^1.1.2",
751 | "cacheable-request": "^6.0.0",
752 | "decompress-response": "^3.3.0",
753 | "duplexer3": "^0.1.4",
754 | "get-stream": "^4.1.0",
755 | "lowercase-keys": "^1.0.1",
756 | "mimic-response": "^1.0.1",
757 | "p-cancelable": "^1.0.0",
758 | "to-readable-stream": "^1.0.0",
759 | "url-parse-lax": "^3.0.0"
760 | },
761 | "engines": {
762 | "node": ">=8.6"
763 | }
764 | },
765 | "node_modules/graceful-fs": {
766 | "version": "4.2.10",
767 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz",
768 | "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA=="
769 | },
770 | "node_modules/has": {
771 | "version": "1.0.3",
772 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
773 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
774 | "dependencies": {
775 | "function-bind": "^1.1.1"
776 | },
777 | "engines": {
778 | "node": ">= 0.4.0"
779 | }
780 | },
781 | "node_modules/has-flag": {
782 | "version": "3.0.0",
783 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
784 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==",
785 | "engines": {
786 | "node": ">=4"
787 | }
788 | },
789 | "node_modules/has-symbols": {
790 | "version": "1.0.3",
791 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz",
792 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==",
793 | "engines": {
794 | "node": ">= 0.4"
795 | },
796 | "funding": {
797 | "url": "https://github.com/sponsors/ljharb"
798 | }
799 | },
800 | "node_modules/has-yarn": {
801 | "version": "2.1.0",
802 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz",
803 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==",
804 | "engines": {
805 | "node": ">=8"
806 | }
807 | },
808 | "node_modules/http-cache-semantics": {
809 | "version": "4.1.0",
810 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz",
811 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ=="
812 | },
813 | "node_modules/http-errors": {
814 | "version": "2.0.0",
815 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz",
816 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==",
817 | "dependencies": {
818 | "depd": "2.0.0",
819 | "inherits": "2.0.4",
820 | "setprototypeof": "1.2.0",
821 | "statuses": "2.0.1",
822 | "toidentifier": "1.0.1"
823 | },
824 | "engines": {
825 | "node": ">= 0.8"
826 | }
827 | },
828 | "node_modules/iconv-lite": {
829 | "version": "0.4.24",
830 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
831 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
832 | "dependencies": {
833 | "safer-buffer": ">= 2.1.2 < 3"
834 | },
835 | "engines": {
836 | "node": ">=0.10.0"
837 | }
838 | },
839 | "node_modules/ignore-by-default": {
840 | "version": "1.0.1",
841 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz",
842 | "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA=="
843 | },
844 | "node_modules/import-lazy": {
845 | "version": "2.1.0",
846 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz",
847 | "integrity": "sha512-m7ZEHgtw69qOGw+jwxXkHlrlIPdTGkyh66zXZ1ajZbxkDBNjSY/LGbmjc7h0s2ELsUDTAhFr55TrPSSqJGPG0A==",
848 | "engines": {
849 | "node": ">=4"
850 | }
851 | },
852 | "node_modules/imurmurhash": {
853 | "version": "0.1.4",
854 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
855 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==",
856 | "engines": {
857 | "node": ">=0.8.19"
858 | }
859 | },
860 | "node_modules/inherits": {
861 | "version": "2.0.4",
862 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
863 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
864 | },
865 | "node_modules/ini": {
866 | "version": "2.0.0",
867 | "resolved": "https://registry.npmjs.org/ini/-/ini-2.0.0.tgz",
868 | "integrity": "sha512-7PnF4oN3CvZF23ADhA5wRaYEQpJ8qygSkbtTXWBeXWXmEVRXK+1ITciHWwHhsjv1TmW0MgacIv6hEi5pX5NQdA==",
869 | "engines": {
870 | "node": ">=10"
871 | }
872 | },
873 | "node_modules/ipaddr.js": {
874 | "version": "1.9.1",
875 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz",
876 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==",
877 | "engines": {
878 | "node": ">= 0.10"
879 | }
880 | },
881 | "node_modules/is-binary-path": {
882 | "version": "2.1.0",
883 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
884 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
885 | "dependencies": {
886 | "binary-extensions": "^2.0.0"
887 | },
888 | "engines": {
889 | "node": ">=8"
890 | }
891 | },
892 | "node_modules/is-ci": {
893 | "version": "2.0.0",
894 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz",
895 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==",
896 | "dependencies": {
897 | "ci-info": "^2.0.0"
898 | },
899 | "bin": {
900 | "is-ci": "bin.js"
901 | }
902 | },
903 | "node_modules/is-extglob": {
904 | "version": "2.1.1",
905 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
906 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
907 | "engines": {
908 | "node": ">=0.10.0"
909 | }
910 | },
911 | "node_modules/is-fullwidth-code-point": {
912 | "version": "3.0.0",
913 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
914 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
915 | "engines": {
916 | "node": ">=8"
917 | }
918 | },
919 | "node_modules/is-glob": {
920 | "version": "4.0.3",
921 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
922 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
923 | "dependencies": {
924 | "is-extglob": "^2.1.1"
925 | },
926 | "engines": {
927 | "node": ">=0.10.0"
928 | }
929 | },
930 | "node_modules/is-installed-globally": {
931 | "version": "0.4.0",
932 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.4.0.tgz",
933 | "integrity": "sha512-iwGqO3J21aaSkC7jWnHP/difazwS7SFeIqxv6wEtLU8Y5KlzFTjyqcSIT0d8s4+dDhKytsk9PJZ2BkS5eZwQRQ==",
934 | "dependencies": {
935 | "global-dirs": "^3.0.0",
936 | "is-path-inside": "^3.0.2"
937 | },
938 | "engines": {
939 | "node": ">=10"
940 | },
941 | "funding": {
942 | "url": "https://github.com/sponsors/sindresorhus"
943 | }
944 | },
945 | "node_modules/is-npm": {
946 | "version": "5.0.0",
947 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-5.0.0.tgz",
948 | "integrity": "sha512-WW/rQLOazUq+ST/bCAVBp/2oMERWLsR7OrKyt052dNDk4DHcDE0/7QSXITlmi+VBcV13DfIbysG3tZJm5RfdBA==",
949 | "engines": {
950 | "node": ">=10"
951 | },
952 | "funding": {
953 | "url": "https://github.com/sponsors/sindresorhus"
954 | }
955 | },
956 | "node_modules/is-number": {
957 | "version": "7.0.0",
958 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
959 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
960 | "engines": {
961 | "node": ">=0.12.0"
962 | }
963 | },
964 | "node_modules/is-obj": {
965 | "version": "2.0.0",
966 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz",
967 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==",
968 | "engines": {
969 | "node": ">=8"
970 | }
971 | },
972 | "node_modules/is-path-inside": {
973 | "version": "3.0.3",
974 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz",
975 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==",
976 | "engines": {
977 | "node": ">=8"
978 | }
979 | },
980 | "node_modules/is-typedarray": {
981 | "version": "1.0.0",
982 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz",
983 | "integrity": "sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA=="
984 | },
985 | "node_modules/is-yarn-global": {
986 | "version": "0.3.0",
987 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz",
988 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw=="
989 | },
990 | "node_modules/json-buffer": {
991 | "version": "3.0.0",
992 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz",
993 | "integrity": "sha512-CuUqjv0FUZIdXkHPI8MezCnFCdaTAacej1TZYulLoAg1h/PhwkdXFN4V/gzY4g+fMBCOV2xF+rp7t2XD2ns/NQ=="
994 | },
995 | "node_modules/keyv": {
996 | "version": "3.1.0",
997 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz",
998 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==",
999 | "dependencies": {
1000 | "json-buffer": "3.0.0"
1001 | }
1002 | },
1003 | "node_modules/latest-version": {
1004 | "version": "5.1.0",
1005 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz",
1006 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==",
1007 | "dependencies": {
1008 | "package-json": "^6.3.0"
1009 | },
1010 | "engines": {
1011 | "node": ">=8"
1012 | }
1013 | },
1014 | "node_modules/lowercase-keys": {
1015 | "version": "1.0.1",
1016 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz",
1017 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==",
1018 | "engines": {
1019 | "node": ">=0.10.0"
1020 | }
1021 | },
1022 | "node_modules/lru-cache": {
1023 | "version": "6.0.0",
1024 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
1025 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
1026 | "dependencies": {
1027 | "yallist": "^4.0.0"
1028 | },
1029 | "engines": {
1030 | "node": ">=10"
1031 | }
1032 | },
1033 | "node_modules/make-dir": {
1034 | "version": "3.1.0",
1035 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz",
1036 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==",
1037 | "dependencies": {
1038 | "semver": "^6.0.0"
1039 | },
1040 | "engines": {
1041 | "node": ">=8"
1042 | },
1043 | "funding": {
1044 | "url": "https://github.com/sponsors/sindresorhus"
1045 | }
1046 | },
1047 | "node_modules/make-dir/node_modules/semver": {
1048 | "version": "6.3.0",
1049 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
1050 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
1051 | "bin": {
1052 | "semver": "bin/semver.js"
1053 | }
1054 | },
1055 | "node_modules/media-typer": {
1056 | "version": "0.3.0",
1057 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
1058 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==",
1059 | "engines": {
1060 | "node": ">= 0.6"
1061 | }
1062 | },
1063 | "node_modules/merge-descriptors": {
1064 | "version": "1.0.1",
1065 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
1066 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w=="
1067 | },
1068 | "node_modules/methods": {
1069 | "version": "1.1.2",
1070 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
1071 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==",
1072 | "engines": {
1073 | "node": ">= 0.6"
1074 | }
1075 | },
1076 | "node_modules/mime": {
1077 | "version": "1.6.0",
1078 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
1079 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
1080 | "bin": {
1081 | "mime": "cli.js"
1082 | },
1083 | "engines": {
1084 | "node": ">=4"
1085 | }
1086 | },
1087 | "node_modules/mime-db": {
1088 | "version": "1.52.0",
1089 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
1090 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
1091 | "engines": {
1092 | "node": ">= 0.6"
1093 | }
1094 | },
1095 | "node_modules/mime-types": {
1096 | "version": "2.1.35",
1097 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
1098 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
1099 | "dependencies": {
1100 | "mime-db": "1.52.0"
1101 | },
1102 | "engines": {
1103 | "node": ">= 0.6"
1104 | }
1105 | },
1106 | "node_modules/mimic-response": {
1107 | "version": "1.0.1",
1108 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz",
1109 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==",
1110 | "engines": {
1111 | "node": ">=4"
1112 | }
1113 | },
1114 | "node_modules/minimatch": {
1115 | "version": "3.1.2",
1116 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
1117 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
1118 | "dependencies": {
1119 | "brace-expansion": "^1.1.7"
1120 | },
1121 | "engines": {
1122 | "node": "*"
1123 | }
1124 | },
1125 | "node_modules/minimist": {
1126 | "version": "1.2.6",
1127 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz",
1128 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q=="
1129 | },
1130 | "node_modules/ms": {
1131 | "version": "2.0.0",
1132 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
1133 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
1134 | },
1135 | "node_modules/negotiator": {
1136 | "version": "0.6.3",
1137 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz",
1138 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==",
1139 | "engines": {
1140 | "node": ">= 0.6"
1141 | }
1142 | },
1143 | "node_modules/node-domexception": {
1144 | "version": "1.0.0",
1145 | "resolved": "https://registry.npmjs.org/node-domexception/-/node-domexception-1.0.0.tgz",
1146 | "integrity": "sha512-/jKZoMpw0F8GRwl4/eLROPA3cfcXtLApP0QzLmUT/HuPCZWyB7IY9ZrMeKw2O/nFIqPQB3PVM9aYm0F312AXDQ==",
1147 | "funding": [
1148 | {
1149 | "type": "github",
1150 | "url": "https://github.com/sponsors/jimmywarting"
1151 | },
1152 | {
1153 | "type": "github",
1154 | "url": "https://paypal.me/jimmywarting"
1155 | }
1156 | ],
1157 | "engines": {
1158 | "node": ">=10.5.0"
1159 | }
1160 | },
1161 | "node_modules/node-fetch": {
1162 | "version": "3.2.6",
1163 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-3.2.6.tgz",
1164 | "integrity": "sha512-LAy/HZnLADOVkVPubaxHDft29booGglPFDr2Hw0J1AercRh01UiVFm++KMDnJeH9sHgNB4hsXPii7Sgym/sTbw==",
1165 | "dependencies": {
1166 | "data-uri-to-buffer": "^4.0.0",
1167 | "fetch-blob": "^3.1.4",
1168 | "formdata-polyfill": "^4.0.10"
1169 | },
1170 | "engines": {
1171 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
1172 | },
1173 | "funding": {
1174 | "type": "opencollective",
1175 | "url": "https://opencollective.com/node-fetch"
1176 | }
1177 | },
1178 | "node_modules/nodemon": {
1179 | "version": "2.0.16",
1180 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.16.tgz",
1181 | "integrity": "sha512-zsrcaOfTWRuUzBn3P44RDliLlp263Z/76FPoHFr3cFFkOz0lTPAcIw8dCzfdVIx/t3AtDYCZRCDkoCojJqaG3w==",
1182 | "hasInstallScript": true,
1183 | "dependencies": {
1184 | "chokidar": "^3.5.2",
1185 | "debug": "^3.2.7",
1186 | "ignore-by-default": "^1.0.1",
1187 | "minimatch": "^3.0.4",
1188 | "pstree.remy": "^1.1.8",
1189 | "semver": "^5.7.1",
1190 | "supports-color": "^5.5.0",
1191 | "touch": "^3.1.0",
1192 | "undefsafe": "^2.0.5",
1193 | "update-notifier": "^5.1.0"
1194 | },
1195 | "bin": {
1196 | "nodemon": "bin/nodemon.js"
1197 | },
1198 | "engines": {
1199 | "node": ">=8.10.0"
1200 | },
1201 | "funding": {
1202 | "type": "opencollective",
1203 | "url": "https://opencollective.com/nodemon"
1204 | }
1205 | },
1206 | "node_modules/nodemon/node_modules/debug": {
1207 | "version": "3.2.7",
1208 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz",
1209 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==",
1210 | "dependencies": {
1211 | "ms": "^2.1.1"
1212 | }
1213 | },
1214 | "node_modules/nodemon/node_modules/ms": {
1215 | "version": "2.1.3",
1216 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
1217 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
1218 | },
1219 | "node_modules/nopt": {
1220 | "version": "1.0.10",
1221 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz",
1222 | "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==",
1223 | "dependencies": {
1224 | "abbrev": "1"
1225 | },
1226 | "bin": {
1227 | "nopt": "bin/nopt.js"
1228 | },
1229 | "engines": {
1230 | "node": "*"
1231 | }
1232 | },
1233 | "node_modules/normalize-path": {
1234 | "version": "3.0.0",
1235 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
1236 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
1237 | "engines": {
1238 | "node": ">=0.10.0"
1239 | }
1240 | },
1241 | "node_modules/normalize-url": {
1242 | "version": "4.5.1",
1243 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.1.tgz",
1244 | "integrity": "sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA==",
1245 | "engines": {
1246 | "node": ">=8"
1247 | }
1248 | },
1249 | "node_modules/object-inspect": {
1250 | "version": "1.12.2",
1251 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz",
1252 | "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==",
1253 | "funding": {
1254 | "url": "https://github.com/sponsors/ljharb"
1255 | }
1256 | },
1257 | "node_modules/on-finished": {
1258 | "version": "2.4.1",
1259 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz",
1260 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==",
1261 | "dependencies": {
1262 | "ee-first": "1.1.1"
1263 | },
1264 | "engines": {
1265 | "node": ">= 0.8"
1266 | }
1267 | },
1268 | "node_modules/once": {
1269 | "version": "1.4.0",
1270 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
1271 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==",
1272 | "dependencies": {
1273 | "wrappy": "1"
1274 | }
1275 | },
1276 | "node_modules/p-cancelable": {
1277 | "version": "1.1.0",
1278 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz",
1279 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==",
1280 | "engines": {
1281 | "node": ">=6"
1282 | }
1283 | },
1284 | "node_modules/package-json": {
1285 | "version": "6.5.0",
1286 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz",
1287 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==",
1288 | "dependencies": {
1289 | "got": "^9.6.0",
1290 | "registry-auth-token": "^4.0.0",
1291 | "registry-url": "^5.0.0",
1292 | "semver": "^6.2.0"
1293 | },
1294 | "engines": {
1295 | "node": ">=8"
1296 | }
1297 | },
1298 | "node_modules/package-json/node_modules/semver": {
1299 | "version": "6.3.0",
1300 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
1301 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
1302 | "bin": {
1303 | "semver": "bin/semver.js"
1304 | }
1305 | },
1306 | "node_modules/parseurl": {
1307 | "version": "1.3.3",
1308 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
1309 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==",
1310 | "engines": {
1311 | "node": ">= 0.8"
1312 | }
1313 | },
1314 | "node_modules/path": {
1315 | "version": "0.12.7",
1316 | "resolved": "https://registry.npmjs.org/path/-/path-0.12.7.tgz",
1317 | "integrity": "sha512-aXXC6s+1w7otVF9UletFkFcDsJeO7lSZBPUQhtb5O0xJe8LtYhj/GxldoL09bBj9+ZmE2hNoHqQSFMN5fikh4Q==",
1318 | "dependencies": {
1319 | "process": "^0.11.1",
1320 | "util": "^0.10.3"
1321 | }
1322 | },
1323 | "node_modules/path-to-regexp": {
1324 | "version": "0.1.7",
1325 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
1326 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ=="
1327 | },
1328 | "node_modules/picomatch": {
1329 | "version": "2.3.1",
1330 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
1331 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
1332 | "engines": {
1333 | "node": ">=8.6"
1334 | },
1335 | "funding": {
1336 | "url": "https://github.com/sponsors/jonschlinkert"
1337 | }
1338 | },
1339 | "node_modules/prepend-http": {
1340 | "version": "2.0.0",
1341 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz",
1342 | "integrity": "sha512-ravE6m9Atw9Z/jjttRUZ+clIXogdghyZAuWJ3qEzjT+jI/dL1ifAqhZeC5VHzQp1MSt1+jxKkFNemj/iO7tVUA==",
1343 | "engines": {
1344 | "node": ">=4"
1345 | }
1346 | },
1347 | "node_modules/process": {
1348 | "version": "0.11.10",
1349 | "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz",
1350 | "integrity": "sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A==",
1351 | "engines": {
1352 | "node": ">= 0.6.0"
1353 | }
1354 | },
1355 | "node_modules/proxy-addr": {
1356 | "version": "2.0.7",
1357 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz",
1358 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==",
1359 | "dependencies": {
1360 | "forwarded": "0.2.0",
1361 | "ipaddr.js": "1.9.1"
1362 | },
1363 | "engines": {
1364 | "node": ">= 0.10"
1365 | }
1366 | },
1367 | "node_modules/pstree.remy": {
1368 | "version": "1.1.8",
1369 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz",
1370 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w=="
1371 | },
1372 | "node_modules/pump": {
1373 | "version": "3.0.0",
1374 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz",
1375 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==",
1376 | "dependencies": {
1377 | "end-of-stream": "^1.1.0",
1378 | "once": "^1.3.1"
1379 | }
1380 | },
1381 | "node_modules/pupa": {
1382 | "version": "2.1.1",
1383 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz",
1384 | "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==",
1385 | "dependencies": {
1386 | "escape-goat": "^2.0.0"
1387 | },
1388 | "engines": {
1389 | "node": ">=8"
1390 | }
1391 | },
1392 | "node_modules/qs": {
1393 | "version": "6.10.3",
1394 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.10.3.tgz",
1395 | "integrity": "sha512-wr7M2E0OFRfIfJZjKGieI8lBKb7fRCH4Fv5KNPEs7gJ8jadvotdsS08PzOKR7opXhZ/Xkjtt3WF9g38drmyRqQ==",
1396 | "dependencies": {
1397 | "side-channel": "^1.0.4"
1398 | },
1399 | "engines": {
1400 | "node": ">=0.6"
1401 | },
1402 | "funding": {
1403 | "url": "https://github.com/sponsors/ljharb"
1404 | }
1405 | },
1406 | "node_modules/range-parser": {
1407 | "version": "1.2.1",
1408 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
1409 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==",
1410 | "engines": {
1411 | "node": ">= 0.6"
1412 | }
1413 | },
1414 | "node_modules/raw-body": {
1415 | "version": "2.5.1",
1416 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz",
1417 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==",
1418 | "dependencies": {
1419 | "bytes": "3.1.2",
1420 | "http-errors": "2.0.0",
1421 | "iconv-lite": "0.4.24",
1422 | "unpipe": "1.0.0"
1423 | },
1424 | "engines": {
1425 | "node": ">= 0.8"
1426 | }
1427 | },
1428 | "node_modules/rc": {
1429 | "version": "1.2.8",
1430 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz",
1431 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==",
1432 | "dependencies": {
1433 | "deep-extend": "^0.6.0",
1434 | "ini": "~1.3.0",
1435 | "minimist": "^1.2.0",
1436 | "strip-json-comments": "~2.0.1"
1437 | },
1438 | "bin": {
1439 | "rc": "cli.js"
1440 | }
1441 | },
1442 | "node_modules/rc/node_modules/ini": {
1443 | "version": "1.3.8",
1444 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz",
1445 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew=="
1446 | },
1447 | "node_modules/readdirp": {
1448 | "version": "3.6.0",
1449 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
1450 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
1451 | "dependencies": {
1452 | "picomatch": "^2.2.1"
1453 | },
1454 | "engines": {
1455 | "node": ">=8.10.0"
1456 | }
1457 | },
1458 | "node_modules/registry-auth-token": {
1459 | "version": "4.2.2",
1460 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.2.tgz",
1461 | "integrity": "sha512-PC5ZysNb42zpFME6D/XlIgtNGdTl8bBOCw90xQLVMpzuuubJKYDWFAEuUNc+Cn8Z8724tg2SDhDRrkVEsqfDMg==",
1462 | "dependencies": {
1463 | "rc": "1.2.8"
1464 | },
1465 | "engines": {
1466 | "node": ">=6.0.0"
1467 | }
1468 | },
1469 | "node_modules/registry-url": {
1470 | "version": "5.1.0",
1471 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz",
1472 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==",
1473 | "dependencies": {
1474 | "rc": "^1.2.8"
1475 | },
1476 | "engines": {
1477 | "node": ">=8"
1478 | }
1479 | },
1480 | "node_modules/responselike": {
1481 | "version": "1.0.2",
1482 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz",
1483 | "integrity": "sha512-/Fpe5guzJk1gPqdJLJR5u7eG/gNY4nImjbRDaVWVMRhne55TCmj2i9Q+54PBRfatRC8v/rIiv9BN0pMd9OV5EQ==",
1484 | "dependencies": {
1485 | "lowercase-keys": "^1.0.0"
1486 | }
1487 | },
1488 | "node_modules/safe-buffer": {
1489 | "version": "5.2.1",
1490 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
1491 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
1492 | "funding": [
1493 | {
1494 | "type": "github",
1495 | "url": "https://github.com/sponsors/feross"
1496 | },
1497 | {
1498 | "type": "patreon",
1499 | "url": "https://www.patreon.com/feross"
1500 | },
1501 | {
1502 | "type": "consulting",
1503 | "url": "https://feross.org/support"
1504 | }
1505 | ]
1506 | },
1507 | "node_modules/safer-buffer": {
1508 | "version": "2.1.2",
1509 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
1510 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
1511 | },
1512 | "node_modules/semver": {
1513 | "version": "5.7.1",
1514 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
1515 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==",
1516 | "bin": {
1517 | "semver": "bin/semver"
1518 | }
1519 | },
1520 | "node_modules/semver-diff": {
1521 | "version": "3.1.1",
1522 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz",
1523 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==",
1524 | "dependencies": {
1525 | "semver": "^6.3.0"
1526 | },
1527 | "engines": {
1528 | "node": ">=8"
1529 | }
1530 | },
1531 | "node_modules/semver-diff/node_modules/semver": {
1532 | "version": "6.3.0",
1533 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
1534 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
1535 | "bin": {
1536 | "semver": "bin/semver.js"
1537 | }
1538 | },
1539 | "node_modules/send": {
1540 | "version": "0.18.0",
1541 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz",
1542 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==",
1543 | "dependencies": {
1544 | "debug": "2.6.9",
1545 | "depd": "2.0.0",
1546 | "destroy": "1.2.0",
1547 | "encodeurl": "~1.0.2",
1548 | "escape-html": "~1.0.3",
1549 | "etag": "~1.8.1",
1550 | "fresh": "0.5.2",
1551 | "http-errors": "2.0.0",
1552 | "mime": "1.6.0",
1553 | "ms": "2.1.3",
1554 | "on-finished": "2.4.1",
1555 | "range-parser": "~1.2.1",
1556 | "statuses": "2.0.1"
1557 | },
1558 | "engines": {
1559 | "node": ">= 0.8.0"
1560 | }
1561 | },
1562 | "node_modules/send/node_modules/ms": {
1563 | "version": "2.1.3",
1564 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
1565 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
1566 | },
1567 | "node_modules/serve-static": {
1568 | "version": "1.15.0",
1569 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz",
1570 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==",
1571 | "dependencies": {
1572 | "encodeurl": "~1.0.2",
1573 | "escape-html": "~1.0.3",
1574 | "parseurl": "~1.3.3",
1575 | "send": "0.18.0"
1576 | },
1577 | "engines": {
1578 | "node": ">= 0.8.0"
1579 | }
1580 | },
1581 | "node_modules/setprototypeof": {
1582 | "version": "1.2.0",
1583 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz",
1584 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw=="
1585 | },
1586 | "node_modules/side-channel": {
1587 | "version": "1.0.4",
1588 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz",
1589 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==",
1590 | "dependencies": {
1591 | "call-bind": "^1.0.0",
1592 | "get-intrinsic": "^1.0.2",
1593 | "object-inspect": "^1.9.0"
1594 | },
1595 | "funding": {
1596 | "url": "https://github.com/sponsors/ljharb"
1597 | }
1598 | },
1599 | "node_modules/signal-exit": {
1600 | "version": "3.0.7",
1601 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz",
1602 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ=="
1603 | },
1604 | "node_modules/statuses": {
1605 | "version": "2.0.1",
1606 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
1607 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==",
1608 | "engines": {
1609 | "node": ">= 0.8"
1610 | }
1611 | },
1612 | "node_modules/string-width": {
1613 | "version": "4.2.3",
1614 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
1615 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
1616 | "dependencies": {
1617 | "emoji-regex": "^8.0.0",
1618 | "is-fullwidth-code-point": "^3.0.0",
1619 | "strip-ansi": "^6.0.1"
1620 | },
1621 | "engines": {
1622 | "node": ">=8"
1623 | }
1624 | },
1625 | "node_modules/strip-ansi": {
1626 | "version": "6.0.1",
1627 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
1628 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
1629 | "dependencies": {
1630 | "ansi-regex": "^5.0.1"
1631 | },
1632 | "engines": {
1633 | "node": ">=8"
1634 | }
1635 | },
1636 | "node_modules/strip-json-comments": {
1637 | "version": "2.0.1",
1638 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz",
1639 | "integrity": "sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ==",
1640 | "engines": {
1641 | "node": ">=0.10.0"
1642 | }
1643 | },
1644 | "node_modules/supports-color": {
1645 | "version": "5.5.0",
1646 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
1647 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
1648 | "dependencies": {
1649 | "has-flag": "^3.0.0"
1650 | },
1651 | "engines": {
1652 | "node": ">=4"
1653 | }
1654 | },
1655 | "node_modules/to-readable-stream": {
1656 | "version": "1.0.0",
1657 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz",
1658 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==",
1659 | "engines": {
1660 | "node": ">=6"
1661 | }
1662 | },
1663 | "node_modules/to-regex-range": {
1664 | "version": "5.0.1",
1665 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
1666 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
1667 | "dependencies": {
1668 | "is-number": "^7.0.0"
1669 | },
1670 | "engines": {
1671 | "node": ">=8.0"
1672 | }
1673 | },
1674 | "node_modules/toidentifier": {
1675 | "version": "1.0.1",
1676 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz",
1677 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==",
1678 | "engines": {
1679 | "node": ">=0.6"
1680 | }
1681 | },
1682 | "node_modules/touch": {
1683 | "version": "3.1.0",
1684 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz",
1685 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==",
1686 | "dependencies": {
1687 | "nopt": "~1.0.10"
1688 | },
1689 | "bin": {
1690 | "nodetouch": "bin/nodetouch.js"
1691 | }
1692 | },
1693 | "node_modules/type-fest": {
1694 | "version": "0.20.2",
1695 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz",
1696 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==",
1697 | "engines": {
1698 | "node": ">=10"
1699 | },
1700 | "funding": {
1701 | "url": "https://github.com/sponsors/sindresorhus"
1702 | }
1703 | },
1704 | "node_modules/type-is": {
1705 | "version": "1.6.18",
1706 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
1707 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
1708 | "dependencies": {
1709 | "media-typer": "0.3.0",
1710 | "mime-types": "~2.1.24"
1711 | },
1712 | "engines": {
1713 | "node": ">= 0.6"
1714 | }
1715 | },
1716 | "node_modules/typedarray-to-buffer": {
1717 | "version": "3.1.5",
1718 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz",
1719 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==",
1720 | "dependencies": {
1721 | "is-typedarray": "^1.0.0"
1722 | }
1723 | },
1724 | "node_modules/undefsafe": {
1725 | "version": "2.0.5",
1726 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz",
1727 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA=="
1728 | },
1729 | "node_modules/unique-string": {
1730 | "version": "2.0.0",
1731 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz",
1732 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==",
1733 | "dependencies": {
1734 | "crypto-random-string": "^2.0.0"
1735 | },
1736 | "engines": {
1737 | "node": ">=8"
1738 | }
1739 | },
1740 | "node_modules/unpipe": {
1741 | "version": "1.0.0",
1742 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
1743 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==",
1744 | "engines": {
1745 | "node": ">= 0.8"
1746 | }
1747 | },
1748 | "node_modules/update-notifier": {
1749 | "version": "5.1.0",
1750 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-5.1.0.tgz",
1751 | "integrity": "sha512-ItnICHbeMh9GqUy31hFPrD1kcuZ3rpxDZbf4KUDavXwS0bW5m7SLbDQpGX3UYr072cbrF5hFUs3r5tUsPwjfHw==",
1752 | "dependencies": {
1753 | "boxen": "^5.0.0",
1754 | "chalk": "^4.1.0",
1755 | "configstore": "^5.0.1",
1756 | "has-yarn": "^2.1.0",
1757 | "import-lazy": "^2.1.0",
1758 | "is-ci": "^2.0.0",
1759 | "is-installed-globally": "^0.4.0",
1760 | "is-npm": "^5.0.0",
1761 | "is-yarn-global": "^0.3.0",
1762 | "latest-version": "^5.1.0",
1763 | "pupa": "^2.1.1",
1764 | "semver": "^7.3.4",
1765 | "semver-diff": "^3.1.1",
1766 | "xdg-basedir": "^4.0.0"
1767 | },
1768 | "engines": {
1769 | "node": ">=10"
1770 | },
1771 | "funding": {
1772 | "url": "https://github.com/yeoman/update-notifier?sponsor=1"
1773 | }
1774 | },
1775 | "node_modules/update-notifier/node_modules/semver": {
1776 | "version": "7.3.7",
1777 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz",
1778 | "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==",
1779 | "dependencies": {
1780 | "lru-cache": "^6.0.0"
1781 | },
1782 | "bin": {
1783 | "semver": "bin/semver.js"
1784 | },
1785 | "engines": {
1786 | "node": ">=10"
1787 | }
1788 | },
1789 | "node_modules/url-parse-lax": {
1790 | "version": "3.0.0",
1791 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz",
1792 | "integrity": "sha512-NjFKA0DidqPa5ciFcSrXnAltTtzz84ogy+NebPvfEgAck0+TNg4UJ4IN+fB7zRZfbgUf0syOo9MDxFkDSMuFaQ==",
1793 | "dependencies": {
1794 | "prepend-http": "^2.0.0"
1795 | },
1796 | "engines": {
1797 | "node": ">=4"
1798 | }
1799 | },
1800 | "node_modules/util": {
1801 | "version": "0.10.4",
1802 | "resolved": "https://registry.npmjs.org/util/-/util-0.10.4.tgz",
1803 | "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==",
1804 | "dependencies": {
1805 | "inherits": "2.0.3"
1806 | }
1807 | },
1808 | "node_modules/util/node_modules/inherits": {
1809 | "version": "2.0.3",
1810 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
1811 | "integrity": "sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw=="
1812 | },
1813 | "node_modules/utils-merge": {
1814 | "version": "1.0.1",
1815 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
1816 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==",
1817 | "engines": {
1818 | "node": ">= 0.4.0"
1819 | }
1820 | },
1821 | "node_modules/vary": {
1822 | "version": "1.1.2",
1823 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
1824 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==",
1825 | "engines": {
1826 | "node": ">= 0.8"
1827 | }
1828 | },
1829 | "node_modules/web-streams-polyfill": {
1830 | "version": "3.2.1",
1831 | "resolved": "https://registry.npmjs.org/web-streams-polyfill/-/web-streams-polyfill-3.2.1.tgz",
1832 | "integrity": "sha512-e0MO3wdXWKrLbL0DgGnUV7WHVuw9OUvL4hjgnPkIeEvESk74gAITi5G606JtZPp39cd8HA9VQzCIvA49LpPN5Q==",
1833 | "engines": {
1834 | "node": ">= 8"
1835 | }
1836 | },
1837 | "node_modules/widest-line": {
1838 | "version": "3.1.0",
1839 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz",
1840 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==",
1841 | "dependencies": {
1842 | "string-width": "^4.0.0"
1843 | },
1844 | "engines": {
1845 | "node": ">=8"
1846 | }
1847 | },
1848 | "node_modules/wrap-ansi": {
1849 | "version": "7.0.0",
1850 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
1851 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
1852 | "dependencies": {
1853 | "ansi-styles": "^4.0.0",
1854 | "string-width": "^4.1.0",
1855 | "strip-ansi": "^6.0.0"
1856 | },
1857 | "engines": {
1858 | "node": ">=10"
1859 | },
1860 | "funding": {
1861 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
1862 | }
1863 | },
1864 | "node_modules/wrappy": {
1865 | "version": "1.0.2",
1866 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
1867 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ=="
1868 | },
1869 | "node_modules/write-file-atomic": {
1870 | "version": "3.0.3",
1871 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz",
1872 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==",
1873 | "dependencies": {
1874 | "imurmurhash": "^0.1.4",
1875 | "is-typedarray": "^1.0.0",
1876 | "signal-exit": "^3.0.2",
1877 | "typedarray-to-buffer": "^3.1.5"
1878 | }
1879 | },
1880 | "node_modules/xdg-basedir": {
1881 | "version": "4.0.0",
1882 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz",
1883 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==",
1884 | "engines": {
1885 | "node": ">=8"
1886 | }
1887 | },
1888 | "node_modules/yallist": {
1889 | "version": "4.0.0",
1890 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
1891 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A=="
1892 | }
1893 | },
1894 | "dependencies": {
1895 | "@sindresorhus/is": {
1896 | "version": "0.14.0",
1897 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz",
1898 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ=="
1899 | },
1900 | "@szmarczak/http-timer": {
1901 | "version": "1.1.2",
1902 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz",
1903 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==",
1904 | "requires": {
1905 | "defer-to-connect": "^1.0.1"
1906 | }
1907 | },
1908 | "abbrev": {
1909 | "version": "1.1.1",
1910 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz",
1911 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q=="
1912 | },
1913 | "accepts": {
1914 | "version": "1.3.8",
1915 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz",
1916 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==",
1917 | "requires": {
1918 | "mime-types": "~2.1.34",
1919 | "negotiator": "0.6.3"
1920 | }
1921 | },
1922 | "ansi-align": {
1923 | "version": "3.0.1",
1924 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.1.tgz",
1925 | "integrity": "sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w==",
1926 | "requires": {
1927 | "string-width": "^4.1.0"
1928 | }
1929 | },
1930 | "ansi-regex": {
1931 | "version": "5.0.1",
1932 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
1933 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ=="
1934 | },
1935 | "ansi-styles": {
1936 | "version": "4.3.0",
1937 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
1938 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
1939 | "requires": {
1940 | "color-convert": "^2.0.1"
1941 | }
1942 | },
1943 | "anymatch": {
1944 | "version": "3.1.2",
1945 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz",
1946 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==",
1947 | "requires": {
1948 | "normalize-path": "^3.0.0",
1949 | "picomatch": "^2.0.4"
1950 | }
1951 | },
1952 | "array-flatten": {
1953 | "version": "1.1.1",
1954 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
1955 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg=="
1956 | },
1957 | "balanced-match": {
1958 | "version": "1.0.2",
1959 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
1960 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw=="
1961 | },
1962 | "binary-extensions": {
1963 | "version": "2.2.0",
1964 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
1965 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA=="
1966 | },
1967 | "body-parser": {
1968 | "version": "1.20.0",
1969 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.0.tgz",
1970 | "integrity": "sha512-DfJ+q6EPcGKZD1QWUjSpqp+Q7bDQTsQIF4zfUAtZ6qk+H/3/QRhg9CEp39ss+/T2vw0+HaidC0ecJj/DRLIaKg==",
1971 | "requires": {
1972 | "bytes": "3.1.2",
1973 | "content-type": "~1.0.4",
1974 | "debug": "2.6.9",
1975 | "depd": "2.0.0",
1976 | "destroy": "1.2.0",
1977 | "http-errors": "2.0.0",
1978 | "iconv-lite": "0.4.24",
1979 | "on-finished": "2.4.1",
1980 | "qs": "6.10.3",
1981 | "raw-body": "2.5.1",
1982 | "type-is": "~1.6.18",
1983 | "unpipe": "1.0.0"
1984 | }
1985 | },
1986 | "boxen": {
1987 | "version": "5.1.2",
1988 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-5.1.2.tgz",
1989 | "integrity": "sha512-9gYgQKXx+1nP8mP7CzFyaUARhg7D3n1dF/FnErWmu9l6JvGpNUN278h0aSb+QjoiKSWG+iZ3uHrcqk0qrY9RQQ==",
1990 | "requires": {
1991 | "ansi-align": "^3.0.0",
1992 | "camelcase": "^6.2.0",
1993 | "chalk": "^4.1.0",
1994 | "cli-boxes": "^2.2.1",
1995 | "string-width": "^4.2.2",
1996 | "type-fest": "^0.20.2",
1997 | "widest-line": "^3.1.0",
1998 | "wrap-ansi": "^7.0.0"
1999 | }
2000 | },
2001 | "brace-expansion": {
2002 | "version": "1.1.11",
2003 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
2004 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
2005 | "requires": {
2006 | "balanced-match": "^1.0.0",
2007 | "concat-map": "0.0.1"
2008 | }
2009 | },
2010 | "braces": {
2011 | "version": "3.0.2",
2012 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
2013 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
2014 | "requires": {
2015 | "fill-range": "^7.0.1"
2016 | }
2017 | },
2018 | "bytes": {
2019 | "version": "3.1.2",
2020 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz",
2021 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg=="
2022 | },
2023 | "cacheable-request": {
2024 | "version": "6.1.0",
2025 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz",
2026 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==",
2027 | "requires": {
2028 | "clone-response": "^1.0.2",
2029 | "get-stream": "^5.1.0",
2030 | "http-cache-semantics": "^4.0.0",
2031 | "keyv": "^3.0.0",
2032 | "lowercase-keys": "^2.0.0",
2033 | "normalize-url": "^4.1.0",
2034 | "responselike": "^1.0.2"
2035 | },
2036 | "dependencies": {
2037 | "get-stream": {
2038 | "version": "5.2.0",
2039 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz",
2040 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==",
2041 | "requires": {
2042 | "pump": "^3.0.0"
2043 | }
2044 | },
2045 | "lowercase-keys": {
2046 | "version": "2.0.0",
2047 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz",
2048 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA=="
2049 | }
2050 | }
2051 | },
2052 | "call-bind": {
2053 | "version": "1.0.2",
2054 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz",
2055 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==",
2056 | "requires": {
2057 | "function-bind": "^1.1.1",
2058 | "get-intrinsic": "^1.0.2"
2059 | }
2060 | },
2061 | "camelcase": {
2062 | "version": "6.3.0",
2063 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz",
2064 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA=="
2065 | },
2066 | "chalk": {
2067 | "version": "4.1.2",
2068 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
2069 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
2070 | "requires": {
2071 | "ansi-styles": "^4.1.0",
2072 | "supports-color": "^7.1.0"
2073 | },
2074 | "dependencies": {
2075 | "has-flag": {
2076 | "version": "4.0.0",
2077 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
2078 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ=="
2079 | },
2080 | "supports-color": {
2081 | "version": "7.2.0",
2082 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
2083 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
2084 | "requires": {
2085 | "has-flag": "^4.0.0"
2086 | }
2087 | }
2088 | }
2089 | },
2090 | "chokidar": {
2091 | "version": "3.5.3",
2092 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz",
2093 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==",
2094 | "requires": {
2095 | "anymatch": "~3.1.2",
2096 | "braces": "~3.0.2",
2097 | "fsevents": "~2.3.2",
2098 | "glob-parent": "~5.1.2",
2099 | "is-binary-path": "~2.1.0",
2100 | "is-glob": "~4.0.1",
2101 | "normalize-path": "~3.0.0",
2102 | "readdirp": "~3.6.0"
2103 | }
2104 | },
2105 | "ci-info": {
2106 | "version": "2.0.0",
2107 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz",
2108 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ=="
2109 | },
2110 | "cli-boxes": {
2111 | "version": "2.2.1",
2112 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz",
2113 | "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw=="
2114 | },
2115 | "clone-response": {
2116 | "version": "1.0.2",
2117 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz",
2118 | "integrity": "sha512-yjLXh88P599UOyPTFX0POsd7WxnbsVsGohcwzHOLspIhhpalPw1BcqED8NblyZLKcGrL8dTgMlcaZxV2jAD41Q==",
2119 | "requires": {
2120 | "mimic-response": "^1.0.0"
2121 | }
2122 | },
2123 | "color-convert": {
2124 | "version": "2.0.1",
2125 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
2126 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
2127 | "requires": {
2128 | "color-name": "~1.1.4"
2129 | }
2130 | },
2131 | "color-name": {
2132 | "version": "1.1.4",
2133 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
2134 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA=="
2135 | },
2136 | "concat-map": {
2137 | "version": "0.0.1",
2138 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
2139 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg=="
2140 | },
2141 | "configstore": {
2142 | "version": "5.0.1",
2143 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz",
2144 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==",
2145 | "requires": {
2146 | "dot-prop": "^5.2.0",
2147 | "graceful-fs": "^4.1.2",
2148 | "make-dir": "^3.0.0",
2149 | "unique-string": "^2.0.0",
2150 | "write-file-atomic": "^3.0.0",
2151 | "xdg-basedir": "^4.0.0"
2152 | }
2153 | },
2154 | "content-disposition": {
2155 | "version": "0.5.4",
2156 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz",
2157 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==",
2158 | "requires": {
2159 | "safe-buffer": "5.2.1"
2160 | }
2161 | },
2162 | "content-type": {
2163 | "version": "1.0.4",
2164 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz",
2165 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA=="
2166 | },
2167 | "cookie": {
2168 | "version": "0.5.0",
2169 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz",
2170 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw=="
2171 | },
2172 | "cookie-parser": {
2173 | "version": "1.4.6",
2174 | "resolved": "https://registry.npmjs.org/cookie-parser/-/cookie-parser-1.4.6.tgz",
2175 | "integrity": "sha512-z3IzaNjdwUC2olLIB5/ITd0/setiaFMLYiZJle7xg5Fe9KWAceil7xszYfHHBtDFYLSgJduS2Ty0P1uJdPDJeA==",
2176 | "requires": {
2177 | "cookie": "0.4.1",
2178 | "cookie-signature": "1.0.6"
2179 | },
2180 | "dependencies": {
2181 | "cookie": {
2182 | "version": "0.4.1",
2183 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz",
2184 | "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA=="
2185 | }
2186 | }
2187 | },
2188 | "cookie-signature": {
2189 | "version": "1.0.6",
2190 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
2191 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ=="
2192 | },
2193 | "crypto-random-string": {
2194 | "version": "2.0.0",
2195 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz",
2196 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA=="
2197 | },
2198 | "data-uri-to-buffer": {
2199 | "version": "4.0.0",
2200 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-4.0.0.tgz",
2201 | "integrity": "sha512-Vr3mLBA8qWmcuschSLAOogKgQ/Jwxulv3RNE4FXnYWRGujzrRWQI4m12fQqRkwX06C0KanhLr4hK+GydchZsaA=="
2202 | },
2203 | "debug": {
2204 | "version": "2.6.9",
2205 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
2206 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
2207 | "requires": {
2208 | "ms": "2.0.0"
2209 | }
2210 | },
2211 | "decompress-response": {
2212 | "version": "3.3.0",
2213 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz",
2214 | "integrity": "sha512-BzRPQuY1ip+qDonAOz42gRm/pg9F768C+npV/4JOsxRC2sq+Rlk+Q4ZCAsOhnIaMrgarILY+RMUIvMmmX1qAEA==",
2215 | "requires": {
2216 | "mimic-response": "^1.0.0"
2217 | }
2218 | },
2219 | "deep-extend": {
2220 | "version": "0.6.0",
2221 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz",
2222 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA=="
2223 | },
2224 | "defer-to-connect": {
2225 | "version": "1.1.3",
2226 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz",
2227 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ=="
2228 | },
2229 | "depd": {
2230 | "version": "2.0.0",
2231 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz",
2232 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw=="
2233 | },
2234 | "destroy": {
2235 | "version": "1.2.0",
2236 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz",
2237 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg=="
2238 | },
2239 | "dot-prop": {
2240 | "version": "5.3.0",
2241 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz",
2242 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==",
2243 | "requires": {
2244 | "is-obj": "^2.0.0"
2245 | }
2246 | },
2247 | "dotenv": {
2248 | "version": "16.0.1",
2249 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.1.tgz",
2250 | "integrity": "sha512-1K6hR6wtk2FviQ4kEiSjFiH5rpzEVi8WW0x96aztHVMhEspNpc4DVOUTEHtEva5VThQ8IaBX1Pe4gSzpVVUsKQ=="
2251 | },
2252 | "duplexer3": {
2253 | "version": "0.1.4",
2254 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz",
2255 | "integrity": "sha512-CEj8FwwNA4cVH2uFCoHUrmojhYh1vmCdOaneKJXwkeY1i9jnlslVo9dx+hQ5Hl9GnH/Bwy/IjxAyOePyPKYnzA=="
2256 | },
2257 | "ee-first": {
2258 | "version": "1.1.1",
2259 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
2260 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow=="
2261 | },
2262 | "emoji-regex": {
2263 | "version": "8.0.0",
2264 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
2265 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A=="
2266 | },
2267 | "encodeurl": {
2268 | "version": "1.0.2",
2269 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
2270 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w=="
2271 | },
2272 | "end-of-stream": {
2273 | "version": "1.4.4",
2274 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz",
2275 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==",
2276 | "requires": {
2277 | "once": "^1.4.0"
2278 | }
2279 | },
2280 | "escape-goat": {
2281 | "version": "2.1.1",
2282 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz",
2283 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q=="
2284 | },
2285 | "escape-html": {
2286 | "version": "1.0.3",
2287 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
2288 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow=="
2289 | },
2290 | "etag": {
2291 | "version": "1.8.1",
2292 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
2293 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg=="
2294 | },
2295 | "express": {
2296 | "version": "4.18.1",
2297 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.1.tgz",
2298 | "integrity": "sha512-zZBcOX9TfehHQhtupq57OF8lFZ3UZi08Y97dwFCkD8p9d/d2Y3M+ykKcwaMDEL+4qyUolgBDX6AblpR3fL212Q==",
2299 | "requires": {
2300 | "accepts": "~1.3.8",
2301 | "array-flatten": "1.1.1",
2302 | "body-parser": "1.20.0",
2303 | "content-disposition": "0.5.4",
2304 | "content-type": "~1.0.4",
2305 | "cookie": "0.5.0",
2306 | "cookie-signature": "1.0.6",
2307 | "debug": "2.6.9",
2308 | "depd": "2.0.0",
2309 | "encodeurl": "~1.0.2",
2310 | "escape-html": "~1.0.3",
2311 | "etag": "~1.8.1",
2312 | "finalhandler": "1.2.0",
2313 | "fresh": "0.5.2",
2314 | "http-errors": "2.0.0",
2315 | "merge-descriptors": "1.0.1",
2316 | "methods": "~1.1.2",
2317 | "on-finished": "2.4.1",
2318 | "parseurl": "~1.3.3",
2319 | "path-to-regexp": "0.1.7",
2320 | "proxy-addr": "~2.0.7",
2321 | "qs": "6.10.3",
2322 | "range-parser": "~1.2.1",
2323 | "safe-buffer": "5.2.1",
2324 | "send": "0.18.0",
2325 | "serve-static": "1.15.0",
2326 | "setprototypeof": "1.2.0",
2327 | "statuses": "2.0.1",
2328 | "type-is": "~1.6.18",
2329 | "utils-merge": "1.0.1",
2330 | "vary": "~1.1.2"
2331 | }
2332 | },
2333 | "fetch-blob": {
2334 | "version": "3.1.5",
2335 | "resolved": "https://registry.npmjs.org/fetch-blob/-/fetch-blob-3.1.5.tgz",
2336 | "integrity": "sha512-N64ZpKqoLejlrwkIAnb9iLSA3Vx/kjgzpcDhygcqJ2KKjky8nCgUQ+dzXtbrLaWZGZNmNfQTsiQ0weZ1svglHg==",
2337 | "requires": {
2338 | "node-domexception": "^1.0.0",
2339 | "web-streams-polyfill": "^3.0.3"
2340 | }
2341 | },
2342 | "fill-range": {
2343 | "version": "7.0.1",
2344 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
2345 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
2346 | "requires": {
2347 | "to-regex-range": "^5.0.1"
2348 | }
2349 | },
2350 | "finalhandler": {
2351 | "version": "1.2.0",
2352 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz",
2353 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==",
2354 | "requires": {
2355 | "debug": "2.6.9",
2356 | "encodeurl": "~1.0.2",
2357 | "escape-html": "~1.0.3",
2358 | "on-finished": "2.4.1",
2359 | "parseurl": "~1.3.3",
2360 | "statuses": "2.0.1",
2361 | "unpipe": "~1.0.0"
2362 | }
2363 | },
2364 | "formdata-polyfill": {
2365 | "version": "4.0.10",
2366 | "resolved": "https://registry.npmjs.org/formdata-polyfill/-/formdata-polyfill-4.0.10.tgz",
2367 | "integrity": "sha512-buewHzMvYL29jdeQTVILecSaZKnt/RJWjoZCF5OW60Z67/GmSLBkOFM7qh1PI3zFNtJbaZL5eQu1vLfazOwj4g==",
2368 | "requires": {
2369 | "fetch-blob": "^3.1.2"
2370 | }
2371 | },
2372 | "forwarded": {
2373 | "version": "0.2.0",
2374 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz",
2375 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow=="
2376 | },
2377 | "fresh": {
2378 | "version": "0.5.2",
2379 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
2380 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q=="
2381 | },
2382 | "fsevents": {
2383 | "version": "2.3.2",
2384 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
2385 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
2386 | "optional": true
2387 | },
2388 | "function-bind": {
2389 | "version": "1.1.1",
2390 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
2391 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A=="
2392 | },
2393 | "get-intrinsic": {
2394 | "version": "1.1.2",
2395 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.2.tgz",
2396 | "integrity": "sha512-Jfm3OyCxHh9DJyc28qGk+JmfkpO41A4XkneDSujN9MDXrm4oDKdHvndhZ2dN94+ERNfkYJWDclW6k2L/ZGHjXA==",
2397 | "requires": {
2398 | "function-bind": "^1.1.1",
2399 | "has": "^1.0.3",
2400 | "has-symbols": "^1.0.3"
2401 | }
2402 | },
2403 | "get-stream": {
2404 | "version": "4.1.0",
2405 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz",
2406 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==",
2407 | "requires": {
2408 | "pump": "^3.0.0"
2409 | }
2410 | },
2411 | "glob-parent": {
2412 | "version": "5.1.2",
2413 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
2414 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
2415 | "requires": {
2416 | "is-glob": "^4.0.1"
2417 | }
2418 | },
2419 | "global-dirs": {
2420 | "version": "3.0.0",
2421 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-3.0.0.tgz",
2422 | "integrity": "sha512-v8ho2DS5RiCjftj1nD9NmnfaOzTdud7RRnVd9kFNOjqZbISlx5DQ+OrTkywgd0dIt7oFCvKetZSHoHcP3sDdiA==",
2423 | "requires": {
2424 | "ini": "2.0.0"
2425 | }
2426 | },
2427 | "got": {
2428 | "version": "9.6.0",
2429 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz",
2430 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==",
2431 | "requires": {
2432 | "@sindresorhus/is": "^0.14.0",
2433 | "@szmarczak/http-timer": "^1.1.2",
2434 | "cacheable-request": "^6.0.0",
2435 | "decompress-response": "^3.3.0",
2436 | "duplexer3": "^0.1.4",
2437 | "get-stream": "^4.1.0",
2438 | "lowercase-keys": "^1.0.1",
2439 | "mimic-response": "^1.0.1",
2440 | "p-cancelable": "^1.0.0",
2441 | "to-readable-stream": "^1.0.0",
2442 | "url-parse-lax": "^3.0.0"
2443 | }
2444 | },
2445 | "graceful-fs": {
2446 | "version": "4.2.10",
2447 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz",
2448 | "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA=="
2449 | },
2450 | "has": {
2451 | "version": "1.0.3",
2452 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
2453 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
2454 | "requires": {
2455 | "function-bind": "^1.1.1"
2456 | }
2457 | },
2458 | "has-flag": {
2459 | "version": "3.0.0",
2460 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
2461 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw=="
2462 | },
2463 | "has-symbols": {
2464 | "version": "1.0.3",
2465 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz",
2466 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A=="
2467 | },
2468 | "has-yarn": {
2469 | "version": "2.1.0",
2470 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz",
2471 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw=="
2472 | },
2473 | "http-cache-semantics": {
2474 | "version": "4.1.0",
2475 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz",
2476 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ=="
2477 | },
2478 | "http-errors": {
2479 | "version": "2.0.0",
2480 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz",
2481 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==",
2482 | "requires": {
2483 | "depd": "2.0.0",
2484 | "inherits": "2.0.4",
2485 | "setprototypeof": "1.2.0",
2486 | "statuses": "2.0.1",
2487 | "toidentifier": "1.0.1"
2488 | }
2489 | },
2490 | "iconv-lite": {
2491 | "version": "0.4.24",
2492 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
2493 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
2494 | "requires": {
2495 | "safer-buffer": ">= 2.1.2 < 3"
2496 | }
2497 | },
2498 | "ignore-by-default": {
2499 | "version": "1.0.1",
2500 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz",
2501 | "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA=="
2502 | },
2503 | "import-lazy": {
2504 | "version": "2.1.0",
2505 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz",
2506 | "integrity": "sha512-m7ZEHgtw69qOGw+jwxXkHlrlIPdTGkyh66zXZ1ajZbxkDBNjSY/LGbmjc7h0s2ELsUDTAhFr55TrPSSqJGPG0A=="
2507 | },
2508 | "imurmurhash": {
2509 | "version": "0.1.4",
2510 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
2511 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA=="
2512 | },
2513 | "inherits": {
2514 | "version": "2.0.4",
2515 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
2516 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
2517 | },
2518 | "ini": {
2519 | "version": "2.0.0",
2520 | "resolved": "https://registry.npmjs.org/ini/-/ini-2.0.0.tgz",
2521 | "integrity": "sha512-7PnF4oN3CvZF23ADhA5wRaYEQpJ8qygSkbtTXWBeXWXmEVRXK+1ITciHWwHhsjv1TmW0MgacIv6hEi5pX5NQdA=="
2522 | },
2523 | "ipaddr.js": {
2524 | "version": "1.9.1",
2525 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz",
2526 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g=="
2527 | },
2528 | "is-binary-path": {
2529 | "version": "2.1.0",
2530 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
2531 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
2532 | "requires": {
2533 | "binary-extensions": "^2.0.0"
2534 | }
2535 | },
2536 | "is-ci": {
2537 | "version": "2.0.0",
2538 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz",
2539 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==",
2540 | "requires": {
2541 | "ci-info": "^2.0.0"
2542 | }
2543 | },
2544 | "is-extglob": {
2545 | "version": "2.1.1",
2546 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
2547 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ=="
2548 | },
2549 | "is-fullwidth-code-point": {
2550 | "version": "3.0.0",
2551 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
2552 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg=="
2553 | },
2554 | "is-glob": {
2555 | "version": "4.0.3",
2556 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
2557 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
2558 | "requires": {
2559 | "is-extglob": "^2.1.1"
2560 | }
2561 | },
2562 | "is-installed-globally": {
2563 | "version": "0.4.0",
2564 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.4.0.tgz",
2565 | "integrity": "sha512-iwGqO3J21aaSkC7jWnHP/difazwS7SFeIqxv6wEtLU8Y5KlzFTjyqcSIT0d8s4+dDhKytsk9PJZ2BkS5eZwQRQ==",
2566 | "requires": {
2567 | "global-dirs": "^3.0.0",
2568 | "is-path-inside": "^3.0.2"
2569 | }
2570 | },
2571 | "is-npm": {
2572 | "version": "5.0.0",
2573 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-5.0.0.tgz",
2574 | "integrity": "sha512-WW/rQLOazUq+ST/bCAVBp/2oMERWLsR7OrKyt052dNDk4DHcDE0/7QSXITlmi+VBcV13DfIbysG3tZJm5RfdBA=="
2575 | },
2576 | "is-number": {
2577 | "version": "7.0.0",
2578 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
2579 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng=="
2580 | },
2581 | "is-obj": {
2582 | "version": "2.0.0",
2583 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz",
2584 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w=="
2585 | },
2586 | "is-path-inside": {
2587 | "version": "3.0.3",
2588 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz",
2589 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ=="
2590 | },
2591 | "is-typedarray": {
2592 | "version": "1.0.0",
2593 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz",
2594 | "integrity": "sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA=="
2595 | },
2596 | "is-yarn-global": {
2597 | "version": "0.3.0",
2598 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz",
2599 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw=="
2600 | },
2601 | "json-buffer": {
2602 | "version": "3.0.0",
2603 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz",
2604 | "integrity": "sha512-CuUqjv0FUZIdXkHPI8MezCnFCdaTAacej1TZYulLoAg1h/PhwkdXFN4V/gzY4g+fMBCOV2xF+rp7t2XD2ns/NQ=="
2605 | },
2606 | "keyv": {
2607 | "version": "3.1.0",
2608 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz",
2609 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==",
2610 | "requires": {
2611 | "json-buffer": "3.0.0"
2612 | }
2613 | },
2614 | "latest-version": {
2615 | "version": "5.1.0",
2616 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz",
2617 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==",
2618 | "requires": {
2619 | "package-json": "^6.3.0"
2620 | }
2621 | },
2622 | "lowercase-keys": {
2623 | "version": "1.0.1",
2624 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz",
2625 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA=="
2626 | },
2627 | "lru-cache": {
2628 | "version": "6.0.0",
2629 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
2630 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
2631 | "requires": {
2632 | "yallist": "^4.0.0"
2633 | }
2634 | },
2635 | "make-dir": {
2636 | "version": "3.1.0",
2637 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz",
2638 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==",
2639 | "requires": {
2640 | "semver": "^6.0.0"
2641 | },
2642 | "dependencies": {
2643 | "semver": {
2644 | "version": "6.3.0",
2645 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
2646 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw=="
2647 | }
2648 | }
2649 | },
2650 | "media-typer": {
2651 | "version": "0.3.0",
2652 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
2653 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ=="
2654 | },
2655 | "merge-descriptors": {
2656 | "version": "1.0.1",
2657 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
2658 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w=="
2659 | },
2660 | "methods": {
2661 | "version": "1.1.2",
2662 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
2663 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w=="
2664 | },
2665 | "mime": {
2666 | "version": "1.6.0",
2667 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
2668 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg=="
2669 | },
2670 | "mime-db": {
2671 | "version": "1.52.0",
2672 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
2673 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg=="
2674 | },
2675 | "mime-types": {
2676 | "version": "2.1.35",
2677 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
2678 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
2679 | "requires": {
2680 | "mime-db": "1.52.0"
2681 | }
2682 | },
2683 | "mimic-response": {
2684 | "version": "1.0.1",
2685 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz",
2686 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ=="
2687 | },
2688 | "minimatch": {
2689 | "version": "3.1.2",
2690 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
2691 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
2692 | "requires": {
2693 | "brace-expansion": "^1.1.7"
2694 | }
2695 | },
2696 | "minimist": {
2697 | "version": "1.2.6",
2698 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz",
2699 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q=="
2700 | },
2701 | "ms": {
2702 | "version": "2.0.0",
2703 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
2704 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
2705 | },
2706 | "negotiator": {
2707 | "version": "0.6.3",
2708 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz",
2709 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg=="
2710 | },
2711 | "node-domexception": {
2712 | "version": "1.0.0",
2713 | "resolved": "https://registry.npmjs.org/node-domexception/-/node-domexception-1.0.0.tgz",
2714 | "integrity": "sha512-/jKZoMpw0F8GRwl4/eLROPA3cfcXtLApP0QzLmUT/HuPCZWyB7IY9ZrMeKw2O/nFIqPQB3PVM9aYm0F312AXDQ=="
2715 | },
2716 | "node-fetch": {
2717 | "version": "3.2.6",
2718 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-3.2.6.tgz",
2719 | "integrity": "sha512-LAy/HZnLADOVkVPubaxHDft29booGglPFDr2Hw0J1AercRh01UiVFm++KMDnJeH9sHgNB4hsXPii7Sgym/sTbw==",
2720 | "requires": {
2721 | "data-uri-to-buffer": "^4.0.0",
2722 | "fetch-blob": "^3.1.4",
2723 | "formdata-polyfill": "^4.0.10"
2724 | }
2725 | },
2726 | "nodemon": {
2727 | "version": "2.0.16",
2728 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.16.tgz",
2729 | "integrity": "sha512-zsrcaOfTWRuUzBn3P44RDliLlp263Z/76FPoHFr3cFFkOz0lTPAcIw8dCzfdVIx/t3AtDYCZRCDkoCojJqaG3w==",
2730 | "requires": {
2731 | "chokidar": "^3.5.2",
2732 | "debug": "^3.2.7",
2733 | "ignore-by-default": "^1.0.1",
2734 | "minimatch": "^3.0.4",
2735 | "pstree.remy": "^1.1.8",
2736 | "semver": "^5.7.1",
2737 | "supports-color": "^5.5.0",
2738 | "touch": "^3.1.0",
2739 | "undefsafe": "^2.0.5",
2740 | "update-notifier": "^5.1.0"
2741 | },
2742 | "dependencies": {
2743 | "debug": {
2744 | "version": "3.2.7",
2745 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz",
2746 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==",
2747 | "requires": {
2748 | "ms": "^2.1.1"
2749 | }
2750 | },
2751 | "ms": {
2752 | "version": "2.1.3",
2753 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
2754 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
2755 | }
2756 | }
2757 | },
2758 | "nopt": {
2759 | "version": "1.0.10",
2760 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz",
2761 | "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==",
2762 | "requires": {
2763 | "abbrev": "1"
2764 | }
2765 | },
2766 | "normalize-path": {
2767 | "version": "3.0.0",
2768 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
2769 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA=="
2770 | },
2771 | "normalize-url": {
2772 | "version": "4.5.1",
2773 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.1.tgz",
2774 | "integrity": "sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA=="
2775 | },
2776 | "object-inspect": {
2777 | "version": "1.12.2",
2778 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz",
2779 | "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ=="
2780 | },
2781 | "on-finished": {
2782 | "version": "2.4.1",
2783 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz",
2784 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==",
2785 | "requires": {
2786 | "ee-first": "1.1.1"
2787 | }
2788 | },
2789 | "once": {
2790 | "version": "1.4.0",
2791 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
2792 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==",
2793 | "requires": {
2794 | "wrappy": "1"
2795 | }
2796 | },
2797 | "p-cancelable": {
2798 | "version": "1.1.0",
2799 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz",
2800 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw=="
2801 | },
2802 | "package-json": {
2803 | "version": "6.5.0",
2804 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz",
2805 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==",
2806 | "requires": {
2807 | "got": "^9.6.0",
2808 | "registry-auth-token": "^4.0.0",
2809 | "registry-url": "^5.0.0",
2810 | "semver": "^6.2.0"
2811 | },
2812 | "dependencies": {
2813 | "semver": {
2814 | "version": "6.3.0",
2815 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
2816 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw=="
2817 | }
2818 | }
2819 | },
2820 | "parseurl": {
2821 | "version": "1.3.3",
2822 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
2823 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ=="
2824 | },
2825 | "path": {
2826 | "version": "0.12.7",
2827 | "resolved": "https://registry.npmjs.org/path/-/path-0.12.7.tgz",
2828 | "integrity": "sha512-aXXC6s+1w7otVF9UletFkFcDsJeO7lSZBPUQhtb5O0xJe8LtYhj/GxldoL09bBj9+ZmE2hNoHqQSFMN5fikh4Q==",
2829 | "requires": {
2830 | "process": "^0.11.1",
2831 | "util": "^0.10.3"
2832 | }
2833 | },
2834 | "path-to-regexp": {
2835 | "version": "0.1.7",
2836 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
2837 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ=="
2838 | },
2839 | "picomatch": {
2840 | "version": "2.3.1",
2841 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
2842 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA=="
2843 | },
2844 | "prepend-http": {
2845 | "version": "2.0.0",
2846 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz",
2847 | "integrity": "sha512-ravE6m9Atw9Z/jjttRUZ+clIXogdghyZAuWJ3qEzjT+jI/dL1ifAqhZeC5VHzQp1MSt1+jxKkFNemj/iO7tVUA=="
2848 | },
2849 | "process": {
2850 | "version": "0.11.10",
2851 | "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz",
2852 | "integrity": "sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A=="
2853 | },
2854 | "proxy-addr": {
2855 | "version": "2.0.7",
2856 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz",
2857 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==",
2858 | "requires": {
2859 | "forwarded": "0.2.0",
2860 | "ipaddr.js": "1.9.1"
2861 | }
2862 | },
2863 | "pstree.remy": {
2864 | "version": "1.1.8",
2865 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz",
2866 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w=="
2867 | },
2868 | "pump": {
2869 | "version": "3.0.0",
2870 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz",
2871 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==",
2872 | "requires": {
2873 | "end-of-stream": "^1.1.0",
2874 | "once": "^1.3.1"
2875 | }
2876 | },
2877 | "pupa": {
2878 | "version": "2.1.1",
2879 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz",
2880 | "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==",
2881 | "requires": {
2882 | "escape-goat": "^2.0.0"
2883 | }
2884 | },
2885 | "qs": {
2886 | "version": "6.10.3",
2887 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.10.3.tgz",
2888 | "integrity": "sha512-wr7M2E0OFRfIfJZjKGieI8lBKb7fRCH4Fv5KNPEs7gJ8jadvotdsS08PzOKR7opXhZ/Xkjtt3WF9g38drmyRqQ==",
2889 | "requires": {
2890 | "side-channel": "^1.0.4"
2891 | }
2892 | },
2893 | "range-parser": {
2894 | "version": "1.2.1",
2895 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
2896 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg=="
2897 | },
2898 | "raw-body": {
2899 | "version": "2.5.1",
2900 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz",
2901 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==",
2902 | "requires": {
2903 | "bytes": "3.1.2",
2904 | "http-errors": "2.0.0",
2905 | "iconv-lite": "0.4.24",
2906 | "unpipe": "1.0.0"
2907 | }
2908 | },
2909 | "rc": {
2910 | "version": "1.2.8",
2911 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz",
2912 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==",
2913 | "requires": {
2914 | "deep-extend": "^0.6.0",
2915 | "ini": "~1.3.0",
2916 | "minimist": "^1.2.0",
2917 | "strip-json-comments": "~2.0.1"
2918 | },
2919 | "dependencies": {
2920 | "ini": {
2921 | "version": "1.3.8",
2922 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz",
2923 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew=="
2924 | }
2925 | }
2926 | },
2927 | "readdirp": {
2928 | "version": "3.6.0",
2929 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
2930 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
2931 | "requires": {
2932 | "picomatch": "^2.2.1"
2933 | }
2934 | },
2935 | "registry-auth-token": {
2936 | "version": "4.2.2",
2937 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.2.tgz",
2938 | "integrity": "sha512-PC5ZysNb42zpFME6D/XlIgtNGdTl8bBOCw90xQLVMpzuuubJKYDWFAEuUNc+Cn8Z8724tg2SDhDRrkVEsqfDMg==",
2939 | "requires": {
2940 | "rc": "1.2.8"
2941 | }
2942 | },
2943 | "registry-url": {
2944 | "version": "5.1.0",
2945 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz",
2946 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==",
2947 | "requires": {
2948 | "rc": "^1.2.8"
2949 | }
2950 | },
2951 | "responselike": {
2952 | "version": "1.0.2",
2953 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz",
2954 | "integrity": "sha512-/Fpe5guzJk1gPqdJLJR5u7eG/gNY4nImjbRDaVWVMRhne55TCmj2i9Q+54PBRfatRC8v/rIiv9BN0pMd9OV5EQ==",
2955 | "requires": {
2956 | "lowercase-keys": "^1.0.0"
2957 | }
2958 | },
2959 | "safe-buffer": {
2960 | "version": "5.2.1",
2961 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
2962 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ=="
2963 | },
2964 | "safer-buffer": {
2965 | "version": "2.1.2",
2966 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
2967 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
2968 | },
2969 | "semver": {
2970 | "version": "5.7.1",
2971 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
2972 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ=="
2973 | },
2974 | "semver-diff": {
2975 | "version": "3.1.1",
2976 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz",
2977 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==",
2978 | "requires": {
2979 | "semver": "^6.3.0"
2980 | },
2981 | "dependencies": {
2982 | "semver": {
2983 | "version": "6.3.0",
2984 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
2985 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw=="
2986 | }
2987 | }
2988 | },
2989 | "send": {
2990 | "version": "0.18.0",
2991 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz",
2992 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==",
2993 | "requires": {
2994 | "debug": "2.6.9",
2995 | "depd": "2.0.0",
2996 | "destroy": "1.2.0",
2997 | "encodeurl": "~1.0.2",
2998 | "escape-html": "~1.0.3",
2999 | "etag": "~1.8.1",
3000 | "fresh": "0.5.2",
3001 | "http-errors": "2.0.0",
3002 | "mime": "1.6.0",
3003 | "ms": "2.1.3",
3004 | "on-finished": "2.4.1",
3005 | "range-parser": "~1.2.1",
3006 | "statuses": "2.0.1"
3007 | },
3008 | "dependencies": {
3009 | "ms": {
3010 | "version": "2.1.3",
3011 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
3012 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
3013 | }
3014 | }
3015 | },
3016 | "serve-static": {
3017 | "version": "1.15.0",
3018 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz",
3019 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==",
3020 | "requires": {
3021 | "encodeurl": "~1.0.2",
3022 | "escape-html": "~1.0.3",
3023 | "parseurl": "~1.3.3",
3024 | "send": "0.18.0"
3025 | }
3026 | },
3027 | "setprototypeof": {
3028 | "version": "1.2.0",
3029 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz",
3030 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw=="
3031 | },
3032 | "side-channel": {
3033 | "version": "1.0.4",
3034 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz",
3035 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==",
3036 | "requires": {
3037 | "call-bind": "^1.0.0",
3038 | "get-intrinsic": "^1.0.2",
3039 | "object-inspect": "^1.9.0"
3040 | }
3041 | },
3042 | "signal-exit": {
3043 | "version": "3.0.7",
3044 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz",
3045 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ=="
3046 | },
3047 | "statuses": {
3048 | "version": "2.0.1",
3049 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
3050 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ=="
3051 | },
3052 | "string-width": {
3053 | "version": "4.2.3",
3054 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
3055 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
3056 | "requires": {
3057 | "emoji-regex": "^8.0.0",
3058 | "is-fullwidth-code-point": "^3.0.0",
3059 | "strip-ansi": "^6.0.1"
3060 | }
3061 | },
3062 | "strip-ansi": {
3063 | "version": "6.0.1",
3064 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
3065 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
3066 | "requires": {
3067 | "ansi-regex": "^5.0.1"
3068 | }
3069 | },
3070 | "strip-json-comments": {
3071 | "version": "2.0.1",
3072 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz",
3073 | "integrity": "sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ=="
3074 | },
3075 | "supports-color": {
3076 | "version": "5.5.0",
3077 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
3078 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
3079 | "requires": {
3080 | "has-flag": "^3.0.0"
3081 | }
3082 | },
3083 | "to-readable-stream": {
3084 | "version": "1.0.0",
3085 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz",
3086 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q=="
3087 | },
3088 | "to-regex-range": {
3089 | "version": "5.0.1",
3090 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
3091 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
3092 | "requires": {
3093 | "is-number": "^7.0.0"
3094 | }
3095 | },
3096 | "toidentifier": {
3097 | "version": "1.0.1",
3098 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz",
3099 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA=="
3100 | },
3101 | "touch": {
3102 | "version": "3.1.0",
3103 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz",
3104 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==",
3105 | "requires": {
3106 | "nopt": "~1.0.10"
3107 | }
3108 | },
3109 | "type-fest": {
3110 | "version": "0.20.2",
3111 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz",
3112 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ=="
3113 | },
3114 | "type-is": {
3115 | "version": "1.6.18",
3116 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
3117 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
3118 | "requires": {
3119 | "media-typer": "0.3.0",
3120 | "mime-types": "~2.1.24"
3121 | }
3122 | },
3123 | "typedarray-to-buffer": {
3124 | "version": "3.1.5",
3125 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz",
3126 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==",
3127 | "requires": {
3128 | "is-typedarray": "^1.0.0"
3129 | }
3130 | },
3131 | "undefsafe": {
3132 | "version": "2.0.5",
3133 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz",
3134 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA=="
3135 | },
3136 | "unique-string": {
3137 | "version": "2.0.0",
3138 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz",
3139 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==",
3140 | "requires": {
3141 | "crypto-random-string": "^2.0.0"
3142 | }
3143 | },
3144 | "unpipe": {
3145 | "version": "1.0.0",
3146 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
3147 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ=="
3148 | },
3149 | "update-notifier": {
3150 | "version": "5.1.0",
3151 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-5.1.0.tgz",
3152 | "integrity": "sha512-ItnICHbeMh9GqUy31hFPrD1kcuZ3rpxDZbf4KUDavXwS0bW5m7SLbDQpGX3UYr072cbrF5hFUs3r5tUsPwjfHw==",
3153 | "requires": {
3154 | "boxen": "^5.0.0",
3155 | "chalk": "^4.1.0",
3156 | "configstore": "^5.0.1",
3157 | "has-yarn": "^2.1.0",
3158 | "import-lazy": "^2.1.0",
3159 | "is-ci": "^2.0.0",
3160 | "is-installed-globally": "^0.4.0",
3161 | "is-npm": "^5.0.0",
3162 | "is-yarn-global": "^0.3.0",
3163 | "latest-version": "^5.1.0",
3164 | "pupa": "^2.1.1",
3165 | "semver": "^7.3.4",
3166 | "semver-diff": "^3.1.1",
3167 | "xdg-basedir": "^4.0.0"
3168 | },
3169 | "dependencies": {
3170 | "semver": {
3171 | "version": "7.3.7",
3172 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz",
3173 | "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==",
3174 | "requires": {
3175 | "lru-cache": "^6.0.0"
3176 | }
3177 | }
3178 | }
3179 | },
3180 | "url-parse-lax": {
3181 | "version": "3.0.0",
3182 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz",
3183 | "integrity": "sha512-NjFKA0DidqPa5ciFcSrXnAltTtzz84ogy+NebPvfEgAck0+TNg4UJ4IN+fB7zRZfbgUf0syOo9MDxFkDSMuFaQ==",
3184 | "requires": {
3185 | "prepend-http": "^2.0.0"
3186 | }
3187 | },
3188 | "util": {
3189 | "version": "0.10.4",
3190 | "resolved": "https://registry.npmjs.org/util/-/util-0.10.4.tgz",
3191 | "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==",
3192 | "requires": {
3193 | "inherits": "2.0.3"
3194 | },
3195 | "dependencies": {
3196 | "inherits": {
3197 | "version": "2.0.3",
3198 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
3199 | "integrity": "sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw=="
3200 | }
3201 | }
3202 | },
3203 | "utils-merge": {
3204 | "version": "1.0.1",
3205 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
3206 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA=="
3207 | },
3208 | "vary": {
3209 | "version": "1.1.2",
3210 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
3211 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg=="
3212 | },
3213 | "web-streams-polyfill": {
3214 | "version": "3.2.1",
3215 | "resolved": "https://registry.npmjs.org/web-streams-polyfill/-/web-streams-polyfill-3.2.1.tgz",
3216 | "integrity": "sha512-e0MO3wdXWKrLbL0DgGnUV7WHVuw9OUvL4hjgnPkIeEvESk74gAITi5G606JtZPp39cd8HA9VQzCIvA49LpPN5Q=="
3217 | },
3218 | "widest-line": {
3219 | "version": "3.1.0",
3220 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz",
3221 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==",
3222 | "requires": {
3223 | "string-width": "^4.0.0"
3224 | }
3225 | },
3226 | "wrap-ansi": {
3227 | "version": "7.0.0",
3228 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
3229 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
3230 | "requires": {
3231 | "ansi-styles": "^4.0.0",
3232 | "string-width": "^4.1.0",
3233 | "strip-ansi": "^6.0.0"
3234 | }
3235 | },
3236 | "wrappy": {
3237 | "version": "1.0.2",
3238 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
3239 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ=="
3240 | },
3241 | "write-file-atomic": {
3242 | "version": "3.0.3",
3243 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz",
3244 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==",
3245 | "requires": {
3246 | "imurmurhash": "^0.1.4",
3247 | "is-typedarray": "^1.0.0",
3248 | "signal-exit": "^3.0.2",
3249 | "typedarray-to-buffer": "^3.1.5"
3250 | }
3251 | },
3252 | "xdg-basedir": {
3253 | "version": "4.0.0",
3254 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz",
3255 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q=="
3256 | },
3257 | "yallist": {
3258 | "version": "4.0.0",
3259 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
3260 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A=="
3261 | }
3262 | }
3263 | }
3264 |
--------------------------------------------------------------------------------
/frontend/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "frontend",
3 | "version": "1.0.0",
4 | "description": "",
5 | "main": "index.js",
6 | "scripts": {
7 | "start": "nodemon index.js"
8 | },
9 | "keywords": [],
10 | "author": "",
11 | "license": "ISC",
12 | "dependencies": {
13 | "cookie-parser": "^1.4.6",
14 | "dotenv": "^16.0.1",
15 | "express": "^4.18.1",
16 | "node-fetch": "^3.2.6",
17 | "nodemon": "^2.0.16",
18 | "path": "^0.12.7"
19 | }
20 | }
21 |
--------------------------------------------------------------------------------
/frontend/routes/auth/login.js:
--------------------------------------------------------------------------------
1 | const express = require('express');
2 | const cookie = require('cookie');
3 | const fetch = (...args) =>
4 | import('node-fetch').then(({ default: fetch }) => fetch(...args));
5 |
6 | const router = express.Router();
7 |
8 | router.post('/api/users/login', async (req, res) => {
9 | const { email, password } = req.body;
10 |
11 | const body = JSON.stringify({ email, password });
12 |
13 | try {
14 | const apiRes = await fetch(`${process.env.API_URL}/api/token/`, {
15 | method: 'POST',
16 | headers: {
17 | Accept: 'application/json',
18 | 'Content-Type': 'application/json',
19 | },
20 | body,
21 | });
22 |
23 | const data = await apiRes.json();
24 |
25 | if (apiRes.status === 200) {
26 | res.setHeader('Set-Cookie', [
27 | cookie.serialize('access', data.access, {
28 | httpOnly: true,
29 | maxAge: 60 * 30,
30 | path: '/api/',
31 | sameSite: 'strict',
32 | secure: process.env.NODE_ENV === 'production',
33 | }),
34 | cookie.serialize('refresh', data.refresh, {
35 | httpOnly: true,
36 | maxAge: 60 * 60 * 24,
37 | path: '/api/',
38 | sameSite: 'strict',
39 | secure: process.env.NODE_ENV === 'production',
40 | }),
41 | ]);
42 |
43 | return res.status(200).json({ success: 'Logged in successfully' });
44 | } else {
45 | return res.status(apiRes.status).json(data);
46 | }
47 | } catch (err) {
48 | return res.status(500).json({
49 | error: 'Something went wrong when logging in',
50 | });
51 | }
52 | });
53 |
54 | module.exports = router;
55 |
--------------------------------------------------------------------------------
/frontend/routes/auth/logout.js:
--------------------------------------------------------------------------------
1 | const express = require('express');
2 | const cookie = require('cookie');
3 |
4 | const router = express.Router();
5 |
6 | router.get('/api/users/logout', (req, res) => {
7 | res.setHeader('Set-Cookie', [
8 | cookie.serialize('access', '', {
9 | httpOnly: true,
10 | expires: new Date(0),
11 | path: '/api/',
12 | sameSite: 'strict',
13 | secure: process.env.NODE_ENV === 'production',
14 | }),
15 | cookie.serialize('refresh', '', {
16 | httpOnly: true,
17 | expires: new Date(0),
18 | path: '/api/',
19 | sameSite: 'strict',
20 | secure: process.env.NODE_ENV === 'production',
21 | }),
22 | ]);
23 |
24 | return res.status(200).json({ success: 'Logged out successfully' });
25 | });
26 |
27 | module.exports = router;
28 |
--------------------------------------------------------------------------------
/frontend/routes/auth/me.js:
--------------------------------------------------------------------------------
1 | const express = require('express');
2 | const fetch = (...args) =>
3 | import('node-fetch').then(({ default: fetch }) => fetch(...args));
4 |
5 | const router = express.Router();
6 |
7 | router.get('/api/users/me', async (req, res) => {
8 | const { access } = req.cookies;
9 |
10 | try {
11 | const apiRes = await fetch(`${process.env.API_URL}/api/users/me`, {
12 | method: 'GET',
13 | headers: {
14 | Accept: 'application/json',
15 | Authorization: `Bearer ${access}`,
16 | },
17 | });
18 |
19 | const data = await apiRes.json();
20 |
21 | return res.status(apiRes.status).json(data);
22 | } catch (err) {
23 | return res.status(500).json({
24 | error: 'Something went wrong when trying to retrieve user',
25 | });
26 | }
27 | });
28 |
29 | module.exports = router;
30 |
--------------------------------------------------------------------------------
/frontend/routes/auth/register.js:
--------------------------------------------------------------------------------
1 | const express = require('express');
2 | const fetch = (...args) =>
3 | import('node-fetch').then(({ default: fetch }) => fetch(...args));
4 |
5 | const router = express.Router();
6 |
7 | router.post('/api/users/register', async (req, res) => {
8 | const { first_name, last_name, email, password } = req.body;
9 |
10 | const body = JSON.stringify({
11 | first_name,
12 | last_name,
13 | email,
14 | password,
15 | });
16 |
17 | try {
18 | const apiRes = await fetch(`${process.env.API_URL}/api/users/register`, {
19 | method: 'POST',
20 | headers: {
21 | Accept: 'application/json',
22 | 'Content-Type': 'application/json',
23 | },
24 | body,
25 | });
26 |
27 | const data = await apiRes.json();
28 |
29 | return res.status(apiRes.status).json(data);
30 | } catch (err) {
31 | return res.status(500).json({
32 | error: 'Something went wrong when registering account',
33 | });
34 | }
35 | });
36 |
37 | module.exports = router;
38 |
--------------------------------------------------------------------------------
/frontend/routes/auth/verify.js:
--------------------------------------------------------------------------------
1 | const express = require('express');
2 | const fetch = (...args) =>
3 | import('node-fetch').then(({ default: fetch }) => fetch(...args));
4 |
5 | const router = express.Router();
6 |
7 | router.get('/api/users/verify', async (req, res) => {
8 | const { access } = req.cookies;
9 |
10 | const body = JSON.stringify({
11 | token: access,
12 | });
13 |
14 | try {
15 | const apiRes = await fetch(`${process.env.API_URL}/api/token/verify/`, {
16 | method: 'POST',
17 | headers: {
18 | Accept: 'application/json',
19 | 'Content-Type': 'application/json',
20 | },
21 | body,
22 | });
23 |
24 | const data = await apiRes.json();
25 |
26 | return res.status(apiRes.status).json(data);
27 | } catch (err) {
28 | return res.status(500).json({
29 | error: 'Something went wrong when trying to verify login status',
30 | });
31 | }
32 | });
33 |
34 | module.exports = router;
35 |
--------------------------------------------------------------------------------