├── 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 |
    40 |
    41 | 44 | 52 |
    53 |
    54 | 57 | 65 |
    66 | {loading ? ( 67 |
    68 | Loading... 69 |
    70 | ) : ( 71 | 72 | )} 73 |
    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 |
    36 |
    37 | 40 | 48 |
    49 |
    50 | 53 | 61 |
    62 |
    63 | 66 | 74 |
    75 |
    76 | 79 | 87 |
    88 | {loading ? ( 89 |
    90 | Loading... 91 |
    92 | ) : ( 93 | 94 | )} 95 |
    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 | --------------------------------------------------------------------------------