├── .eslintrc.js ├── .gitignore ├── LICENSE ├── README.md ├── components ├── auth │ ├── Auth.tsx │ └── index.ts ├── content │ └── Content.tsx ├── dashboard │ ├── Dashboard.tsx │ └── index.ts ├── shell │ ├── Shell.tsx │ ├── index.ts │ ├── navBar │ │ ├── NavBar.tsx │ │ ├── NavBarOptions.tsx │ │ └── index.ts │ └── sideNav │ │ └── SideNav.tsx ├── splash │ ├── Splash.tsx │ └── index.ts └── svg │ ├── ChartPieSvg.tsx │ ├── CogSvg.tsx │ ├── FireSvg.tsx │ ├── GitHubSvg.tsx │ ├── MessagesSvg.tsx │ ├── SignOutSvg.tsx │ ├── UsersSvg.tsx │ └── index.ts ├── firebase.json ├── firebase ├── adminApp.ts ├── auth │ ├── auth.tsx │ └── utils.tsx └── clientApp.ts ├── functions ├── .gitignore ├── package-lock.json ├── package.json ├── src │ └── index.ts └── tsconfig.json ├── images ├── hero.png └── svg │ └── logo.svg ├── next-env.d.ts ├── next.config.js ├── package-lock.json ├── package.json ├── pages ├── _app.tsx ├── index.tsx ├── login.tsx ├── messages.tsx ├── settings.tsx └── users.tsx ├── postcss.config.js ├── public └── favicon.ico ├── sample.env.local ├── styles ├── Home.module.css └── globals.css ├── tailwind.config.js ├── tsconfig.json └── utils ├── genericUtils.tsx └── hooks └── useLocalStorage.ts /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | browser: true, 4 | es2021: true, 5 | node: true, 6 | }, 7 | extends: [ 8 | "eslint:recommended", 9 | "plugin:react/recommended", 10 | "plugin:@typescript-eslint/recommended", 11 | "plugin:@next/next/recommended", 12 | ], 13 | parser: "@typescript-eslint/parser", 14 | parserOptions: { 15 | ecmaFeatures: { 16 | jsx: true, 17 | }, 18 | ecmaVersion: "latest", 19 | sourceType: "module", 20 | }, 21 | plugins: ["react", "@typescript-eslint"], 22 | rules: {}, 23 | }; 24 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # dependencies 2 | /node_modules 3 | /.pnp 4 | .pnp.js 5 | 6 | # testing 7 | /coverage 8 | 9 | # next.js 10 | /.next/ 11 | /out/ 12 | 13 | # production 14 | /build 15 | 16 | # 😡 17 | .DS_Store 18 | *.pem 19 | 20 | # debug 21 | npm-debug.log* 22 | yarn-debug.log* 23 | yarn-error.log* 24 | 25 | # local env files 26 | .env.local 27 | .env.development.local 28 | .env.test.local 29 | .env.production.local 30 | 31 | # vercel 32 | .vercel 33 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Copyright 2022 Jason Ahern 2 | 3 | Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: 4 | 5 | The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. 6 | 7 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 8 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Next Firebase Typescript Template 2 | 3 | An app template for using Next.js with Firebase and Typescript! 4 | 5 | ## Demo: [next-firebase-ts.vercel.app](https://next-firebase-ts.vercel.app) 6 | 7 | ## Project Overview / Technologies 8 | 9 | - Framework: [Next.js](https://nextjs.org/) (which uses [React](https://reactjs.org)) 10 | - Authentication and Database: [Firebase](https://firebase.google.com/) 11 | - Firebase makes secure authentication almost trivial, providing simple APIs and CLIs with minimal boilerplate 12 | - Firebase also provides handy UI components for sign-in with [FirebaseUI](https://firebase.google.com/docs/auth/web/firebaseui) 13 | - Some server-side authentication which makes use of [Nookies](https://www.npmjs.com/package/nookies) 14 | - Optional use of serverless Firebase [Cloud Functions](https://firebase.google.com/products/functions) 15 | - Language: [Typescript](https://www.typescriptlang.org/) 16 | - Styles: [Tailwind](https://tailwindcss.com/) 17 | - Also [Headless UI](https://headlessui.dev/), a handy set of styled UI components atop Tailwind 18 | - Hosting and CD: [Vercel](https://vercel.com/) 19 | 20 | --- 21 | 22 | ## Getting Started 23 | 24 | Start by forking the repository (since it is a template, click the **_Use this template_** button on the repo) 25 | 26 | ### I. ⚙️ Local Setup 27 | 28 | 1. Navigate to the project you forked and in a terminal run `npm i` 29 | 2. Copy or rename the file `sample.env.local` to `.env.local` for an environmental variable template 30 | 31 | --- 32 | 33 | ### II. 🔥 Firebase General Setup 34 | 35 | 1. Create a [Firebase](https://console.firebase.google.com) project and web app 36 | - You can choose whether to allow analytics. Analytics are not currently implemented in this template. 37 | - Add a web app to the project. Do not check the _"add Firebase hosting"_ box 38 | 2. Copy the config strings in the SDK setup (apiKey, authDomain, ...) into their corresponding entries in your `.env.local` file 39 | - Otherwise, you can ignore this part. We already installed the SDK in step I.1, and we are putting our config strings in the environment variables, instead of explicitly in the code 40 | 3. In the Firebase console, go to Project Settings > Service accounts. Here we will fill the remaining entries in our environment variables file 41 | 1. Copy the Firebase service account string (starting in _"firebase-adminsdk"_) into the `FIREBASE_CLIENT_EMAIL` env entry 42 | 2. Click the button to generate and download a new application private key. This will download a JSON file to your machine 43 | 3. Open the JSON file. We are only interested in the pair with name `"private_key"`. Copy the _entire value_ of the key 44 | 4. Paste the key into the `FIREBASE_PRIVATE_KEY` environment variable entry. The key should be surrounded with both double and single quotes, as displayed in the template. i.e. '"-----BEGIN PRIVATE KEY..."' Just trust me on this one 😉 45 | 4. Enable the Firestore Database 46 | 47 | --- 48 | 49 | ### III. 🔒 Firebase Authentication Setup 50 | 51 | The template supports authentication by Google, GitHub, and Email/Password. You can easily add more if you wish. More details later. 52 | 53 | 1. Enable authentication on the Authentication tab of the Firebase console 54 | 2. Add Google as the first authentication method. Accept the defaults or play with them if you'd like. This can be done entirely from the Firebase console 55 | 3. Add Email/Password as a new authentication provider. This can be done entirely from the Firebase console 56 | 4. Add GitHub as an authentication provider. This one is a bit more complicated 57 | 1. In the Firebase console, begin adding GitHub by sliding the _"Enable"_ slider 58 | 2. Navigate to [GitHub](https://github.com/) > Settings > Developer settings > [OAuth Apps](https://github.com/settings/developers) 59 | 3. Add a new auth app, with a distinguishable name. The Homepage URL can simply be `https://localhost:8080` 60 | 4. Copy the callback URL from the bottom of the Firebase GitHub auth config page into the entry on GitHub. click Register Application 61 | 5. Copy the Client ID displayed on the new GitHub page to the appropriate entry in Firebase 62 | 6. Generate a new client secret with the GitHub OAuth app, and copy that into Firebase as well 63 | 7. Finish the GitHub auth configuration by clicking save 64 | 65 | #### Using different auth providers 66 | 67 | 1. First configure the auth providers you want to use in the Firebase console. [Documentation](https://firebase.google.com/docs/auth) 68 | 2. The application displays the auth providers on the /login page specified by the `uiConfig` object in `components/auth/Auth.tsx`. Edit the `signInOptions` to have the app reflect the auth options you prefer. [FirebaseUI Documentation](https://firebase.google.com/docs/auth/web/firebaseui) 69 | 70 | --- 71 | 72 | **Note:** at this point, you have full local functionality of your app! To locally host your app, enter `npm run dev` on the terminal, and navigate to [localhost:8080](https://localhost:8080) in your browser 73 | 74 | --- 75 | 76 | ### IV. 🚀 Vercel Deployment Setup 77 | 78 | 1. Create a new hobby [Vercel](https://vercel.com/) account, and link your GitHub (or whichever Git provider application you are using) account 79 | 2. Create a new project, and link your project in the "Input Git Repository" step 80 | 3. The default configurations should work for you. Don't click Deploy yet! 81 | 4. In the Environment Variables dropdown, add all of the name/value pairs in your `.env.local` file 82 | > **Note:** for the `FIREBASE_PRIVATE_KEY`, _omit the single quotes!_ So the string should only be wrapped in double quotes. i.e. "-----BEGIN PRIVATE KEY..." 83 | 5. Now you are ready to deploy your app! 84 | 85 | --- 86 | 87 | ### V. ☁️ Optional: Firebase Cloud Function Setup 88 | 89 | The Firebase Spark plan (free tier) does not support Cloud Functions. You'll have to upgrade to the Blaze pay as you go plan before integrating with Firebase Cloud Functions. 90 | 91 | > Note that you have 2M cloud function invocations, so for a hobby app, you likely won't have to worry about paying anything. [Pricing Details](https://firebase.google.com/pricing) 92 | 93 | This template contains a simple use case of cloud functions, which adds a user entry to the Firestore database whenever a new user is authenticated with our app. 94 | 95 | 1. Upgrade your Firebase account to the Blaze plan 96 | 2. Download and install the [Firebase CLI](https://firebase.google.com/docs/cli) 97 | 3. Log into the Firebase CLI with `firebase login` in your shell. (again see [documentation](https://firebase.google.com/docs/cli#sign-in-test-cli)) 98 | 4. To deploy your Cloud Functions, simply run `firebase deploy --project `. Alternatively, you can create a `.firebaserc` file in your project's top-level directory (sample below) and then simply run `firebase deploy` from within that directory. 99 | 100 | **`.firebaserc:`** 101 | 102 | ``` 103 | { 104 | "projects": { 105 | "default": "next-firebase-typescript" 106 | } 107 | } 108 | ``` 109 | 110 | --- 111 | 112 | ## Acknowledgements and Resources 113 | 114 | I used plenty of handy resources to help me understand how the different Next.js and Firebase pieces fit together. Here are a few I used to get started: 115 | 116 | - Jarrod Watts's [NextJS + Firebase Tutorial](https://github.com/jarrodwatts/pineapple) 117 | - Shreyas Jadhav's [next-firebase-starter](https://github.com/shreyas-jadhav/next-firebase-starter) 118 | 119 | ### Additional Documentation 120 | 121 | - [Next.js docs](https://nextjs.org/docs) 122 | - [Firebase docs](https://firebase.google.com/docs) 123 | - [Tailwind docs](https://tailwindcss.com/docs/) 124 | - [Vercel docs](https://vercel.com/docs) 125 | -------------------------------------------------------------------------------- /components/auth/Auth.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import StyledFirebaseAuth from "react-firebaseui/StyledFirebaseAuth"; 3 | import firebase from "../../firebase/clientApp"; 4 | 5 | // Configure FirebaseUI. 6 | const uiConfig = { 7 | // Redirect to / after sign in is successful. Alternatively you can provide a callbacks.signInSuccess function. 8 | signInSuccessUrl: "/", 9 | // We will display GitHub as auth providers. 10 | signInOptions: [ 11 | firebase.auth.GoogleAuthProvider.PROVIDER_ID, 12 | firebase.auth.GithubAuthProvider.PROVIDER_ID, 13 | firebase.auth.EmailAuthProvider.PROVIDER_ID, 14 | ], 15 | }; 16 | 17 | function SignInScreen() { 18 | return ( 19 |
20 |
21 |
22 | Sign in or create a new account 23 |
24 |
25 | 29 |
30 |
31 |
32 | ); 33 | } 34 | 35 | export default SignInScreen; 36 | -------------------------------------------------------------------------------- /components/auth/index.ts: -------------------------------------------------------------------------------- 1 | import Auth from "./Auth"; 2 | 3 | export default Auth; 4 | -------------------------------------------------------------------------------- /components/content/Content.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | 3 | type Props = { 4 | title: string; 5 | children: JSX.Element; 6 | }; 7 | 8 | export default function Content({ title, children }: Props) { 9 | return ( 10 |
11 |
12 | {title} 13 |
14 |
{children}
15 |
16 | ); 17 | } 18 | -------------------------------------------------------------------------------- /components/dashboard/Dashboard.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import Shell from "../shell"; 3 | import Content from "../content/Content"; 4 | 5 | export default function Dashboard() { 6 | return ( 7 | <> 8 | 9 | 10 | <>Dashboard 11 | 12 | 13 | 14 | ); 15 | } 16 | -------------------------------------------------------------------------------- /components/dashboard/index.ts: -------------------------------------------------------------------------------- 1 | import Dashboard from "./Dashboard"; 2 | 3 | export default Dashboard; 4 | -------------------------------------------------------------------------------- /components/shell/Shell.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import NavBar from "./navBar"; 3 | import SideNav from "./sideNav/SideNav"; 4 | 5 | type Props = { 6 | children: JSX.Element; 7 | }; 8 | 9 | export default function Shell({ children }: Props) { 10 | return ( 11 | <> 12 |
13 | 14 |
{children}
15 |
16 |
17 | 18 |
{children}
19 |
20 | 21 | ); 22 | } 23 | -------------------------------------------------------------------------------- /components/shell/index.ts: -------------------------------------------------------------------------------- 1 | import Shell from "./Shell"; 2 | 3 | export default Shell; 4 | -------------------------------------------------------------------------------- /components/shell/navBar/NavBar.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import { Transition } from "@headlessui/react"; 3 | import { useState } from "react"; 4 | import NavBarOptions from "./NavBarOptions"; 5 | import LogoSvg from "../../../images/svg/logo.svg"; 6 | 7 | export default function NavBar() { 8 | const [isOpen, setIsOpen] = useState(false); 9 | return ( 10 | <> 11 | 83 | 84 | ); 85 | } 86 | -------------------------------------------------------------------------------- /components/shell/navBar/NavBarOptions.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import Svg from "../../svg"; 3 | import Link from "next/link"; 4 | import { useRouter } from "next/router"; 5 | import { signOut } from "../../../utils/genericUtils"; 6 | 7 | type Props = { 8 | /** Whether the navbar options are appearing on a small screen, or a collapsed navbar */ 9 | smallScreen?: boolean; 10 | expanded?: boolean; 11 | }; 12 | 13 | export default function NavBarOptions({ 14 | smallScreen = false, 15 | expanded = true, 16 | }: Props) { 17 | return ( 18 | <> 19 | } 22 | title="Dashboard" 23 | expanded={expanded} 24 | /> 25 | } 28 | title="Users" 29 | expanded={expanded} 30 | /> 31 | } 34 | title="Messages" 35 | expanded={expanded} 36 | /> 37 | {smallScreen && ( 38 | <> 39 | } title="Settings" /> 40 | 44 | {} 45 |
Sign Out
46 |
47 | 48 | )} 49 | 50 | ); 51 | } 52 | 53 | type NavItemProps = { 54 | link: string; 55 | svgIcon: JSX.Element; 56 | title: string; 57 | expanded?: boolean; 58 | }; 59 | 60 | const NavItem = ({ link, svgIcon, title, expanded = true }: NavItemProps) => { 61 | const router = useRouter(); 62 | return ( 63 | 64 | 69 | {svgIcon} 70 | {expanded &&
{title}
} 71 |
72 | 73 | ); 74 | }; 75 | 76 | const isActivePage = (link: string, pathName: string) => { 77 | return pathName.toLowerCase() === link.toLowerCase(); 78 | }; 79 | -------------------------------------------------------------------------------- /components/shell/navBar/index.ts: -------------------------------------------------------------------------------- 1 | import NavBar from "./NavBar"; 2 | 3 | export default NavBar; 4 | -------------------------------------------------------------------------------- /components/shell/sideNav/SideNav.tsx: -------------------------------------------------------------------------------- 1 | import React, { createContext, useContext } from "react"; 2 | import Svg from "../../svg/"; 3 | import NavBarOptions from "../navBar/NavBarOptions"; 4 | import Link from "next/link"; 5 | import { signOut } from "../../../utils/genericUtils"; 6 | import LogoSvg from "../../../images/svg/logo.svg"; 7 | import GitHubSvg from "../../svg/GitHubSvg"; 8 | import useLocalStorage from "../../../utils/hooks/useLocalStorage"; 9 | 10 | const CollapsedContext = createContext(false); 11 | 12 | export default function SideNav() { 13 | const [expanded, setExpanded] = useLocalStorage("collapsed", false); 14 | 15 | return ( 16 | 17 |
18 | 19 | 20 | 21 |
22 |
23 | ); 24 | } 25 | 26 | const SideNavHeader = () => { 27 | const collapsed = useContext(CollapsedContext); 28 | 29 | return ( 30 | 38 | ); 39 | }; 40 | 41 | const SideNavMenu = () => { 42 | const collapsed = useContext(CollapsedContext); 43 | 44 | return ( 45 | 48 | ); 49 | }; 50 | 51 | type sideNavFooterProps = { 52 | setExpanded: (expanded: boolean) => void; 53 | }; 54 | 55 | const SideNavFooter = ({ setExpanded }: sideNavFooterProps) => { 56 | const collapsed = useContext(CollapsedContext); 57 | return ( 58 | <> 59 | 60 | 61 | 62 | {!collapsed &&
Settings
} 63 |
64 | 65 | 70 | 71 | {!collapsed &&
Sign Out
} 72 |
73 |
74 |
75 |
76 | 81 | 82 | 83 |
84 |
85 | 93 |
94 |
95 | 96 | ); 97 | }; 98 | -------------------------------------------------------------------------------- /components/splash/Splash.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import Link from "next/link"; 3 | import Image from "next/image"; 4 | import hero from "../../images/hero.png"; 5 | import LogoSvg from "../../images/svg/logo.svg"; 6 | import GitHubSvg from "../svg/GitHubSvg"; 7 | 8 | export default function Splash() { 9 | return ( 10 | <> 11 |
12 |
13 |
14 |
15 | 16 |
My App
17 |
18 | 19 |
20 |
21 | 26 | 27 | 28 |
29 | 30 | 31 | 32 | 35 | 36 | 37 |
38 |
39 |
40 | 41 |
42 |
43 |

44 | Main Hero message to sell your app 45 |

46 |

47 | Sub-hero message, not too long and not too short. Make it just 48 | right! 49 |

50 |
51 | 52 |
53 | 54 |
55 |
56 |
57 | © My App 2022 58 |
59 |
60 |
61 |
62 | 63 | ); 64 | } 65 | -------------------------------------------------------------------------------- /components/splash/index.ts: -------------------------------------------------------------------------------- 1 | import Splash from "./Splash"; 2 | 3 | export default Splash; 4 | -------------------------------------------------------------------------------- /components/svg/ChartPieSvg.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | 3 | export default function ChartPieSvg() { 4 | return ( 5 | 11 | 12 | 13 | 14 | ); 15 | } 16 | -------------------------------------------------------------------------------- /components/svg/CogSvg.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | 3 | export default function CogSvg() { 4 | return ( 5 | 11 | 16 | 17 | ); 18 | } 19 | -------------------------------------------------------------------------------- /components/svg/FireSvg.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | 3 | export default function FireSvg() { 4 | return ( 5 | 12 | 18 | 24 | 25 | ); 26 | } 27 | -------------------------------------------------------------------------------- /components/svg/GitHubSvg.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | 3 | export default function GitHubSvg() { 4 | return ( 5 | 11 | 12 | 13 | ); 14 | } 15 | -------------------------------------------------------------------------------- /components/svg/MessagesSvg.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | 3 | export default function MessagesSvg() { 4 | return ( 5 | 11 | 19 | 20 | ); 21 | } 22 | -------------------------------------------------------------------------------- /components/svg/SignOutSvg.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | 3 | export default function SignOutSvg() { 4 | return ( 5 | 11 | 12 | 13 | ); 14 | } 15 | -------------------------------------------------------------------------------- /components/svg/UsersSvg.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | 3 | export default function UsersSvg() { 4 | return ( 5 | 11 | 12 | 13 | ); 14 | } 15 | -------------------------------------------------------------------------------- /components/svg/index.ts: -------------------------------------------------------------------------------- 1 | import ChartPieSvg from "./ChartPieSvg"; 2 | import CogSvg from "./CogSvg"; 3 | import FireSvg from "./FireSvg"; 4 | import UsersSvg from "./UsersSvg"; 5 | import SignOutSvg from "./SignOutSvg"; 6 | import MessagesSvg from "./MessagesSvg"; 7 | export default { 8 | ChartPieSvg, 9 | CogSvg, 10 | FireSvg, 11 | UsersSvg, 12 | SignOutSvg, 13 | MessagesSvg, 14 | }; 15 | -------------------------------------------------------------------------------- /firebase.json: -------------------------------------------------------------------------------- 1 | { 2 | "functions": { 3 | "predeploy": "npm --prefix \"$RESOURCE_DIR\" run build" 4 | } 5 | } 6 | -------------------------------------------------------------------------------- /firebase/adminApp.ts: -------------------------------------------------------------------------------- 1 | // firebaseAdmin.ts 2 | import * as firebaseAdmin from "firebase-admin"; 3 | 4 | if (!firebaseAdmin.apps.length) { 5 | firebaseAdmin.initializeApp({ 6 | credential: firebaseAdmin.credential.cert({ 7 | privateKey: JSON.parse(process.env.FIREBASE_PRIVATE_KEY ?? ""), 8 | clientEmail: process.env.FIREBASE_CLIENT_EMAIL, 9 | projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID, 10 | }), 11 | databaseURL: process.env.NEXT_PUBLIC_FIREBASE_DATABASE_URL, 12 | }); 13 | } 14 | 15 | export default firebaseAdmin; 16 | -------------------------------------------------------------------------------- /firebase/auth/auth.tsx: -------------------------------------------------------------------------------- 1 | import React, { useState, useEffect, useContext, createContext } from "react"; 2 | import nookies from "nookies"; 3 | import firebaseClient from "../clientApp"; 4 | 5 | const AuthContext = createContext<{ user: firebaseClient.User | null }>({ 6 | user: null, 7 | }); 8 | 9 | export function AuthProvider({ children }: any) { 10 | const [user, setUser] = useState(null); 11 | 12 | useEffect(() => { 13 | if (typeof window !== "undefined") { 14 | (window as any).nookies = nookies; 15 | } 16 | return firebaseClient.auth().onIdTokenChanged(async (user) => { 17 | if (!user) { 18 | setUser(null); 19 | nookies.destroy(null, "token"); 20 | nookies.set(null, "token", "", { path: "/" }); 21 | return; 22 | } 23 | 24 | const token = await user.getIdToken(); 25 | setUser(user); 26 | nookies.destroy(null, "token"); 27 | nookies.set(null, "token", token, { path: "/" }); 28 | }); 29 | }, []); 30 | 31 | // force refresh the token every 10 minutes 32 | useEffect(() => { 33 | const handle = setInterval(async () => { 34 | console.log(`refreshing token...`); 35 | const user = firebaseClient.auth().currentUser; 36 | if (user) await user.getIdToken(true); 37 | }, 10 * 60 * 1000); 38 | return () => clearInterval(handle); 39 | }, []); 40 | 41 | return ( 42 | {children} 43 | ); 44 | } 45 | 46 | export const useAuth = () => { 47 | return useContext(AuthContext); 48 | }; 49 | -------------------------------------------------------------------------------- /firebase/auth/utils.tsx: -------------------------------------------------------------------------------- 1 | import firebaseAdmin from "../adminApp"; 2 | 3 | export const userIsLoggedIn = async (cookies: any) => { 4 | try { 5 | await firebaseAdmin.auth().verifyIdToken(cookies.token); 6 | return true; 7 | } catch (error) { 8 | return false; 9 | } 10 | }; 11 | -------------------------------------------------------------------------------- /firebase/clientApp.ts: -------------------------------------------------------------------------------- 1 | import firebase from "firebase/app"; 2 | import "firebase/auth"; 3 | import "firebase/firestore"; 4 | 5 | const clientCredentials = { 6 | apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY, 7 | authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN, 8 | projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID, 9 | storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET, 10 | messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID, 11 | appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID, 12 | }; 13 | 14 | if (!firebase.apps.length) { 15 | firebase.initializeApp(clientCredentials); 16 | } 17 | 18 | export default firebase; 19 | -------------------------------------------------------------------------------- /functions/.gitignore: -------------------------------------------------------------------------------- 1 | # Compiled JavaScript files 2 | lib/**/*.js 3 | lib/**/*.js.map 4 | lib/ 5 | 6 | # TypeScript v1 declaration files 7 | typings/ 8 | 9 | # Node.js dependency directory 10 | node_modules/ 11 | -------------------------------------------------------------------------------- /functions/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "functions", 3 | "lockfileVersion": 2, 4 | "requires": true, 5 | "packages": { 6 | "": { 7 | "dependencies": { 8 | "firebase-admin": "^9.8.0", 9 | "firebase-functions": "^3.14.1" 10 | }, 11 | "devDependencies": { 12 | "firebase-functions-test": "^0.2.0", 13 | "typescript": "^3.8.0" 14 | }, 15 | "engines": { 16 | "node": "14" 17 | } 18 | }, 19 | "node_modules/@firebase/app-types": { 20 | "version": "0.6.2", 21 | "resolved": "https://registry.npmjs.org/@firebase/app-types/-/app-types-0.6.2.tgz", 22 | "integrity": "sha512-2VXvq/K+n8XMdM4L2xy5bYp2ZXMawJXluUIDzUBvMthVR+lhxK4pfFiqr1mmDbv9ydXvEAuFsD+6DpcZuJcSSw==" 23 | }, 24 | "node_modules/@firebase/auth-interop-types": { 25 | "version": "0.1.6", 26 | "resolved": "https://registry.npmjs.org/@firebase/auth-interop-types/-/auth-interop-types-0.1.6.tgz", 27 | "integrity": "sha512-etIi92fW3CctsmR9e3sYM3Uqnoq861M0Id9mdOPF6PWIg38BXL5k4upCNBggGUpLIS0H1grMOvy/wn1xymwe2g==", 28 | "peerDependencies": { 29 | "@firebase/app-types": "0.x", 30 | "@firebase/util": "1.x" 31 | } 32 | }, 33 | "node_modules/@firebase/component": { 34 | "version": "0.5.0", 35 | "resolved": "https://registry.npmjs.org/@firebase/component/-/component-0.5.0.tgz", 36 | "integrity": "sha512-v18csWtXb0ri+3m7wuGLY/UDgcb89vuMlZGQ//+7jEPLIQeLbylvZhol1uzW9WzoOpxMxOS2W5qyVGX36wZvEA==", 37 | "dependencies": { 38 | "@firebase/util": "1.1.0", 39 | "tslib": "^2.1.0" 40 | } 41 | }, 42 | "node_modules/@firebase/database": { 43 | "version": "0.10.2", 44 | "resolved": "https://registry.npmjs.org/@firebase/database/-/database-0.10.2.tgz", 45 | "integrity": "sha512-jMGtl5eBES9k0rOIZd6/EAuVB6m3LzRei1lvEiqWWBje2Xoz//7sjZcxOYtAKCCLldEI1EUrzW8Tv5yEAoPPpg==", 46 | "dependencies": { 47 | "@firebase/auth-interop-types": "0.1.6", 48 | "@firebase/component": "0.5.0", 49 | "@firebase/database-types": "0.7.2", 50 | "@firebase/logger": "0.2.6", 51 | "@firebase/util": "1.1.0", 52 | "faye-websocket": "0.11.3", 53 | "tslib": "^2.1.0" 54 | } 55 | }, 56 | "node_modules/@firebase/database-types": { 57 | "version": "0.7.2", 58 | "resolved": "https://registry.npmjs.org/@firebase/database-types/-/database-types-0.7.2.tgz", 59 | "integrity": "sha512-cdAd/dgwvC0r3oLEDUR+ULs1vBsEvy0b27nlzKhU6LQgm9fCDzgaH9nFGv8x+S9dly4B0egAXkONkVoWcOAisg==", 60 | "dependencies": { 61 | "@firebase/app-types": "0.6.2" 62 | } 63 | }, 64 | "node_modules/@firebase/logger": { 65 | "version": "0.2.6", 66 | "resolved": "https://registry.npmjs.org/@firebase/logger/-/logger-0.2.6.tgz", 67 | "integrity": "sha512-KIxcUvW/cRGWlzK9Vd2KB864HlUnCfdTH0taHE0sXW5Xl7+W68suaeau1oKNEqmc3l45azkd4NzXTCWZRZdXrw==" 68 | }, 69 | "node_modules/@firebase/util": { 70 | "version": "1.1.0", 71 | "resolved": "https://registry.npmjs.org/@firebase/util/-/util-1.1.0.tgz", 72 | "integrity": "sha512-lfuSASuPKNdfebuFR8rjFamMQUPH9iiZHcKS755Rkm/5gRT0qC7BMhCh3ZkHf7NVbplzIc/GhmX2jM+igDRCag==", 73 | "dependencies": { 74 | "tslib": "^2.1.0" 75 | } 76 | }, 77 | "node_modules/@google-cloud/common": { 78 | "version": "3.6.0", 79 | "resolved": "https://registry.npmjs.org/@google-cloud/common/-/common-3.6.0.tgz", 80 | "integrity": "sha512-aHIFTqJZmeTNO9md8XxV+ywuvXF3xBm5WNmgWeeCK+XN5X+kGW0WEX94wGwj+/MdOnrVf4dL2RvSIt9J5yJG6Q==", 81 | "optional": true, 82 | "dependencies": { 83 | "@google-cloud/projectify": "^2.0.0", 84 | "@google-cloud/promisify": "^2.0.0", 85 | "arrify": "^2.0.1", 86 | "duplexify": "^4.1.1", 87 | "ent": "^2.2.0", 88 | "extend": "^3.0.2", 89 | "google-auth-library": "^7.0.2", 90 | "retry-request": "^4.1.1", 91 | "teeny-request": "^7.0.0" 92 | }, 93 | "engines": { 94 | "node": ">=10" 95 | } 96 | }, 97 | "node_modules/@google-cloud/firestore": { 98 | "version": "4.12.2", 99 | "resolved": "https://registry.npmjs.org/@google-cloud/firestore/-/firestore-4.12.2.tgz", 100 | "integrity": "sha512-5rurTAJXQ0SANEf8K9eA2JAB5zAh+pu4tGRnkZx5gBWQLZXdBFdtepS+irvKuSXw1KbeAQOuRANSc/nguys6SQ==", 101 | "optional": true, 102 | "dependencies": { 103 | "fast-deep-equal": "^3.1.1", 104 | "functional-red-black-tree": "^1.0.1", 105 | "google-gax": "^2.12.0", 106 | "protobufjs": "^6.8.6" 107 | }, 108 | "engines": { 109 | "node": ">=10.10.0" 110 | } 111 | }, 112 | "node_modules/@google-cloud/paginator": { 113 | "version": "3.0.5", 114 | "resolved": "https://registry.npmjs.org/@google-cloud/paginator/-/paginator-3.0.5.tgz", 115 | "integrity": "sha512-N4Uk4BT1YuskfRhKXBs0n9Lg2YTROZc6IMpkO/8DIHODtm5s3xY8K5vVBo23v/2XulY3azwITQlYWgT4GdLsUw==", 116 | "optional": true, 117 | "dependencies": { 118 | "arrify": "^2.0.0", 119 | "extend": "^3.0.2" 120 | }, 121 | "engines": { 122 | "node": ">=10" 123 | } 124 | }, 125 | "node_modules/@google-cloud/projectify": { 126 | "version": "2.0.1", 127 | "resolved": "https://registry.npmjs.org/@google-cloud/projectify/-/projectify-2.0.1.tgz", 128 | "integrity": "sha512-ZDG38U/Yy6Zr21LaR3BTiiLtpJl6RkPS/JwoRT453G+6Q1DhlV0waNf8Lfu+YVYGIIxgKnLayJRfYlFJfiI8iQ==", 129 | "optional": true, 130 | "engines": { 131 | "node": ">=10" 132 | } 133 | }, 134 | "node_modules/@google-cloud/promisify": { 135 | "version": "2.0.3", 136 | "resolved": "https://registry.npmjs.org/@google-cloud/promisify/-/promisify-2.0.3.tgz", 137 | "integrity": "sha512-d4VSA86eL/AFTe5xtyZX+ePUjE8dIFu2T8zmdeNBSa5/kNgXPCx/o/wbFNHAGLJdGnk1vddRuMESD9HbOC8irw==", 138 | "optional": true, 139 | "engines": { 140 | "node": ">=10" 141 | } 142 | }, 143 | "node_modules/@google-cloud/storage": { 144 | "version": "5.8.5", 145 | "resolved": "https://registry.npmjs.org/@google-cloud/storage/-/storage-5.8.5.tgz", 146 | "integrity": "sha512-i0gB9CRwQeOBYP7xuvn14M40LhHCwMjceBjxE4CTvsqL519sVY5yVKxLiAedHWGwUZHJNRa7Q2CmNfkdRwVNPg==", 147 | "optional": true, 148 | "dependencies": { 149 | "@google-cloud/common": "^3.6.0", 150 | "@google-cloud/paginator": "^3.0.0", 151 | "@google-cloud/promisify": "^2.0.0", 152 | "arrify": "^2.0.0", 153 | "async-retry": "^1.3.1", 154 | "compressible": "^2.0.12", 155 | "date-and-time": "^1.0.0", 156 | "duplexify": "^4.0.0", 157 | "extend": "^3.0.2", 158 | "gaxios": "^4.0.0", 159 | "gcs-resumable-upload": "^3.1.4", 160 | "get-stream": "^6.0.0", 161 | "hash-stream-validation": "^0.2.2", 162 | "mime": "^2.2.0", 163 | "mime-types": "^2.0.8", 164 | "onetime": "^5.1.0", 165 | "p-limit": "^3.0.1", 166 | "pumpify": "^2.0.0", 167 | "snakeize": "^0.1.0", 168 | "stream-events": "^1.0.1", 169 | "xdg-basedir": "^4.0.0" 170 | }, 171 | "engines": { 172 | "node": ">=10" 173 | } 174 | }, 175 | "node_modules/@grpc/grpc-js": { 176 | "version": "1.3.2", 177 | "resolved": "https://registry.npmjs.org/@grpc/grpc-js/-/grpc-js-1.3.2.tgz", 178 | "integrity": "sha512-UXepkOKCATJrhHGsxt+CGfpZy9zUn1q9mop5kfcXq1fBkTePxVNPOdnISlCbJFlCtld+pSLGyZCzr9/zVprFKA==", 179 | "optional": true, 180 | "dependencies": { 181 | "@types/node": ">=12.12.47" 182 | }, 183 | "engines": { 184 | "node": "^8.13.0 || >=10.10.0" 185 | } 186 | }, 187 | "node_modules/@grpc/proto-loader": { 188 | "version": "0.6.2", 189 | "resolved": "https://registry.npmjs.org/@grpc/proto-loader/-/proto-loader-0.6.2.tgz", 190 | "integrity": "sha512-q2Qle60Ht2OQBCp9S5hv1JbI4uBBq6/mqSevFNK3ZEgRDBCAkWqZPUhD/K9gXOHrHKluliHiVq2L9sw1mVyAIg==", 191 | "optional": true, 192 | "dependencies": { 193 | "@types/long": "^4.0.1", 194 | "lodash.camelcase": "^4.3.0", 195 | "long": "^4.0.0", 196 | "protobufjs": "^6.10.0", 197 | "yargs": "^16.1.1" 198 | }, 199 | "bin": { 200 | "proto-loader-gen-types": "build/bin/proto-loader-gen-types.js" 201 | }, 202 | "engines": { 203 | "node": ">=6" 204 | } 205 | }, 206 | "node_modules/@panva/asn1.js": { 207 | "version": "1.0.0", 208 | "resolved": "https://registry.npmjs.org/@panva/asn1.js/-/asn1.js-1.0.0.tgz", 209 | "integrity": "sha512-UdkG3mLEqXgnlKsWanWcgb6dOjUzJ+XC5f+aWw30qrtjxeNUSfKX1cd5FBzOaXQumoe9nIqeZUvrRJS03HCCtw==", 210 | "engines": { 211 | "node": ">=10.13.0" 212 | } 213 | }, 214 | "node_modules/@protobufjs/aspromise": { 215 | "version": "1.1.2", 216 | "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", 217 | "integrity": "sha1-m4sMxmPWaafY9vXQiToU00jzD78=", 218 | "optional": true 219 | }, 220 | "node_modules/@protobufjs/base64": { 221 | "version": "1.1.2", 222 | "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", 223 | "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==", 224 | "optional": true 225 | }, 226 | "node_modules/@protobufjs/codegen": { 227 | "version": "2.0.4", 228 | "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", 229 | "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==", 230 | "optional": true 231 | }, 232 | "node_modules/@protobufjs/eventemitter": { 233 | "version": "1.1.0", 234 | "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", 235 | "integrity": "sha1-NVy8mLr61ZePntCV85diHx0Ga3A=", 236 | "optional": true 237 | }, 238 | "node_modules/@protobufjs/fetch": { 239 | "version": "1.1.0", 240 | "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", 241 | "integrity": "sha1-upn7WYYUr2VwDBYZ/wbUVLDYTEU=", 242 | "optional": true, 243 | "dependencies": { 244 | "@protobufjs/aspromise": "^1.1.1", 245 | "@protobufjs/inquire": "^1.1.0" 246 | } 247 | }, 248 | "node_modules/@protobufjs/float": { 249 | "version": "1.0.2", 250 | "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", 251 | "integrity": "sha1-Xp4avctz/Ap8uLKR33jIy9l7h9E=", 252 | "optional": true 253 | }, 254 | "node_modules/@protobufjs/inquire": { 255 | "version": "1.1.0", 256 | "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", 257 | "integrity": "sha1-/yAOPnzyQp4tyvwRQIKOjMY48Ik=", 258 | "optional": true 259 | }, 260 | "node_modules/@protobufjs/path": { 261 | "version": "1.1.2", 262 | "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", 263 | "integrity": "sha1-bMKyDFya1q0NzP0hynZz2Nf79o0=", 264 | "optional": true 265 | }, 266 | "node_modules/@protobufjs/pool": { 267 | "version": "1.1.0", 268 | "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", 269 | "integrity": "sha1-Cf0V8tbTq/qbZbw2ZQbWrXhG/1Q=", 270 | "optional": true 271 | }, 272 | "node_modules/@protobufjs/utf8": { 273 | "version": "1.1.0", 274 | "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", 275 | "integrity": "sha1-p3c2C1s5oaLlEG+OhY8v0tBgxXA=", 276 | "optional": true 277 | }, 278 | "node_modules/@tootallnate/once": { 279 | "version": "1.1.2", 280 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 281 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 282 | "optional": true, 283 | "engines": { 284 | "node": ">= 6" 285 | } 286 | }, 287 | "node_modules/@types/body-parser": { 288 | "version": "1.19.0", 289 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.0.tgz", 290 | "integrity": "sha512-W98JrE0j2K78swW4ukqMleo8R7h/pFETjM2DQ90MF6XK2i4LO4W3gQ71Lt4w3bfm2EvVSyWHplECvB5sK22yFQ==", 291 | "dependencies": { 292 | "@types/connect": "*", 293 | "@types/node": "*" 294 | } 295 | }, 296 | "node_modules/@types/connect": { 297 | "version": "3.4.34", 298 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.34.tgz", 299 | "integrity": "sha512-ePPA/JuI+X0vb+gSWlPKOY0NdNAie/rPUqX2GUPpbZwiKTkSPhjXWuee47E4MtE54QVzGCQMQkAL6JhV2E1+cQ==", 300 | "dependencies": { 301 | "@types/node": "*" 302 | } 303 | }, 304 | "node_modules/@types/express": { 305 | "version": "4.17.3", 306 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.3.tgz", 307 | "integrity": "sha512-I8cGRJj3pyOLs/HndoP+25vOqhqWkAZsWMEmq1qXy/b/M3ppufecUwaK2/TVDVxcV61/iSdhykUjQQ2DLSrTdg==", 308 | "dependencies": { 309 | "@types/body-parser": "*", 310 | "@types/express-serve-static-core": "*", 311 | "@types/serve-static": "*" 312 | } 313 | }, 314 | "node_modules/@types/express-jwt": { 315 | "version": "0.0.42", 316 | "resolved": "https://registry.npmjs.org/@types/express-jwt/-/express-jwt-0.0.42.tgz", 317 | "integrity": "sha512-WszgUddvM1t5dPpJ3LhWNH8kfNN8GPIBrAGxgIYXVCEGx6Bx4A036aAuf/r5WH9DIEdlmp7gHOYvSM6U87B0ag==", 318 | "dependencies": { 319 | "@types/express": "*", 320 | "@types/express-unless": "*" 321 | } 322 | }, 323 | "node_modules/@types/express-serve-static-core": { 324 | "version": "4.17.20", 325 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.20.tgz", 326 | "integrity": "sha512-8qqFN4W53IEWa9bdmuVrUcVkFemQWnt5DKPQ/oa8xKDYgtjCr2OO6NX5TIK49NLFr3mPYU2cLh92DQquC3oWWQ==", 327 | "dependencies": { 328 | "@types/node": "*", 329 | "@types/qs": "*", 330 | "@types/range-parser": "*" 331 | } 332 | }, 333 | "node_modules/@types/express-unless": { 334 | "version": "0.5.1", 335 | "resolved": "https://registry.npmjs.org/@types/express-unless/-/express-unless-0.5.1.tgz", 336 | "integrity": "sha512-5fuvg7C69lemNgl0+v+CUxDYWVPSfXHhJPst4yTLcqi4zKJpORCxnDrnnilk3k0DTq/WrAUdvXFs01+vUqUZHw==", 337 | "dependencies": { 338 | "@types/express": "*" 339 | } 340 | }, 341 | "node_modules/@types/lodash": { 342 | "version": "4.14.170", 343 | "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.170.tgz", 344 | "integrity": "sha512-bpcvu/MKHHeYX+qeEN8GE7DIravODWdACVA1ctevD8CN24RhPZIKMn9ntfAsrvLfSX3cR5RrBKAbYm9bGs0A+Q==", 345 | "dev": true 346 | }, 347 | "node_modules/@types/long": { 348 | "version": "4.0.1", 349 | "resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.1.tgz", 350 | "integrity": "sha512-5tXH6Bx/kNGd3MgffdmP4dy2Z+G4eaXw0SE81Tq3BNadtnMR5/ySMzX4SLEzHJzSmPNn4HIdpQsBvXMUykr58w==", 351 | "optional": true 352 | }, 353 | "node_modules/@types/mime": { 354 | "version": "1.3.2", 355 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", 356 | "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==" 357 | }, 358 | "node_modules/@types/node": { 359 | "version": "15.6.1", 360 | "resolved": "https://registry.npmjs.org/@types/node/-/node-15.6.1.tgz", 361 | "integrity": "sha512-7EIraBEyRHEe7CH+Fm1XvgqU6uwZN8Q7jppJGcqjROMT29qhAuuOxYB1uEY5UMYQKEmA5D+5tBnhdaPXSsLONA==" 362 | }, 363 | "node_modules/@types/qs": { 364 | "version": "6.9.6", 365 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.6.tgz", 366 | "integrity": "sha512-0/HnwIfW4ki2D8L8c9GVcG5I72s9jP5GSLVF0VIXDW00kmIpA6O33G7a8n59Tmh7Nz0WUC3rSb7PTY/sdW2JzA==" 367 | }, 368 | "node_modules/@types/range-parser": { 369 | "version": "1.2.3", 370 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.3.tgz", 371 | "integrity": "sha512-ewFXqrQHlFsgc09MK5jP5iR7vumV/BYayNC6PgJO2LPe8vrnNFyjQjSppfEngITi0qvfKtzFvgKymGheFM9UOA==" 372 | }, 373 | "node_modules/@types/serve-static": { 374 | "version": "1.13.9", 375 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.9.tgz", 376 | "integrity": "sha512-ZFqF6qa48XsPdjXV5Gsz0Zqmux2PerNd3a/ktL45mHpa19cuMi/cL8tcxdAx497yRh+QtYPuofjT9oWw9P7nkA==", 377 | "dependencies": { 378 | "@types/mime": "^1", 379 | "@types/node": "*" 380 | } 381 | }, 382 | "node_modules/abort-controller": { 383 | "version": "3.0.0", 384 | "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", 385 | "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", 386 | "optional": true, 387 | "dependencies": { 388 | "event-target-shim": "^5.0.0" 389 | }, 390 | "engines": { 391 | "node": ">=6.5" 392 | } 393 | }, 394 | "node_modules/accepts": { 395 | "version": "1.3.7", 396 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 397 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 398 | "dependencies": { 399 | "mime-types": "~2.1.24", 400 | "negotiator": "0.6.2" 401 | }, 402 | "engines": { 403 | "node": ">= 0.6" 404 | } 405 | }, 406 | "node_modules/agent-base": { 407 | "version": "6.0.2", 408 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 409 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 410 | "optional": true, 411 | "dependencies": { 412 | "debug": "4" 413 | }, 414 | "engines": { 415 | "node": ">= 6.0.0" 416 | } 417 | }, 418 | "node_modules/agent-base/node_modules/debug": { 419 | "version": "4.3.1", 420 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 421 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 422 | "optional": true, 423 | "dependencies": { 424 | "ms": "2.1.2" 425 | }, 426 | "engines": { 427 | "node": ">=6.0" 428 | }, 429 | "peerDependenciesMeta": { 430 | "supports-color": { 431 | "optional": true 432 | } 433 | } 434 | }, 435 | "node_modules/agent-base/node_modules/ms": { 436 | "version": "2.1.2", 437 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 438 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 439 | "optional": true 440 | }, 441 | "node_modules/ansi-regex": { 442 | "version": "5.0.0", 443 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 444 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 445 | "optional": true, 446 | "engines": { 447 | "node": ">=8" 448 | } 449 | }, 450 | "node_modules/ansi-styles": { 451 | "version": "4.3.0", 452 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 453 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 454 | "optional": true, 455 | "dependencies": { 456 | "color-convert": "^2.0.1" 457 | }, 458 | "engines": { 459 | "node": ">=8" 460 | }, 461 | "funding": { 462 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 463 | } 464 | }, 465 | "node_modules/array-flatten": { 466 | "version": "1.1.1", 467 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 468 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 469 | }, 470 | "node_modules/arrify": { 471 | "version": "2.0.1", 472 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-2.0.1.tgz", 473 | "integrity": "sha512-3duEwti880xqi4eAMN8AyR4a0ByT90zoYdLlevfrvU43vb0YZwZVfxOgxWrLXXXpyugL0hNZc9G6BiB5B3nUug==", 474 | "optional": true, 475 | "engines": { 476 | "node": ">=8" 477 | } 478 | }, 479 | "node_modules/async-retry": { 480 | "version": "1.3.1", 481 | "resolved": "https://registry.npmjs.org/async-retry/-/async-retry-1.3.1.tgz", 482 | "integrity": "sha512-aiieFW/7h3hY0Bq5d+ktDBejxuwR78vRu9hDUdR8rNhSaQ29VzPL4AoIRG7D/c7tdenwOcKvgPM6tIxB3cB6HA==", 483 | "optional": true, 484 | "dependencies": { 485 | "retry": "0.12.0" 486 | } 487 | }, 488 | "node_modules/base64-js": { 489 | "version": "1.5.1", 490 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 491 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 492 | "funding": [ 493 | { 494 | "type": "github", 495 | "url": "https://github.com/sponsors/feross" 496 | }, 497 | { 498 | "type": "patreon", 499 | "url": "https://www.patreon.com/feross" 500 | }, 501 | { 502 | "type": "consulting", 503 | "url": "https://feross.org/support" 504 | } 505 | ], 506 | "optional": true 507 | }, 508 | "node_modules/bignumber.js": { 509 | "version": "9.0.1", 510 | "resolved": "https://registry.npmjs.org/bignumber.js/-/bignumber.js-9.0.1.tgz", 511 | "integrity": "sha512-IdZR9mh6ahOBv/hYGiXyVuyCetmGJhtYkqLBpTStdhEGjegpPlUawydyaF3pbIOFynJTpllEs+NP+CS9jKFLjA==", 512 | "optional": true, 513 | "engines": { 514 | "node": "*" 515 | } 516 | }, 517 | "node_modules/body-parser": { 518 | "version": "1.19.0", 519 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 520 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 521 | "dependencies": { 522 | "bytes": "3.1.0", 523 | "content-type": "~1.0.4", 524 | "debug": "2.6.9", 525 | "depd": "~1.1.2", 526 | "http-errors": "1.7.2", 527 | "iconv-lite": "0.4.24", 528 | "on-finished": "~2.3.0", 529 | "qs": "6.7.0", 530 | "raw-body": "2.4.0", 531 | "type-is": "~1.6.17" 532 | }, 533 | "engines": { 534 | "node": ">= 0.8" 535 | } 536 | }, 537 | "node_modules/buffer-equal-constant-time": { 538 | "version": "1.0.1", 539 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 540 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 541 | }, 542 | "node_modules/bytes": { 543 | "version": "3.1.0", 544 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 545 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==", 546 | "engines": { 547 | "node": ">= 0.8" 548 | } 549 | }, 550 | "node_modules/cliui": { 551 | "version": "7.0.4", 552 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 553 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 554 | "optional": true, 555 | "dependencies": { 556 | "string-width": "^4.2.0", 557 | "strip-ansi": "^6.0.0", 558 | "wrap-ansi": "^7.0.0" 559 | } 560 | }, 561 | "node_modules/color-convert": { 562 | "version": "2.0.1", 563 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 564 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 565 | "optional": true, 566 | "dependencies": { 567 | "color-name": "~1.1.4" 568 | }, 569 | "engines": { 570 | "node": ">=7.0.0" 571 | } 572 | }, 573 | "node_modules/color-name": { 574 | "version": "1.1.4", 575 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 576 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 577 | "optional": true 578 | }, 579 | "node_modules/compressible": { 580 | "version": "2.0.18", 581 | "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz", 582 | "integrity": "sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==", 583 | "optional": true, 584 | "dependencies": { 585 | "mime-db": ">= 1.43.0 < 2" 586 | }, 587 | "engines": { 588 | "node": ">= 0.6" 589 | } 590 | }, 591 | "node_modules/configstore": { 592 | "version": "5.0.1", 593 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz", 594 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==", 595 | "optional": true, 596 | "dependencies": { 597 | "dot-prop": "^5.2.0", 598 | "graceful-fs": "^4.1.2", 599 | "make-dir": "^3.0.0", 600 | "unique-string": "^2.0.0", 601 | "write-file-atomic": "^3.0.0", 602 | "xdg-basedir": "^4.0.0" 603 | }, 604 | "engines": { 605 | "node": ">=8" 606 | } 607 | }, 608 | "node_modules/content-disposition": { 609 | "version": "0.5.3", 610 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 611 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 612 | "dependencies": { 613 | "safe-buffer": "5.1.2" 614 | }, 615 | "engines": { 616 | "node": ">= 0.6" 617 | } 618 | }, 619 | "node_modules/content-type": { 620 | "version": "1.0.4", 621 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 622 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", 623 | "engines": { 624 | "node": ">= 0.6" 625 | } 626 | }, 627 | "node_modules/cookie": { 628 | "version": "0.4.0", 629 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 630 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==", 631 | "engines": { 632 | "node": ">= 0.6" 633 | } 634 | }, 635 | "node_modules/cookie-signature": { 636 | "version": "1.0.6", 637 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 638 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 639 | }, 640 | "node_modules/cors": { 641 | "version": "2.8.5", 642 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 643 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 644 | "dependencies": { 645 | "object-assign": "^4", 646 | "vary": "^1" 647 | }, 648 | "engines": { 649 | "node": ">= 0.10" 650 | } 651 | }, 652 | "node_modules/crypto-random-string": { 653 | "version": "2.0.0", 654 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", 655 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==", 656 | "optional": true, 657 | "engines": { 658 | "node": ">=8" 659 | } 660 | }, 661 | "node_modules/date-and-time": { 662 | "version": "1.0.0", 663 | "resolved": "https://registry.npmjs.org/date-and-time/-/date-and-time-1.0.0.tgz", 664 | "integrity": "sha512-477D7ypIiqlXBkxhU7YtG9wWZJEQ+RUpujt2quTfgf4+E8g5fNUkB0QIL0bVyP5/TKBg8y55Hfa1R/c4bt3dEw==", 665 | "optional": true 666 | }, 667 | "node_modules/debug": { 668 | "version": "2.6.9", 669 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 670 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 671 | "dependencies": { 672 | "ms": "2.0.0" 673 | } 674 | }, 675 | "node_modules/depd": { 676 | "version": "1.1.2", 677 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 678 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 679 | "engines": { 680 | "node": ">= 0.6" 681 | } 682 | }, 683 | "node_modules/destroy": { 684 | "version": "1.0.4", 685 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 686 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 687 | }, 688 | "node_modules/dicer": { 689 | "version": "0.3.0", 690 | "resolved": "https://registry.npmjs.org/dicer/-/dicer-0.3.0.tgz", 691 | "integrity": "sha512-MdceRRWqltEG2dZqO769g27N/3PXfcKl04VhYnBlo2YhH7zPi88VebsjTKclaOyiuMaGU72hTfw3VkUitGcVCA==", 692 | "dependencies": { 693 | "streamsearch": "0.1.2" 694 | }, 695 | "engines": { 696 | "node": ">=4.5.0" 697 | } 698 | }, 699 | "node_modules/dot-prop": { 700 | "version": "5.3.0", 701 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz", 702 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==", 703 | "optional": true, 704 | "dependencies": { 705 | "is-obj": "^2.0.0" 706 | }, 707 | "engines": { 708 | "node": ">=8" 709 | } 710 | }, 711 | "node_modules/duplexify": { 712 | "version": "4.1.1", 713 | "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-4.1.1.tgz", 714 | "integrity": "sha512-DY3xVEmVHTv1wSzKNbwoU6nVjzI369Y6sPoqfYr0/xlx3IdX2n94xIszTcjPO8W8ZIv0Wb0PXNcjuZyT4wiICA==", 715 | "optional": true, 716 | "dependencies": { 717 | "end-of-stream": "^1.4.1", 718 | "inherits": "^2.0.3", 719 | "readable-stream": "^3.1.1", 720 | "stream-shift": "^1.0.0" 721 | } 722 | }, 723 | "node_modules/ecdsa-sig-formatter": { 724 | "version": "1.0.11", 725 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 726 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 727 | "dependencies": { 728 | "safe-buffer": "^5.0.1" 729 | } 730 | }, 731 | "node_modules/ee-first": { 732 | "version": "1.1.1", 733 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 734 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 735 | }, 736 | "node_modules/emoji-regex": { 737 | "version": "8.0.0", 738 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 739 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 740 | "optional": true 741 | }, 742 | "node_modules/encodeurl": { 743 | "version": "1.0.2", 744 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 745 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", 746 | "engines": { 747 | "node": ">= 0.8" 748 | } 749 | }, 750 | "node_modules/end-of-stream": { 751 | "version": "1.4.4", 752 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 753 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 754 | "optional": true, 755 | "dependencies": { 756 | "once": "^1.4.0" 757 | } 758 | }, 759 | "node_modules/ent": { 760 | "version": "2.2.0", 761 | "resolved": "https://registry.npmjs.org/ent/-/ent-2.2.0.tgz", 762 | "integrity": "sha1-6WQhkyWiHQX0RGai9obtbOX13R0=", 763 | "optional": true 764 | }, 765 | "node_modules/escalade": { 766 | "version": "3.1.1", 767 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 768 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 769 | "optional": true, 770 | "engines": { 771 | "node": ">=6" 772 | } 773 | }, 774 | "node_modules/escape-html": { 775 | "version": "1.0.3", 776 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 777 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 778 | }, 779 | "node_modules/etag": { 780 | "version": "1.8.1", 781 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 782 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", 783 | "engines": { 784 | "node": ">= 0.6" 785 | } 786 | }, 787 | "node_modules/event-target-shim": { 788 | "version": "5.0.1", 789 | "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz", 790 | "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==", 791 | "optional": true, 792 | "engines": { 793 | "node": ">=6" 794 | } 795 | }, 796 | "node_modules/express": { 797 | "version": "4.17.1", 798 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 799 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 800 | "dependencies": { 801 | "accepts": "~1.3.7", 802 | "array-flatten": "1.1.1", 803 | "body-parser": "1.19.0", 804 | "content-disposition": "0.5.3", 805 | "content-type": "~1.0.4", 806 | "cookie": "0.4.0", 807 | "cookie-signature": "1.0.6", 808 | "debug": "2.6.9", 809 | "depd": "~1.1.2", 810 | "encodeurl": "~1.0.2", 811 | "escape-html": "~1.0.3", 812 | "etag": "~1.8.1", 813 | "finalhandler": "~1.1.2", 814 | "fresh": "0.5.2", 815 | "merge-descriptors": "1.0.1", 816 | "methods": "~1.1.2", 817 | "on-finished": "~2.3.0", 818 | "parseurl": "~1.3.3", 819 | "path-to-regexp": "0.1.7", 820 | "proxy-addr": "~2.0.5", 821 | "qs": "6.7.0", 822 | "range-parser": "~1.2.1", 823 | "safe-buffer": "5.1.2", 824 | "send": "0.17.1", 825 | "serve-static": "1.14.1", 826 | "setprototypeof": "1.1.1", 827 | "statuses": "~1.5.0", 828 | "type-is": "~1.6.18", 829 | "utils-merge": "1.0.1", 830 | "vary": "~1.1.2" 831 | }, 832 | "engines": { 833 | "node": ">= 0.10.0" 834 | } 835 | }, 836 | "node_modules/extend": { 837 | "version": "3.0.2", 838 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 839 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 840 | "optional": true 841 | }, 842 | "node_modules/fast-deep-equal": { 843 | "version": "3.1.3", 844 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 845 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 846 | "optional": true 847 | }, 848 | "node_modules/fast-text-encoding": { 849 | "version": "1.0.3", 850 | "resolved": "https://registry.npmjs.org/fast-text-encoding/-/fast-text-encoding-1.0.3.tgz", 851 | "integrity": "sha512-dtm4QZH9nZtcDt8qJiOH9fcQd1NAgi+K1O2DbE6GG1PPCK/BWfOH3idCTRQ4ImXRUOyopDEgDEnVEE7Y/2Wrig==", 852 | "optional": true 853 | }, 854 | "node_modules/faye-websocket": { 855 | "version": "0.11.3", 856 | "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.3.tgz", 857 | "integrity": "sha512-D2y4bovYpzziGgbHYtGCMjlJM36vAl/y+xUyn1C+FVx8szd1E+86KwVw6XvYSzOP8iMpm1X0I4xJD+QtUb36OA==", 858 | "dependencies": { 859 | "websocket-driver": ">=0.5.1" 860 | }, 861 | "engines": { 862 | "node": ">=0.8.0" 863 | } 864 | }, 865 | "node_modules/finalhandler": { 866 | "version": "1.1.2", 867 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 868 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 869 | "dependencies": { 870 | "debug": "2.6.9", 871 | "encodeurl": "~1.0.2", 872 | "escape-html": "~1.0.3", 873 | "on-finished": "~2.3.0", 874 | "parseurl": "~1.3.3", 875 | "statuses": "~1.5.0", 876 | "unpipe": "~1.0.0" 877 | }, 878 | "engines": { 879 | "node": ">= 0.8" 880 | } 881 | }, 882 | "node_modules/firebase-admin": { 883 | "version": "9.9.0", 884 | "resolved": "https://registry.npmjs.org/firebase-admin/-/firebase-admin-9.9.0.tgz", 885 | "integrity": "sha512-04HT7JAAqcJYty95qf15IBD9CXf+vr7S8zNU6Zt1ayC1J05DLaCsUd19/sCNAjZ614KHexAYUtyLgZoJwu2wOQ==", 886 | "dependencies": { 887 | "@firebase/database": "^0.10.0", 888 | "@firebase/database-types": "^0.7.2", 889 | "@types/node": ">=12.12.47", 890 | "dicer": "^0.3.0", 891 | "jsonwebtoken": "^8.5.1", 892 | "jwks-rsa": "^2.0.2", 893 | "node-forge": "^0.10.0" 894 | }, 895 | "engines": { 896 | "node": ">=10.13.0" 897 | }, 898 | "optionalDependencies": { 899 | "@google-cloud/firestore": "^4.5.0", 900 | "@google-cloud/storage": "^5.3.0" 901 | } 902 | }, 903 | "node_modules/firebase-functions": { 904 | "version": "3.14.1", 905 | "resolved": "https://registry.npmjs.org/firebase-functions/-/firebase-functions-3.14.1.tgz", 906 | "integrity": "sha512-hL/qm+i5i1qKYmAFMlQ4mwRngDkP+3YT3F4E4Nd5Hj2QKeawBdZiMGgEt6zqTx08Zq04vHiSnSM0z75UJRSg6Q==", 907 | "dependencies": { 908 | "@types/express": "4.17.3", 909 | "cors": "^2.8.5", 910 | "express": "^4.17.1", 911 | "lodash": "^4.17.14" 912 | }, 913 | "engines": { 914 | "node": "^8.13.0 || >=10.10.0" 915 | }, 916 | "peerDependencies": { 917 | "firebase-admin": "^8.0.0 || ^9.0.0" 918 | } 919 | }, 920 | "node_modules/firebase-functions-test": { 921 | "version": "0.2.3", 922 | "resolved": "https://registry.npmjs.org/firebase-functions-test/-/firebase-functions-test-0.2.3.tgz", 923 | "integrity": "sha512-zYX0QTm53wCazuej7O0xqbHl90r/v1PTXt/hwa0jo1YF8nDM+iBKnLDlkIoW66MDd0R6aGg4BvKzTTdJpvigUA==", 924 | "dev": true, 925 | "dependencies": { 926 | "@types/lodash": "^4.14.104", 927 | "lodash": "^4.17.5" 928 | }, 929 | "engines": { 930 | "node": ">=8.0.0" 931 | }, 932 | "peerDependencies": { 933 | "firebase-admin": ">=6.0.0", 934 | "firebase-functions": ">=2.0.0" 935 | } 936 | }, 937 | "node_modules/forwarded": { 938 | "version": "0.1.2", 939 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 940 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=", 941 | "engines": { 942 | "node": ">= 0.6" 943 | } 944 | }, 945 | "node_modules/fresh": { 946 | "version": "0.5.2", 947 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 948 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", 949 | "engines": { 950 | "node": ">= 0.6" 951 | } 952 | }, 953 | "node_modules/functional-red-black-tree": { 954 | "version": "1.0.1", 955 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 956 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 957 | "optional": true 958 | }, 959 | "node_modules/gaxios": { 960 | "version": "4.3.0", 961 | "resolved": "https://registry.npmjs.org/gaxios/-/gaxios-4.3.0.tgz", 962 | "integrity": "sha512-pHplNbslpwCLMyII/lHPWFQbJWOX0B3R1hwBEOvzYi1GmdKZruuEHK4N9V6f7tf1EaPYyF80mui1+344p6SmLg==", 963 | "optional": true, 964 | "dependencies": { 965 | "abort-controller": "^3.0.0", 966 | "extend": "^3.0.2", 967 | "https-proxy-agent": "^5.0.0", 968 | "is-stream": "^2.0.0", 969 | "node-fetch": "^2.3.0" 970 | }, 971 | "engines": { 972 | "node": ">=10" 973 | } 974 | }, 975 | "node_modules/gcp-metadata": { 976 | "version": "4.2.1", 977 | "resolved": "https://registry.npmjs.org/gcp-metadata/-/gcp-metadata-4.2.1.tgz", 978 | "integrity": "sha512-tSk+REe5iq/N+K+SK1XjZJUrFPuDqGZVzCy2vocIHIGmPlTGsa8owXMJwGkrXr73NO0AzhPW4MF2DEHz7P2AVw==", 979 | "optional": true, 980 | "dependencies": { 981 | "gaxios": "^4.0.0", 982 | "json-bigint": "^1.0.0" 983 | }, 984 | "engines": { 985 | "node": ">=10" 986 | } 987 | }, 988 | "node_modules/gcs-resumable-upload": { 989 | "version": "3.1.4", 990 | "resolved": "https://registry.npmjs.org/gcs-resumable-upload/-/gcs-resumable-upload-3.1.4.tgz", 991 | "integrity": "sha512-5dyDfHrrVcIskiw/cPssVD4HRiwoHjhk1Nd6h5W3pQ/qffDvhfy4oNCr1f3ZXFPwTnxkCbibsB+73oOM+NvmJQ==", 992 | "optional": true, 993 | "dependencies": { 994 | "abort-controller": "^3.0.0", 995 | "configstore": "^5.0.0", 996 | "extend": "^3.0.2", 997 | "gaxios": "^4.0.0", 998 | "google-auth-library": "^7.0.0", 999 | "pumpify": "^2.0.0", 1000 | "stream-events": "^1.0.4" 1001 | }, 1002 | "bin": { 1003 | "gcs-upload": "build/src/cli.js" 1004 | }, 1005 | "engines": { 1006 | "node": ">=10" 1007 | } 1008 | }, 1009 | "node_modules/get-caller-file": { 1010 | "version": "2.0.5", 1011 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1012 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1013 | "optional": true, 1014 | "engines": { 1015 | "node": "6.* || 8.* || >= 10.*" 1016 | } 1017 | }, 1018 | "node_modules/get-stream": { 1019 | "version": "6.0.1", 1020 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 1021 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 1022 | "optional": true, 1023 | "engines": { 1024 | "node": ">=10" 1025 | }, 1026 | "funding": { 1027 | "url": "https://github.com/sponsors/sindresorhus" 1028 | } 1029 | }, 1030 | "node_modules/google-auth-library": { 1031 | "version": "7.1.0", 1032 | "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-7.1.0.tgz", 1033 | "integrity": "sha512-X+gbkGjnLN3HUZP2W3KBREuA603BXd80ITvL0PeS0QpyDNYz/u0pIZ7aRuGnrSuUc0grk/qxEgtVTFt1ogbP+A==", 1034 | "optional": true, 1035 | "dependencies": { 1036 | "arrify": "^2.0.0", 1037 | "base64-js": "^1.3.0", 1038 | "ecdsa-sig-formatter": "^1.0.11", 1039 | "fast-text-encoding": "^1.0.0", 1040 | "gaxios": "^4.0.0", 1041 | "gcp-metadata": "^4.2.0", 1042 | "gtoken": "^5.0.4", 1043 | "jws": "^4.0.0", 1044 | "lru-cache": "^6.0.0" 1045 | }, 1046 | "engines": { 1047 | "node": ">=10" 1048 | } 1049 | }, 1050 | "node_modules/google-gax": { 1051 | "version": "2.14.1", 1052 | "resolved": "https://registry.npmjs.org/google-gax/-/google-gax-2.14.1.tgz", 1053 | "integrity": "sha512-I5RDEN7MEptrCxeHX3ht7nKFGfyjgYX4hQKI9eVMBohMzVbFSwWUndo0CcKXu8es7NhB4gt2XYLm1AHkXhtHpA==", 1054 | "optional": true, 1055 | "dependencies": { 1056 | "@grpc/grpc-js": "~1.3.0", 1057 | "@grpc/proto-loader": "^0.6.1", 1058 | "@types/long": "^4.0.0", 1059 | "abort-controller": "^3.0.0", 1060 | "duplexify": "^4.0.0", 1061 | "fast-text-encoding": "^1.0.3", 1062 | "google-auth-library": "^7.0.2", 1063 | "is-stream-ended": "^0.1.4", 1064 | "node-fetch": "^2.6.1", 1065 | "object-hash": "^2.1.1", 1066 | "protobufjs": "^6.10.2", 1067 | "retry-request": "^4.0.0" 1068 | }, 1069 | "bin": { 1070 | "compileProtos": "build/tools/compileProtos.js" 1071 | }, 1072 | "engines": { 1073 | "node": ">=10" 1074 | } 1075 | }, 1076 | "node_modules/google-p12-pem": { 1077 | "version": "3.0.3", 1078 | "resolved": "https://registry.npmjs.org/google-p12-pem/-/google-p12-pem-3.0.3.tgz", 1079 | "integrity": "sha512-wS0ek4ZtFx/ACKYF3JhyGe5kzH7pgiQ7J5otlumqR9psmWMYc+U9cErKlCYVYHoUaidXHdZ2xbo34kB+S+24hA==", 1080 | "optional": true, 1081 | "dependencies": { 1082 | "node-forge": "^0.10.0" 1083 | }, 1084 | "bin": { 1085 | "gp12-pem": "build/src/bin/gp12-pem.js" 1086 | }, 1087 | "engines": { 1088 | "node": ">=10" 1089 | } 1090 | }, 1091 | "node_modules/graceful-fs": { 1092 | "version": "4.2.6", 1093 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.6.tgz", 1094 | "integrity": "sha512-nTnJ528pbqxYanhpDYsi4Rd8MAeaBA67+RZ10CM1m3bTAVFEDcd5AuA4a6W5YkGZ1iNXHzZz8T6TBKLeBuNriQ==", 1095 | "optional": true 1096 | }, 1097 | "node_modules/gtoken": { 1098 | "version": "5.2.1", 1099 | "resolved": "https://registry.npmjs.org/gtoken/-/gtoken-5.2.1.tgz", 1100 | "integrity": "sha512-OY0BfPKe3QnMsY9MzTHTSKn+Vl2l1CcLe6BwDEQj00mbbkl5nyQ/7EUREstg4fQNZ8iYE7br4JJ7TdKeDOPWmw==", 1101 | "optional": true, 1102 | "dependencies": { 1103 | "gaxios": "^4.0.0", 1104 | "google-p12-pem": "^3.0.3", 1105 | "jws": "^4.0.0" 1106 | }, 1107 | "engines": { 1108 | "node": ">=10" 1109 | } 1110 | }, 1111 | "node_modules/hash-stream-validation": { 1112 | "version": "0.2.4", 1113 | "resolved": "https://registry.npmjs.org/hash-stream-validation/-/hash-stream-validation-0.2.4.tgz", 1114 | "integrity": "sha512-Gjzu0Xn7IagXVkSu9cSFuK1fqzwtLwFhNhVL8IFJijRNMgUttFbBSIAzKuSIrsFMO1+g1RlsoN49zPIbwPDMGQ==", 1115 | "optional": true 1116 | }, 1117 | "node_modules/http-errors": { 1118 | "version": "1.7.2", 1119 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 1120 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 1121 | "dependencies": { 1122 | "depd": "~1.1.2", 1123 | "inherits": "2.0.3", 1124 | "setprototypeof": "1.1.1", 1125 | "statuses": ">= 1.5.0 < 2", 1126 | "toidentifier": "1.0.0" 1127 | }, 1128 | "engines": { 1129 | "node": ">= 0.6" 1130 | } 1131 | }, 1132 | "node_modules/http-errors/node_modules/inherits": { 1133 | "version": "2.0.3", 1134 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1135 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1136 | }, 1137 | "node_modules/http-parser-js": { 1138 | "version": "0.5.3", 1139 | "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.3.tgz", 1140 | "integrity": "sha512-t7hjvef/5HEK7RWTdUzVUhl8zkEu+LlaE0IYzdMuvbSDipxBRpOn4Uhw8ZyECEa808iVT8XCjzo6xmYt4CiLZg==" 1141 | }, 1142 | "node_modules/http-proxy-agent": { 1143 | "version": "4.0.1", 1144 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 1145 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 1146 | "optional": true, 1147 | "dependencies": { 1148 | "@tootallnate/once": "1", 1149 | "agent-base": "6", 1150 | "debug": "4" 1151 | }, 1152 | "engines": { 1153 | "node": ">= 6" 1154 | } 1155 | }, 1156 | "node_modules/http-proxy-agent/node_modules/debug": { 1157 | "version": "4.3.1", 1158 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 1159 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 1160 | "optional": true, 1161 | "dependencies": { 1162 | "ms": "2.1.2" 1163 | }, 1164 | "engines": { 1165 | "node": ">=6.0" 1166 | }, 1167 | "peerDependenciesMeta": { 1168 | "supports-color": { 1169 | "optional": true 1170 | } 1171 | } 1172 | }, 1173 | "node_modules/http-proxy-agent/node_modules/ms": { 1174 | "version": "2.1.2", 1175 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1176 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1177 | "optional": true 1178 | }, 1179 | "node_modules/https-proxy-agent": { 1180 | "version": "5.0.0", 1181 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 1182 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 1183 | "optional": true, 1184 | "dependencies": { 1185 | "agent-base": "6", 1186 | "debug": "4" 1187 | }, 1188 | "engines": { 1189 | "node": ">= 6" 1190 | } 1191 | }, 1192 | "node_modules/https-proxy-agent/node_modules/debug": { 1193 | "version": "4.3.1", 1194 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 1195 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 1196 | "optional": true, 1197 | "dependencies": { 1198 | "ms": "2.1.2" 1199 | }, 1200 | "engines": { 1201 | "node": ">=6.0" 1202 | }, 1203 | "peerDependenciesMeta": { 1204 | "supports-color": { 1205 | "optional": true 1206 | } 1207 | } 1208 | }, 1209 | "node_modules/https-proxy-agent/node_modules/ms": { 1210 | "version": "2.1.2", 1211 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1212 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1213 | "optional": true 1214 | }, 1215 | "node_modules/iconv-lite": { 1216 | "version": "0.4.24", 1217 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1218 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1219 | "dependencies": { 1220 | "safer-buffer": ">= 2.1.2 < 3" 1221 | }, 1222 | "engines": { 1223 | "node": ">=0.10.0" 1224 | } 1225 | }, 1226 | "node_modules/imurmurhash": { 1227 | "version": "0.1.4", 1228 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1229 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1230 | "optional": true, 1231 | "engines": { 1232 | "node": ">=0.8.19" 1233 | } 1234 | }, 1235 | "node_modules/inherits": { 1236 | "version": "2.0.4", 1237 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1238 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1239 | "optional": true 1240 | }, 1241 | "node_modules/ipaddr.js": { 1242 | "version": "1.9.1", 1243 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 1244 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 1245 | "engines": { 1246 | "node": ">= 0.10" 1247 | } 1248 | }, 1249 | "node_modules/is-fullwidth-code-point": { 1250 | "version": "3.0.0", 1251 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1252 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1253 | "optional": true, 1254 | "engines": { 1255 | "node": ">=8" 1256 | } 1257 | }, 1258 | "node_modules/is-obj": { 1259 | "version": "2.0.0", 1260 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 1261 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==", 1262 | "optional": true, 1263 | "engines": { 1264 | "node": ">=8" 1265 | } 1266 | }, 1267 | "node_modules/is-stream": { 1268 | "version": "2.0.0", 1269 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", 1270 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==", 1271 | "optional": true, 1272 | "engines": { 1273 | "node": ">=8" 1274 | } 1275 | }, 1276 | "node_modules/is-stream-ended": { 1277 | "version": "0.1.4", 1278 | "resolved": "https://registry.npmjs.org/is-stream-ended/-/is-stream-ended-0.1.4.tgz", 1279 | "integrity": "sha512-xj0XPvmr7bQFTvirqnFr50o0hQIh6ZItDqloxt5aJrR4NQsYeSsyFQERYGCAzfindAcnKjINnwEEgLx4IqVzQw==", 1280 | "optional": true 1281 | }, 1282 | "node_modules/is-typedarray": { 1283 | "version": "1.0.0", 1284 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1285 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1286 | "optional": true 1287 | }, 1288 | "node_modules/jose": { 1289 | "version": "2.0.5", 1290 | "resolved": "https://registry.npmjs.org/jose/-/jose-2.0.5.tgz", 1291 | "integrity": "sha512-BAiDNeDKTMgk4tvD0BbxJ8xHEHBZgpeRZ1zGPPsitSyMgjoMWiLGYAE7H7NpP5h0lPppQajQs871E8NHUrzVPA==", 1292 | "dependencies": { 1293 | "@panva/asn1.js": "^1.0.0" 1294 | }, 1295 | "engines": { 1296 | "node": ">=10.13.0 < 13 || >=13.7.0" 1297 | }, 1298 | "funding": { 1299 | "url": "https://github.com/sponsors/panva" 1300 | } 1301 | }, 1302 | "node_modules/json-bigint": { 1303 | "version": "1.0.0", 1304 | "resolved": "https://registry.npmjs.org/json-bigint/-/json-bigint-1.0.0.tgz", 1305 | "integrity": "sha512-SiPv/8VpZuWbvLSMtTDU8hEfrZWg/mH/nV/b4o0CYbSxu1UIQPLdwKOCIyLQX+VIPO5vrLX3i8qtqFyhdPSUSQ==", 1306 | "optional": true, 1307 | "dependencies": { 1308 | "bignumber.js": "^9.0.0" 1309 | } 1310 | }, 1311 | "node_modules/jsonwebtoken": { 1312 | "version": "8.5.1", 1313 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", 1314 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", 1315 | "dependencies": { 1316 | "jws": "^3.2.2", 1317 | "lodash.includes": "^4.3.0", 1318 | "lodash.isboolean": "^3.0.3", 1319 | "lodash.isinteger": "^4.0.4", 1320 | "lodash.isnumber": "^3.0.3", 1321 | "lodash.isplainobject": "^4.0.6", 1322 | "lodash.isstring": "^4.0.1", 1323 | "lodash.once": "^4.0.0", 1324 | "ms": "^2.1.1", 1325 | "semver": "^5.6.0" 1326 | }, 1327 | "engines": { 1328 | "node": ">=4", 1329 | "npm": ">=1.4.28" 1330 | } 1331 | }, 1332 | "node_modules/jsonwebtoken/node_modules/jwa": { 1333 | "version": "1.4.1", 1334 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 1335 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 1336 | "dependencies": { 1337 | "buffer-equal-constant-time": "1.0.1", 1338 | "ecdsa-sig-formatter": "1.0.11", 1339 | "safe-buffer": "^5.0.1" 1340 | } 1341 | }, 1342 | "node_modules/jsonwebtoken/node_modules/jws": { 1343 | "version": "3.2.2", 1344 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 1345 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 1346 | "dependencies": { 1347 | "jwa": "^1.4.1", 1348 | "safe-buffer": "^5.0.1" 1349 | } 1350 | }, 1351 | "node_modules/jsonwebtoken/node_modules/ms": { 1352 | "version": "2.1.3", 1353 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1354 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1355 | }, 1356 | "node_modules/jwa": { 1357 | "version": "2.0.0", 1358 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-2.0.0.tgz", 1359 | "integrity": "sha512-jrZ2Qx916EA+fq9cEAeCROWPTfCwi1IVHqT2tapuqLEVVDKFDENFw1oL+MwrTvH6msKxsd1YTDVw6uKEcsrLEA==", 1360 | "optional": true, 1361 | "dependencies": { 1362 | "buffer-equal-constant-time": "1.0.1", 1363 | "ecdsa-sig-formatter": "1.0.11", 1364 | "safe-buffer": "^5.0.1" 1365 | } 1366 | }, 1367 | "node_modules/jwks-rsa": { 1368 | "version": "2.0.3", 1369 | "resolved": "https://registry.npmjs.org/jwks-rsa/-/jwks-rsa-2.0.3.tgz", 1370 | "integrity": "sha512-/rkjXRWAp0cS00tunsHResw68P5iTQru8+jHufLNv3JHc4nObFEndfEUSuPugh09N+V9XYxKUqi7QrkmCHSSSg==", 1371 | "dependencies": { 1372 | "@types/express-jwt": "0.0.42", 1373 | "debug": "^4.1.0", 1374 | "jose": "^2.0.5", 1375 | "limiter": "^1.1.5", 1376 | "lru-memoizer": "^2.1.2" 1377 | }, 1378 | "engines": { 1379 | "node": ">=10 < 13 || >=14" 1380 | } 1381 | }, 1382 | "node_modules/jwks-rsa/node_modules/debug": { 1383 | "version": "4.3.1", 1384 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 1385 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 1386 | "dependencies": { 1387 | "ms": "2.1.2" 1388 | }, 1389 | "engines": { 1390 | "node": ">=6.0" 1391 | }, 1392 | "peerDependenciesMeta": { 1393 | "supports-color": { 1394 | "optional": true 1395 | } 1396 | } 1397 | }, 1398 | "node_modules/jwks-rsa/node_modules/ms": { 1399 | "version": "2.1.2", 1400 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1401 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1402 | }, 1403 | "node_modules/jws": { 1404 | "version": "4.0.0", 1405 | "resolved": "https://registry.npmjs.org/jws/-/jws-4.0.0.tgz", 1406 | "integrity": "sha512-KDncfTmOZoOMTFG4mBlG0qUIOlc03fmzH+ru6RgYVZhPkyiy/92Owlt/8UEN+a4TXR1FQetfIpJE8ApdvdVxTg==", 1407 | "optional": true, 1408 | "dependencies": { 1409 | "jwa": "^2.0.0", 1410 | "safe-buffer": "^5.0.1" 1411 | } 1412 | }, 1413 | "node_modules/limiter": { 1414 | "version": "1.1.5", 1415 | "resolved": "https://registry.npmjs.org/limiter/-/limiter-1.1.5.tgz", 1416 | "integrity": "sha512-FWWMIEOxz3GwUI4Ts/IvgVy6LPvoMPgjMdQ185nN6psJyBJ4yOpzqm695/h5umdLJg2vW3GR5iG11MAkR2AzJA==" 1417 | }, 1418 | "node_modules/lodash": { 1419 | "version": "4.17.21", 1420 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1421 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 1422 | }, 1423 | "node_modules/lodash.camelcase": { 1424 | "version": "4.3.0", 1425 | "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", 1426 | "integrity": "sha1-soqmKIorn8ZRA1x3EfZathkDMaY=", 1427 | "optional": true 1428 | }, 1429 | "node_modules/lodash.clonedeep": { 1430 | "version": "4.5.0", 1431 | "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", 1432 | "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=" 1433 | }, 1434 | "node_modules/lodash.includes": { 1435 | "version": "4.3.0", 1436 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 1437 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 1438 | }, 1439 | "node_modules/lodash.isboolean": { 1440 | "version": "3.0.3", 1441 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 1442 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 1443 | }, 1444 | "node_modules/lodash.isinteger": { 1445 | "version": "4.0.4", 1446 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 1447 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 1448 | }, 1449 | "node_modules/lodash.isnumber": { 1450 | "version": "3.0.3", 1451 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 1452 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 1453 | }, 1454 | "node_modules/lodash.isplainobject": { 1455 | "version": "4.0.6", 1456 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 1457 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 1458 | }, 1459 | "node_modules/lodash.isstring": { 1460 | "version": "4.0.1", 1461 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 1462 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 1463 | }, 1464 | "node_modules/lodash.once": { 1465 | "version": "4.1.1", 1466 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1467 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 1468 | }, 1469 | "node_modules/long": { 1470 | "version": "4.0.0", 1471 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 1472 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==", 1473 | "optional": true 1474 | }, 1475 | "node_modules/lru-cache": { 1476 | "version": "6.0.0", 1477 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1478 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1479 | "optional": true, 1480 | "dependencies": { 1481 | "yallist": "^4.0.0" 1482 | }, 1483 | "engines": { 1484 | "node": ">=10" 1485 | } 1486 | }, 1487 | "node_modules/lru-memoizer": { 1488 | "version": "2.1.4", 1489 | "resolved": "https://registry.npmjs.org/lru-memoizer/-/lru-memoizer-2.1.4.tgz", 1490 | "integrity": "sha512-IXAq50s4qwrOBrXJklY+KhgZF+5y98PDaNo0gi/v2KQBFLyWr+JyFvijZXkGKjQj/h9c0OwoE+JZbwUXce76hQ==", 1491 | "dependencies": { 1492 | "lodash.clonedeep": "^4.5.0", 1493 | "lru-cache": "~4.0.0" 1494 | } 1495 | }, 1496 | "node_modules/lru-memoizer/node_modules/lru-cache": { 1497 | "version": "4.0.2", 1498 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.0.2.tgz", 1499 | "integrity": "sha1-HRdnnAac2l0ECZGgnbwsDbN35V4=", 1500 | "dependencies": { 1501 | "pseudomap": "^1.0.1", 1502 | "yallist": "^2.0.0" 1503 | } 1504 | }, 1505 | "node_modules/lru-memoizer/node_modules/yallist": { 1506 | "version": "2.1.2", 1507 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 1508 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 1509 | }, 1510 | "node_modules/make-dir": { 1511 | "version": "3.1.0", 1512 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 1513 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 1514 | "optional": true, 1515 | "dependencies": { 1516 | "semver": "^6.0.0" 1517 | }, 1518 | "engines": { 1519 | "node": ">=8" 1520 | }, 1521 | "funding": { 1522 | "url": "https://github.com/sponsors/sindresorhus" 1523 | } 1524 | }, 1525 | "node_modules/make-dir/node_modules/semver": { 1526 | "version": "6.3.0", 1527 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1528 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1529 | "optional": true, 1530 | "bin": { 1531 | "semver": "bin/semver.js" 1532 | } 1533 | }, 1534 | "node_modules/media-typer": { 1535 | "version": "0.3.0", 1536 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1537 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=", 1538 | "engines": { 1539 | "node": ">= 0.6" 1540 | } 1541 | }, 1542 | "node_modules/merge-descriptors": { 1543 | "version": "1.0.1", 1544 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1545 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1546 | }, 1547 | "node_modules/methods": { 1548 | "version": "1.1.2", 1549 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1550 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", 1551 | "engines": { 1552 | "node": ">= 0.6" 1553 | } 1554 | }, 1555 | "node_modules/mime": { 1556 | "version": "2.5.2", 1557 | "resolved": "https://registry.npmjs.org/mime/-/mime-2.5.2.tgz", 1558 | "integrity": "sha512-tqkh47FzKeCPD2PUiPB6pkbMzsCasjxAfC62/Wap5qrUWcb+sFasXUC5I3gYM5iBM8v/Qpn4UK0x+j0iHyFPDg==", 1559 | "optional": true, 1560 | "bin": { 1561 | "mime": "cli.js" 1562 | }, 1563 | "engines": { 1564 | "node": ">=4.0.0" 1565 | } 1566 | }, 1567 | "node_modules/mime-db": { 1568 | "version": "1.47.0", 1569 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.47.0.tgz", 1570 | "integrity": "sha512-QBmA/G2y+IfeS4oktet3qRZ+P5kPhCKRXxXnQEudYqUaEioAU1/Lq2us3D/t1Jfo4hE9REQPrbB7K5sOczJVIw==", 1571 | "engines": { 1572 | "node": ">= 0.6" 1573 | } 1574 | }, 1575 | "node_modules/mime-types": { 1576 | "version": "2.1.30", 1577 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.30.tgz", 1578 | "integrity": "sha512-crmjA4bLtR8m9qLpHvgxSChT+XoSlZi8J4n/aIdn3z92e/U47Z0V/yl+Wh9W046GgFVAmoNR/fmdbZYcSSIUeg==", 1579 | "dependencies": { 1580 | "mime-db": "1.47.0" 1581 | }, 1582 | "engines": { 1583 | "node": ">= 0.6" 1584 | } 1585 | }, 1586 | "node_modules/mimic-fn": { 1587 | "version": "2.1.0", 1588 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1589 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1590 | "optional": true, 1591 | "engines": { 1592 | "node": ">=6" 1593 | } 1594 | }, 1595 | "node_modules/ms": { 1596 | "version": "2.0.0", 1597 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1598 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1599 | }, 1600 | "node_modules/negotiator": { 1601 | "version": "0.6.2", 1602 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 1603 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==", 1604 | "engines": { 1605 | "node": ">= 0.6" 1606 | } 1607 | }, 1608 | "node_modules/node-fetch": { 1609 | "version": "2.6.1", 1610 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.1.tgz", 1611 | "integrity": "sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw==", 1612 | "optional": true, 1613 | "engines": { 1614 | "node": "4.x || >=6.0.0" 1615 | } 1616 | }, 1617 | "node_modules/node-forge": { 1618 | "version": "0.10.0", 1619 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-0.10.0.tgz", 1620 | "integrity": "sha512-PPmu8eEeG9saEUvI97fm4OYxXVB6bFvyNTyiUOBichBpFG8A1Ljw3bY62+5oOjDEMHRnd0Y7HQ+x7uzxOzC6JA==", 1621 | "engines": { 1622 | "node": ">= 6.0.0" 1623 | } 1624 | }, 1625 | "node_modules/object-assign": { 1626 | "version": "4.1.1", 1627 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1628 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1629 | "engines": { 1630 | "node": ">=0.10.0" 1631 | } 1632 | }, 1633 | "node_modules/object-hash": { 1634 | "version": "2.2.0", 1635 | "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-2.2.0.tgz", 1636 | "integrity": "sha512-gScRMn0bS5fH+IuwyIFgnh9zBdo4DV+6GhygmWM9HyNJSgS0hScp1f5vjtm7oIIOiT9trXrShAkLFSc2IqKNgw==", 1637 | "optional": true, 1638 | "engines": { 1639 | "node": ">= 6" 1640 | } 1641 | }, 1642 | "node_modules/on-finished": { 1643 | "version": "2.3.0", 1644 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1645 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1646 | "dependencies": { 1647 | "ee-first": "1.1.1" 1648 | }, 1649 | "engines": { 1650 | "node": ">= 0.8" 1651 | } 1652 | }, 1653 | "node_modules/once": { 1654 | "version": "1.4.0", 1655 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1656 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1657 | "optional": true, 1658 | "dependencies": { 1659 | "wrappy": "1" 1660 | } 1661 | }, 1662 | "node_modules/onetime": { 1663 | "version": "5.1.2", 1664 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 1665 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 1666 | "optional": true, 1667 | "dependencies": { 1668 | "mimic-fn": "^2.1.0" 1669 | }, 1670 | "engines": { 1671 | "node": ">=6" 1672 | }, 1673 | "funding": { 1674 | "url": "https://github.com/sponsors/sindresorhus" 1675 | } 1676 | }, 1677 | "node_modules/p-limit": { 1678 | "version": "3.1.0", 1679 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1680 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1681 | "optional": true, 1682 | "dependencies": { 1683 | "yocto-queue": "^0.1.0" 1684 | }, 1685 | "engines": { 1686 | "node": ">=10" 1687 | }, 1688 | "funding": { 1689 | "url": "https://github.com/sponsors/sindresorhus" 1690 | } 1691 | }, 1692 | "node_modules/parseurl": { 1693 | "version": "1.3.3", 1694 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1695 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1696 | "engines": { 1697 | "node": ">= 0.8" 1698 | } 1699 | }, 1700 | "node_modules/path-to-regexp": { 1701 | "version": "0.1.7", 1702 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1703 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1704 | }, 1705 | "node_modules/protobufjs": { 1706 | "version": "6.11.2", 1707 | "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.11.2.tgz", 1708 | "integrity": "sha512-4BQJoPooKJl2G9j3XftkIXjoC9C0Av2NOrWmbLWT1vH32GcSUHjM0Arra6UfTsVyfMAuFzaLucXn1sadxJydAw==", 1709 | "hasInstallScript": true, 1710 | "optional": true, 1711 | "dependencies": { 1712 | "@protobufjs/aspromise": "^1.1.2", 1713 | "@protobufjs/base64": "^1.1.2", 1714 | "@protobufjs/codegen": "^2.0.4", 1715 | "@protobufjs/eventemitter": "^1.1.0", 1716 | "@protobufjs/fetch": "^1.1.0", 1717 | "@protobufjs/float": "^1.0.2", 1718 | "@protobufjs/inquire": "^1.1.0", 1719 | "@protobufjs/path": "^1.1.2", 1720 | "@protobufjs/pool": "^1.1.0", 1721 | "@protobufjs/utf8": "^1.1.0", 1722 | "@types/long": "^4.0.1", 1723 | "@types/node": ">=13.7.0", 1724 | "long": "^4.0.0" 1725 | }, 1726 | "bin": { 1727 | "pbjs": "bin/pbjs", 1728 | "pbts": "bin/pbts" 1729 | } 1730 | }, 1731 | "node_modules/proxy-addr": { 1732 | "version": "2.0.6", 1733 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz", 1734 | "integrity": "sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw==", 1735 | "dependencies": { 1736 | "forwarded": "~0.1.2", 1737 | "ipaddr.js": "1.9.1" 1738 | }, 1739 | "engines": { 1740 | "node": ">= 0.10" 1741 | } 1742 | }, 1743 | "node_modules/pseudomap": { 1744 | "version": "1.0.2", 1745 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 1746 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 1747 | }, 1748 | "node_modules/pump": { 1749 | "version": "3.0.0", 1750 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1751 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1752 | "optional": true, 1753 | "dependencies": { 1754 | "end-of-stream": "^1.1.0", 1755 | "once": "^1.3.1" 1756 | } 1757 | }, 1758 | "node_modules/pumpify": { 1759 | "version": "2.0.1", 1760 | "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-2.0.1.tgz", 1761 | "integrity": "sha512-m7KOje7jZxrmutanlkS1daj1dS6z6BgslzOXmcSEpIlCxM3VJH7lG5QLeck/6hgF6F4crFf01UtQmNsJfweTAw==", 1762 | "optional": true, 1763 | "dependencies": { 1764 | "duplexify": "^4.1.1", 1765 | "inherits": "^2.0.3", 1766 | "pump": "^3.0.0" 1767 | } 1768 | }, 1769 | "node_modules/qs": { 1770 | "version": "6.7.0", 1771 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 1772 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==", 1773 | "engines": { 1774 | "node": ">=0.6" 1775 | } 1776 | }, 1777 | "node_modules/range-parser": { 1778 | "version": "1.2.1", 1779 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1780 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1781 | "engines": { 1782 | "node": ">= 0.6" 1783 | } 1784 | }, 1785 | "node_modules/raw-body": { 1786 | "version": "2.4.0", 1787 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 1788 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 1789 | "dependencies": { 1790 | "bytes": "3.1.0", 1791 | "http-errors": "1.7.2", 1792 | "iconv-lite": "0.4.24", 1793 | "unpipe": "1.0.0" 1794 | }, 1795 | "engines": { 1796 | "node": ">= 0.8" 1797 | } 1798 | }, 1799 | "node_modules/readable-stream": { 1800 | "version": "3.6.0", 1801 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 1802 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 1803 | "optional": true, 1804 | "dependencies": { 1805 | "inherits": "^2.0.3", 1806 | "string_decoder": "^1.1.1", 1807 | "util-deprecate": "^1.0.1" 1808 | }, 1809 | "engines": { 1810 | "node": ">= 6" 1811 | } 1812 | }, 1813 | "node_modules/require-directory": { 1814 | "version": "2.1.1", 1815 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1816 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1817 | "optional": true, 1818 | "engines": { 1819 | "node": ">=0.10.0" 1820 | } 1821 | }, 1822 | "node_modules/retry": { 1823 | "version": "0.12.0", 1824 | "resolved": "https://registry.npmjs.org/retry/-/retry-0.12.0.tgz", 1825 | "integrity": "sha1-G0KmJmoh8HQh0bC1S33BZ7AcATs=", 1826 | "optional": true, 1827 | "engines": { 1828 | "node": ">= 4" 1829 | } 1830 | }, 1831 | "node_modules/retry-request": { 1832 | "version": "4.1.3", 1833 | "resolved": "https://registry.npmjs.org/retry-request/-/retry-request-4.1.3.tgz", 1834 | "integrity": "sha512-QnRZUpuPNgX0+D1xVxul6DbJ9slvo4Rm6iV/dn63e048MvGbUZiKySVt6Tenp04JqmchxjiLltGerOJys7kJYQ==", 1835 | "optional": true, 1836 | "dependencies": { 1837 | "debug": "^4.1.1" 1838 | }, 1839 | "engines": { 1840 | "node": ">=8.10.0" 1841 | } 1842 | }, 1843 | "node_modules/retry-request/node_modules/debug": { 1844 | "version": "4.3.1", 1845 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 1846 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 1847 | "optional": true, 1848 | "dependencies": { 1849 | "ms": "2.1.2" 1850 | }, 1851 | "engines": { 1852 | "node": ">=6.0" 1853 | }, 1854 | "peerDependenciesMeta": { 1855 | "supports-color": { 1856 | "optional": true 1857 | } 1858 | } 1859 | }, 1860 | "node_modules/retry-request/node_modules/ms": { 1861 | "version": "2.1.2", 1862 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1863 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1864 | "optional": true 1865 | }, 1866 | "node_modules/safe-buffer": { 1867 | "version": "5.1.2", 1868 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1869 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1870 | }, 1871 | "node_modules/safer-buffer": { 1872 | "version": "2.1.2", 1873 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1874 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1875 | }, 1876 | "node_modules/semver": { 1877 | "version": "5.7.1", 1878 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1879 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1880 | "bin": { 1881 | "semver": "bin/semver" 1882 | } 1883 | }, 1884 | "node_modules/send": { 1885 | "version": "0.17.1", 1886 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 1887 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 1888 | "dependencies": { 1889 | "debug": "2.6.9", 1890 | "depd": "~1.1.2", 1891 | "destroy": "~1.0.4", 1892 | "encodeurl": "~1.0.2", 1893 | "escape-html": "~1.0.3", 1894 | "etag": "~1.8.1", 1895 | "fresh": "0.5.2", 1896 | "http-errors": "~1.7.2", 1897 | "mime": "1.6.0", 1898 | "ms": "2.1.1", 1899 | "on-finished": "~2.3.0", 1900 | "range-parser": "~1.2.1", 1901 | "statuses": "~1.5.0" 1902 | }, 1903 | "engines": { 1904 | "node": ">= 0.8.0" 1905 | } 1906 | }, 1907 | "node_modules/send/node_modules/mime": { 1908 | "version": "1.6.0", 1909 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1910 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 1911 | "bin": { 1912 | "mime": "cli.js" 1913 | }, 1914 | "engines": { 1915 | "node": ">=4" 1916 | } 1917 | }, 1918 | "node_modules/send/node_modules/ms": { 1919 | "version": "2.1.1", 1920 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1921 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1922 | }, 1923 | "node_modules/serve-static": { 1924 | "version": "1.14.1", 1925 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 1926 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 1927 | "dependencies": { 1928 | "encodeurl": "~1.0.2", 1929 | "escape-html": "~1.0.3", 1930 | "parseurl": "~1.3.3", 1931 | "send": "0.17.1" 1932 | }, 1933 | "engines": { 1934 | "node": ">= 0.8.0" 1935 | } 1936 | }, 1937 | "node_modules/setprototypeof": { 1938 | "version": "1.1.1", 1939 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 1940 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 1941 | }, 1942 | "node_modules/signal-exit": { 1943 | "version": "3.0.3", 1944 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 1945 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 1946 | "optional": true 1947 | }, 1948 | "node_modules/snakeize": { 1949 | "version": "0.1.0", 1950 | "resolved": "https://registry.npmjs.org/snakeize/-/snakeize-0.1.0.tgz", 1951 | "integrity": "sha1-EMCI2LWOsHazIpu1oE4jLOEmQi0=", 1952 | "optional": true 1953 | }, 1954 | "node_modules/statuses": { 1955 | "version": "1.5.0", 1956 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1957 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 1958 | "engines": { 1959 | "node": ">= 0.6" 1960 | } 1961 | }, 1962 | "node_modules/stream-events": { 1963 | "version": "1.0.5", 1964 | "resolved": "https://registry.npmjs.org/stream-events/-/stream-events-1.0.5.tgz", 1965 | "integrity": "sha512-E1GUzBSgvct8Jsb3v2X15pjzN1tYebtbLaMg+eBOUOAxgbLoSbT2NS91ckc5lJD1KfLjId+jXJRgo0qnV5Nerg==", 1966 | "optional": true, 1967 | "dependencies": { 1968 | "stubs": "^3.0.0" 1969 | } 1970 | }, 1971 | "node_modules/stream-shift": { 1972 | "version": "1.0.1", 1973 | "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.1.tgz", 1974 | "integrity": "sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ==", 1975 | "optional": true 1976 | }, 1977 | "node_modules/streamsearch": { 1978 | "version": "0.1.2", 1979 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-0.1.2.tgz", 1980 | "integrity": "sha1-gIudDlb8Jz2Am6VzOOkpkZoanxo=", 1981 | "engines": { 1982 | "node": ">=0.8.0" 1983 | } 1984 | }, 1985 | "node_modules/string_decoder": { 1986 | "version": "1.3.0", 1987 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 1988 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 1989 | "optional": true, 1990 | "dependencies": { 1991 | "safe-buffer": "~5.2.0" 1992 | } 1993 | }, 1994 | "node_modules/string_decoder/node_modules/safe-buffer": { 1995 | "version": "5.2.1", 1996 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1997 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1998 | "funding": [ 1999 | { 2000 | "type": "github", 2001 | "url": "https://github.com/sponsors/feross" 2002 | }, 2003 | { 2004 | "type": "patreon", 2005 | "url": "https://www.patreon.com/feross" 2006 | }, 2007 | { 2008 | "type": "consulting", 2009 | "url": "https://feross.org/support" 2010 | } 2011 | ], 2012 | "optional": true 2013 | }, 2014 | "node_modules/string-width": { 2015 | "version": "4.2.2", 2016 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 2017 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 2018 | "optional": true, 2019 | "dependencies": { 2020 | "emoji-regex": "^8.0.0", 2021 | "is-fullwidth-code-point": "^3.0.0", 2022 | "strip-ansi": "^6.0.0" 2023 | }, 2024 | "engines": { 2025 | "node": ">=8" 2026 | } 2027 | }, 2028 | "node_modules/strip-ansi": { 2029 | "version": "6.0.0", 2030 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 2031 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 2032 | "optional": true, 2033 | "dependencies": { 2034 | "ansi-regex": "^5.0.0" 2035 | }, 2036 | "engines": { 2037 | "node": ">=8" 2038 | } 2039 | }, 2040 | "node_modules/stubs": { 2041 | "version": "3.0.0", 2042 | "resolved": "https://registry.npmjs.org/stubs/-/stubs-3.0.0.tgz", 2043 | "integrity": "sha1-6NK6H6nJBXAwPAMLaQD31fiavls=", 2044 | "optional": true 2045 | }, 2046 | "node_modules/teeny-request": { 2047 | "version": "7.1.0", 2048 | "resolved": "https://registry.npmjs.org/teeny-request/-/teeny-request-7.1.0.tgz", 2049 | "integrity": "sha512-hPfSc05a7Mf3syqVhSkrVMb844sMiP60MrfGMts3ft6V6UlSkEIGQzgwf0dy1KjdE3FV2lJ5s7QCBFcaoQLA6g==", 2050 | "optional": true, 2051 | "dependencies": { 2052 | "http-proxy-agent": "^4.0.0", 2053 | "https-proxy-agent": "^5.0.0", 2054 | "node-fetch": "^2.6.1", 2055 | "stream-events": "^1.0.5", 2056 | "uuid": "^8.0.0" 2057 | }, 2058 | "engines": { 2059 | "node": ">=10" 2060 | } 2061 | }, 2062 | "node_modules/toidentifier": { 2063 | "version": "1.0.0", 2064 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 2065 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", 2066 | "engines": { 2067 | "node": ">=0.6" 2068 | } 2069 | }, 2070 | "node_modules/tslib": { 2071 | "version": "2.2.0", 2072 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.2.0.tgz", 2073 | "integrity": "sha512-gS9GVHRU+RGn5KQM2rllAlR3dU6m7AcpJKdtH8gFvQiC4Otgk98XnmMU+nZenHt/+VhnBPWwgrJsyrdcw6i23w==" 2074 | }, 2075 | "node_modules/type-is": { 2076 | "version": "1.6.18", 2077 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2078 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2079 | "dependencies": { 2080 | "media-typer": "0.3.0", 2081 | "mime-types": "~2.1.24" 2082 | }, 2083 | "engines": { 2084 | "node": ">= 0.6" 2085 | } 2086 | }, 2087 | "node_modules/typedarray-to-buffer": { 2088 | "version": "3.1.5", 2089 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 2090 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 2091 | "optional": true, 2092 | "dependencies": { 2093 | "is-typedarray": "^1.0.0" 2094 | } 2095 | }, 2096 | "node_modules/typescript": { 2097 | "version": "3.9.9", 2098 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.9.9.tgz", 2099 | "integrity": "sha512-kdMjTiekY+z/ubJCATUPlRDl39vXYiMV9iyeMuEuXZh2we6zz80uovNN2WlAxmmdE/Z/YQe+EbOEXB5RHEED3w==", 2100 | "dev": true, 2101 | "bin": { 2102 | "tsc": "bin/tsc", 2103 | "tsserver": "bin/tsserver" 2104 | }, 2105 | "engines": { 2106 | "node": ">=4.2.0" 2107 | } 2108 | }, 2109 | "node_modules/unique-string": { 2110 | "version": "2.0.0", 2111 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", 2112 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", 2113 | "optional": true, 2114 | "dependencies": { 2115 | "crypto-random-string": "^2.0.0" 2116 | }, 2117 | "engines": { 2118 | "node": ">=8" 2119 | } 2120 | }, 2121 | "node_modules/unpipe": { 2122 | "version": "1.0.0", 2123 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2124 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", 2125 | "engines": { 2126 | "node": ">= 0.8" 2127 | } 2128 | }, 2129 | "node_modules/util-deprecate": { 2130 | "version": "1.0.2", 2131 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2132 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2133 | "optional": true 2134 | }, 2135 | "node_modules/utils-merge": { 2136 | "version": "1.0.1", 2137 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2138 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 2139 | "engines": { 2140 | "node": ">= 0.4.0" 2141 | } 2142 | }, 2143 | "node_modules/uuid": { 2144 | "version": "8.3.2", 2145 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 2146 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", 2147 | "optional": true, 2148 | "bin": { 2149 | "uuid": "dist/bin/uuid" 2150 | } 2151 | }, 2152 | "node_modules/vary": { 2153 | "version": "1.1.2", 2154 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2155 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", 2156 | "engines": { 2157 | "node": ">= 0.8" 2158 | } 2159 | }, 2160 | "node_modules/websocket-driver": { 2161 | "version": "0.7.4", 2162 | "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz", 2163 | "integrity": "sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg==", 2164 | "dependencies": { 2165 | "http-parser-js": ">=0.5.1", 2166 | "safe-buffer": ">=5.1.0", 2167 | "websocket-extensions": ">=0.1.1" 2168 | }, 2169 | "engines": { 2170 | "node": ">=0.8.0" 2171 | } 2172 | }, 2173 | "node_modules/websocket-extensions": { 2174 | "version": "0.1.4", 2175 | "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.4.tgz", 2176 | "integrity": "sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==", 2177 | "engines": { 2178 | "node": ">=0.8.0" 2179 | } 2180 | }, 2181 | "node_modules/wrap-ansi": { 2182 | "version": "7.0.0", 2183 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2184 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2185 | "optional": true, 2186 | "dependencies": { 2187 | "ansi-styles": "^4.0.0", 2188 | "string-width": "^4.1.0", 2189 | "strip-ansi": "^6.0.0" 2190 | }, 2191 | "engines": { 2192 | "node": ">=10" 2193 | }, 2194 | "funding": { 2195 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2196 | } 2197 | }, 2198 | "node_modules/wrappy": { 2199 | "version": "1.0.2", 2200 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2201 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2202 | "optional": true 2203 | }, 2204 | "node_modules/write-file-atomic": { 2205 | "version": "3.0.3", 2206 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 2207 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 2208 | "optional": true, 2209 | "dependencies": { 2210 | "imurmurhash": "^0.1.4", 2211 | "is-typedarray": "^1.0.0", 2212 | "signal-exit": "^3.0.2", 2213 | "typedarray-to-buffer": "^3.1.5" 2214 | } 2215 | }, 2216 | "node_modules/xdg-basedir": { 2217 | "version": "4.0.0", 2218 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", 2219 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==", 2220 | "optional": true, 2221 | "engines": { 2222 | "node": ">=8" 2223 | } 2224 | }, 2225 | "node_modules/y18n": { 2226 | "version": "5.0.8", 2227 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 2228 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 2229 | "optional": true, 2230 | "engines": { 2231 | "node": ">=10" 2232 | } 2233 | }, 2234 | "node_modules/yallist": { 2235 | "version": "4.0.0", 2236 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2237 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2238 | "optional": true 2239 | }, 2240 | "node_modules/yargs": { 2241 | "version": "16.2.0", 2242 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 2243 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 2244 | "optional": true, 2245 | "dependencies": { 2246 | "cliui": "^7.0.2", 2247 | "escalade": "^3.1.1", 2248 | "get-caller-file": "^2.0.5", 2249 | "require-directory": "^2.1.1", 2250 | "string-width": "^4.2.0", 2251 | "y18n": "^5.0.5", 2252 | "yargs-parser": "^20.2.2" 2253 | }, 2254 | "engines": { 2255 | "node": ">=10" 2256 | } 2257 | }, 2258 | "node_modules/yargs-parser": { 2259 | "version": "20.2.7", 2260 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.7.tgz", 2261 | "integrity": "sha512-FiNkvbeHzB/syOjIUxFDCnhSfzAL8R5vs40MgLFBorXACCOAEaWu0gRZl14vG8MR9AOJIZbmkjhusqBYZ3HTHw==", 2262 | "optional": true, 2263 | "engines": { 2264 | "node": ">=10" 2265 | } 2266 | }, 2267 | "node_modules/yocto-queue": { 2268 | "version": "0.1.0", 2269 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 2270 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 2271 | "optional": true, 2272 | "engines": { 2273 | "node": ">=10" 2274 | }, 2275 | "funding": { 2276 | "url": "https://github.com/sponsors/sindresorhus" 2277 | } 2278 | } 2279 | }, 2280 | "dependencies": { 2281 | "@firebase/app-types": { 2282 | "version": "0.6.2", 2283 | "resolved": "https://registry.npmjs.org/@firebase/app-types/-/app-types-0.6.2.tgz", 2284 | "integrity": "sha512-2VXvq/K+n8XMdM4L2xy5bYp2ZXMawJXluUIDzUBvMthVR+lhxK4pfFiqr1mmDbv9ydXvEAuFsD+6DpcZuJcSSw==" 2285 | }, 2286 | "@firebase/auth-interop-types": { 2287 | "version": "0.1.6", 2288 | "resolved": "https://registry.npmjs.org/@firebase/auth-interop-types/-/auth-interop-types-0.1.6.tgz", 2289 | "integrity": "sha512-etIi92fW3CctsmR9e3sYM3Uqnoq861M0Id9mdOPF6PWIg38BXL5k4upCNBggGUpLIS0H1grMOvy/wn1xymwe2g==", 2290 | "requires": {} 2291 | }, 2292 | "@firebase/component": { 2293 | "version": "0.5.0", 2294 | "resolved": "https://registry.npmjs.org/@firebase/component/-/component-0.5.0.tgz", 2295 | "integrity": "sha512-v18csWtXb0ri+3m7wuGLY/UDgcb89vuMlZGQ//+7jEPLIQeLbylvZhol1uzW9WzoOpxMxOS2W5qyVGX36wZvEA==", 2296 | "requires": { 2297 | "@firebase/util": "1.1.0", 2298 | "tslib": "^2.1.0" 2299 | } 2300 | }, 2301 | "@firebase/database": { 2302 | "version": "0.10.2", 2303 | "resolved": "https://registry.npmjs.org/@firebase/database/-/database-0.10.2.tgz", 2304 | "integrity": "sha512-jMGtl5eBES9k0rOIZd6/EAuVB6m3LzRei1lvEiqWWBje2Xoz//7sjZcxOYtAKCCLldEI1EUrzW8Tv5yEAoPPpg==", 2305 | "requires": { 2306 | "@firebase/auth-interop-types": "0.1.6", 2307 | "@firebase/component": "0.5.0", 2308 | "@firebase/database-types": "0.7.2", 2309 | "@firebase/logger": "0.2.6", 2310 | "@firebase/util": "1.1.0", 2311 | "faye-websocket": "0.11.3", 2312 | "tslib": "^2.1.0" 2313 | } 2314 | }, 2315 | "@firebase/database-types": { 2316 | "version": "0.7.2", 2317 | "resolved": "https://registry.npmjs.org/@firebase/database-types/-/database-types-0.7.2.tgz", 2318 | "integrity": "sha512-cdAd/dgwvC0r3oLEDUR+ULs1vBsEvy0b27nlzKhU6LQgm9fCDzgaH9nFGv8x+S9dly4B0egAXkONkVoWcOAisg==", 2319 | "requires": { 2320 | "@firebase/app-types": "0.6.2" 2321 | } 2322 | }, 2323 | "@firebase/logger": { 2324 | "version": "0.2.6", 2325 | "resolved": "https://registry.npmjs.org/@firebase/logger/-/logger-0.2.6.tgz", 2326 | "integrity": "sha512-KIxcUvW/cRGWlzK9Vd2KB864HlUnCfdTH0taHE0sXW5Xl7+W68suaeau1oKNEqmc3l45azkd4NzXTCWZRZdXrw==" 2327 | }, 2328 | "@firebase/util": { 2329 | "version": "1.1.0", 2330 | "resolved": "https://registry.npmjs.org/@firebase/util/-/util-1.1.0.tgz", 2331 | "integrity": "sha512-lfuSASuPKNdfebuFR8rjFamMQUPH9iiZHcKS755Rkm/5gRT0qC7BMhCh3ZkHf7NVbplzIc/GhmX2jM+igDRCag==", 2332 | "requires": { 2333 | "tslib": "^2.1.0" 2334 | } 2335 | }, 2336 | "@google-cloud/common": { 2337 | "version": "3.6.0", 2338 | "resolved": "https://registry.npmjs.org/@google-cloud/common/-/common-3.6.0.tgz", 2339 | "integrity": "sha512-aHIFTqJZmeTNO9md8XxV+ywuvXF3xBm5WNmgWeeCK+XN5X+kGW0WEX94wGwj+/MdOnrVf4dL2RvSIt9J5yJG6Q==", 2340 | "optional": true, 2341 | "requires": { 2342 | "@google-cloud/projectify": "^2.0.0", 2343 | "@google-cloud/promisify": "^2.0.0", 2344 | "arrify": "^2.0.1", 2345 | "duplexify": "^4.1.1", 2346 | "ent": "^2.2.0", 2347 | "extend": "^3.0.2", 2348 | "google-auth-library": "^7.0.2", 2349 | "retry-request": "^4.1.1", 2350 | "teeny-request": "^7.0.0" 2351 | } 2352 | }, 2353 | "@google-cloud/firestore": { 2354 | "version": "4.12.2", 2355 | "resolved": "https://registry.npmjs.org/@google-cloud/firestore/-/firestore-4.12.2.tgz", 2356 | "integrity": "sha512-5rurTAJXQ0SANEf8K9eA2JAB5zAh+pu4tGRnkZx5gBWQLZXdBFdtepS+irvKuSXw1KbeAQOuRANSc/nguys6SQ==", 2357 | "optional": true, 2358 | "requires": { 2359 | "fast-deep-equal": "^3.1.1", 2360 | "functional-red-black-tree": "^1.0.1", 2361 | "google-gax": "^2.12.0", 2362 | "protobufjs": "^6.8.6" 2363 | } 2364 | }, 2365 | "@google-cloud/paginator": { 2366 | "version": "3.0.5", 2367 | "resolved": "https://registry.npmjs.org/@google-cloud/paginator/-/paginator-3.0.5.tgz", 2368 | "integrity": "sha512-N4Uk4BT1YuskfRhKXBs0n9Lg2YTROZc6IMpkO/8DIHODtm5s3xY8K5vVBo23v/2XulY3azwITQlYWgT4GdLsUw==", 2369 | "optional": true, 2370 | "requires": { 2371 | "arrify": "^2.0.0", 2372 | "extend": "^3.0.2" 2373 | } 2374 | }, 2375 | "@google-cloud/projectify": { 2376 | "version": "2.0.1", 2377 | "resolved": "https://registry.npmjs.org/@google-cloud/projectify/-/projectify-2.0.1.tgz", 2378 | "integrity": "sha512-ZDG38U/Yy6Zr21LaR3BTiiLtpJl6RkPS/JwoRT453G+6Q1DhlV0waNf8Lfu+YVYGIIxgKnLayJRfYlFJfiI8iQ==", 2379 | "optional": true 2380 | }, 2381 | "@google-cloud/promisify": { 2382 | "version": "2.0.3", 2383 | "resolved": "https://registry.npmjs.org/@google-cloud/promisify/-/promisify-2.0.3.tgz", 2384 | "integrity": "sha512-d4VSA86eL/AFTe5xtyZX+ePUjE8dIFu2T8zmdeNBSa5/kNgXPCx/o/wbFNHAGLJdGnk1vddRuMESD9HbOC8irw==", 2385 | "optional": true 2386 | }, 2387 | "@google-cloud/storage": { 2388 | "version": "5.8.5", 2389 | "resolved": "https://registry.npmjs.org/@google-cloud/storage/-/storage-5.8.5.tgz", 2390 | "integrity": "sha512-i0gB9CRwQeOBYP7xuvn14M40LhHCwMjceBjxE4CTvsqL519sVY5yVKxLiAedHWGwUZHJNRa7Q2CmNfkdRwVNPg==", 2391 | "optional": true, 2392 | "requires": { 2393 | "@google-cloud/common": "^3.6.0", 2394 | "@google-cloud/paginator": "^3.0.0", 2395 | "@google-cloud/promisify": "^2.0.0", 2396 | "arrify": "^2.0.0", 2397 | "async-retry": "^1.3.1", 2398 | "compressible": "^2.0.12", 2399 | "date-and-time": "^1.0.0", 2400 | "duplexify": "^4.0.0", 2401 | "extend": "^3.0.2", 2402 | "gaxios": "^4.0.0", 2403 | "gcs-resumable-upload": "^3.1.4", 2404 | "get-stream": "^6.0.0", 2405 | "hash-stream-validation": "^0.2.2", 2406 | "mime": "^2.2.0", 2407 | "mime-types": "^2.0.8", 2408 | "onetime": "^5.1.0", 2409 | "p-limit": "^3.0.1", 2410 | "pumpify": "^2.0.0", 2411 | "snakeize": "^0.1.0", 2412 | "stream-events": "^1.0.1", 2413 | "xdg-basedir": "^4.0.0" 2414 | } 2415 | }, 2416 | "@grpc/grpc-js": { 2417 | "version": "1.3.2", 2418 | "resolved": "https://registry.npmjs.org/@grpc/grpc-js/-/grpc-js-1.3.2.tgz", 2419 | "integrity": "sha512-UXepkOKCATJrhHGsxt+CGfpZy9zUn1q9mop5kfcXq1fBkTePxVNPOdnISlCbJFlCtld+pSLGyZCzr9/zVprFKA==", 2420 | "optional": true, 2421 | "requires": { 2422 | "@types/node": ">=12.12.47" 2423 | } 2424 | }, 2425 | "@grpc/proto-loader": { 2426 | "version": "0.6.2", 2427 | "resolved": "https://registry.npmjs.org/@grpc/proto-loader/-/proto-loader-0.6.2.tgz", 2428 | "integrity": "sha512-q2Qle60Ht2OQBCp9S5hv1JbI4uBBq6/mqSevFNK3ZEgRDBCAkWqZPUhD/K9gXOHrHKluliHiVq2L9sw1mVyAIg==", 2429 | "optional": true, 2430 | "requires": { 2431 | "@types/long": "^4.0.1", 2432 | "lodash.camelcase": "^4.3.0", 2433 | "long": "^4.0.0", 2434 | "protobufjs": "^6.10.0", 2435 | "yargs": "^16.1.1" 2436 | } 2437 | }, 2438 | "@panva/asn1.js": { 2439 | "version": "1.0.0", 2440 | "resolved": "https://registry.npmjs.org/@panva/asn1.js/-/asn1.js-1.0.0.tgz", 2441 | "integrity": "sha512-UdkG3mLEqXgnlKsWanWcgb6dOjUzJ+XC5f+aWw30qrtjxeNUSfKX1cd5FBzOaXQumoe9nIqeZUvrRJS03HCCtw==" 2442 | }, 2443 | "@protobufjs/aspromise": { 2444 | "version": "1.1.2", 2445 | "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", 2446 | "integrity": "sha1-m4sMxmPWaafY9vXQiToU00jzD78=", 2447 | "optional": true 2448 | }, 2449 | "@protobufjs/base64": { 2450 | "version": "1.1.2", 2451 | "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", 2452 | "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==", 2453 | "optional": true 2454 | }, 2455 | "@protobufjs/codegen": { 2456 | "version": "2.0.4", 2457 | "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", 2458 | "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==", 2459 | "optional": true 2460 | }, 2461 | "@protobufjs/eventemitter": { 2462 | "version": "1.1.0", 2463 | "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", 2464 | "integrity": "sha1-NVy8mLr61ZePntCV85diHx0Ga3A=", 2465 | "optional": true 2466 | }, 2467 | "@protobufjs/fetch": { 2468 | "version": "1.1.0", 2469 | "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", 2470 | "integrity": "sha1-upn7WYYUr2VwDBYZ/wbUVLDYTEU=", 2471 | "optional": true, 2472 | "requires": { 2473 | "@protobufjs/aspromise": "^1.1.1", 2474 | "@protobufjs/inquire": "^1.1.0" 2475 | } 2476 | }, 2477 | "@protobufjs/float": { 2478 | "version": "1.0.2", 2479 | "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", 2480 | "integrity": "sha1-Xp4avctz/Ap8uLKR33jIy9l7h9E=", 2481 | "optional": true 2482 | }, 2483 | "@protobufjs/inquire": { 2484 | "version": "1.1.0", 2485 | "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", 2486 | "integrity": "sha1-/yAOPnzyQp4tyvwRQIKOjMY48Ik=", 2487 | "optional": true 2488 | }, 2489 | "@protobufjs/path": { 2490 | "version": "1.1.2", 2491 | "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", 2492 | "integrity": "sha1-bMKyDFya1q0NzP0hynZz2Nf79o0=", 2493 | "optional": true 2494 | }, 2495 | "@protobufjs/pool": { 2496 | "version": "1.1.0", 2497 | "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", 2498 | "integrity": "sha1-Cf0V8tbTq/qbZbw2ZQbWrXhG/1Q=", 2499 | "optional": true 2500 | }, 2501 | "@protobufjs/utf8": { 2502 | "version": "1.1.0", 2503 | "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", 2504 | "integrity": "sha1-p3c2C1s5oaLlEG+OhY8v0tBgxXA=", 2505 | "optional": true 2506 | }, 2507 | "@tootallnate/once": { 2508 | "version": "1.1.2", 2509 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 2510 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 2511 | "optional": true 2512 | }, 2513 | "@types/body-parser": { 2514 | "version": "1.19.0", 2515 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.0.tgz", 2516 | "integrity": "sha512-W98JrE0j2K78swW4ukqMleo8R7h/pFETjM2DQ90MF6XK2i4LO4W3gQ71Lt4w3bfm2EvVSyWHplECvB5sK22yFQ==", 2517 | "requires": { 2518 | "@types/connect": "*", 2519 | "@types/node": "*" 2520 | } 2521 | }, 2522 | "@types/connect": { 2523 | "version": "3.4.34", 2524 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.34.tgz", 2525 | "integrity": "sha512-ePPA/JuI+X0vb+gSWlPKOY0NdNAie/rPUqX2GUPpbZwiKTkSPhjXWuee47E4MtE54QVzGCQMQkAL6JhV2E1+cQ==", 2526 | "requires": { 2527 | "@types/node": "*" 2528 | } 2529 | }, 2530 | "@types/express": { 2531 | "version": "4.17.3", 2532 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.3.tgz", 2533 | "integrity": "sha512-I8cGRJj3pyOLs/HndoP+25vOqhqWkAZsWMEmq1qXy/b/M3ppufecUwaK2/TVDVxcV61/iSdhykUjQQ2DLSrTdg==", 2534 | "requires": { 2535 | "@types/body-parser": "*", 2536 | "@types/express-serve-static-core": "*", 2537 | "@types/serve-static": "*" 2538 | } 2539 | }, 2540 | "@types/express-jwt": { 2541 | "version": "0.0.42", 2542 | "resolved": "https://registry.npmjs.org/@types/express-jwt/-/express-jwt-0.0.42.tgz", 2543 | "integrity": "sha512-WszgUddvM1t5dPpJ3LhWNH8kfNN8GPIBrAGxgIYXVCEGx6Bx4A036aAuf/r5WH9DIEdlmp7gHOYvSM6U87B0ag==", 2544 | "requires": { 2545 | "@types/express": "*", 2546 | "@types/express-unless": "*" 2547 | } 2548 | }, 2549 | "@types/express-serve-static-core": { 2550 | "version": "4.17.20", 2551 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.20.tgz", 2552 | "integrity": "sha512-8qqFN4W53IEWa9bdmuVrUcVkFemQWnt5DKPQ/oa8xKDYgtjCr2OO6NX5TIK49NLFr3mPYU2cLh92DQquC3oWWQ==", 2553 | "requires": { 2554 | "@types/node": "*", 2555 | "@types/qs": "*", 2556 | "@types/range-parser": "*" 2557 | } 2558 | }, 2559 | "@types/express-unless": { 2560 | "version": "0.5.1", 2561 | "resolved": "https://registry.npmjs.org/@types/express-unless/-/express-unless-0.5.1.tgz", 2562 | "integrity": "sha512-5fuvg7C69lemNgl0+v+CUxDYWVPSfXHhJPst4yTLcqi4zKJpORCxnDrnnilk3k0DTq/WrAUdvXFs01+vUqUZHw==", 2563 | "requires": { 2564 | "@types/express": "*" 2565 | } 2566 | }, 2567 | "@types/lodash": { 2568 | "version": "4.14.170", 2569 | "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.170.tgz", 2570 | "integrity": "sha512-bpcvu/MKHHeYX+qeEN8GE7DIravODWdACVA1ctevD8CN24RhPZIKMn9ntfAsrvLfSX3cR5RrBKAbYm9bGs0A+Q==", 2571 | "dev": true 2572 | }, 2573 | "@types/long": { 2574 | "version": "4.0.1", 2575 | "resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.1.tgz", 2576 | "integrity": "sha512-5tXH6Bx/kNGd3MgffdmP4dy2Z+G4eaXw0SE81Tq3BNadtnMR5/ySMzX4SLEzHJzSmPNn4HIdpQsBvXMUykr58w==", 2577 | "optional": true 2578 | }, 2579 | "@types/mime": { 2580 | "version": "1.3.2", 2581 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz", 2582 | "integrity": "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==" 2583 | }, 2584 | "@types/node": { 2585 | "version": "15.6.1", 2586 | "resolved": "https://registry.npmjs.org/@types/node/-/node-15.6.1.tgz", 2587 | "integrity": "sha512-7EIraBEyRHEe7CH+Fm1XvgqU6uwZN8Q7jppJGcqjROMT29qhAuuOxYB1uEY5UMYQKEmA5D+5tBnhdaPXSsLONA==" 2588 | }, 2589 | "@types/qs": { 2590 | "version": "6.9.6", 2591 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.6.tgz", 2592 | "integrity": "sha512-0/HnwIfW4ki2D8L8c9GVcG5I72s9jP5GSLVF0VIXDW00kmIpA6O33G7a8n59Tmh7Nz0WUC3rSb7PTY/sdW2JzA==" 2593 | }, 2594 | "@types/range-parser": { 2595 | "version": "1.2.3", 2596 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.3.tgz", 2597 | "integrity": "sha512-ewFXqrQHlFsgc09MK5jP5iR7vumV/BYayNC6PgJO2LPe8vrnNFyjQjSppfEngITi0qvfKtzFvgKymGheFM9UOA==" 2598 | }, 2599 | "@types/serve-static": { 2600 | "version": "1.13.9", 2601 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.9.tgz", 2602 | "integrity": "sha512-ZFqF6qa48XsPdjXV5Gsz0Zqmux2PerNd3a/ktL45mHpa19cuMi/cL8tcxdAx497yRh+QtYPuofjT9oWw9P7nkA==", 2603 | "requires": { 2604 | "@types/mime": "^1", 2605 | "@types/node": "*" 2606 | } 2607 | }, 2608 | "abort-controller": { 2609 | "version": "3.0.0", 2610 | "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", 2611 | "integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==", 2612 | "optional": true, 2613 | "requires": { 2614 | "event-target-shim": "^5.0.0" 2615 | } 2616 | }, 2617 | "accepts": { 2618 | "version": "1.3.7", 2619 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 2620 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 2621 | "requires": { 2622 | "mime-types": "~2.1.24", 2623 | "negotiator": "0.6.2" 2624 | } 2625 | }, 2626 | "agent-base": { 2627 | "version": "6.0.2", 2628 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 2629 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 2630 | "optional": true, 2631 | "requires": { 2632 | "debug": "4" 2633 | }, 2634 | "dependencies": { 2635 | "debug": { 2636 | "version": "4.3.1", 2637 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 2638 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 2639 | "optional": true, 2640 | "requires": { 2641 | "ms": "2.1.2" 2642 | } 2643 | }, 2644 | "ms": { 2645 | "version": "2.1.2", 2646 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2647 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2648 | "optional": true 2649 | } 2650 | } 2651 | }, 2652 | "ansi-regex": { 2653 | "version": "5.0.0", 2654 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 2655 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 2656 | "optional": true 2657 | }, 2658 | "ansi-styles": { 2659 | "version": "4.3.0", 2660 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2661 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2662 | "optional": true, 2663 | "requires": { 2664 | "color-convert": "^2.0.1" 2665 | } 2666 | }, 2667 | "array-flatten": { 2668 | "version": "1.1.1", 2669 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 2670 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 2671 | }, 2672 | "arrify": { 2673 | "version": "2.0.1", 2674 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-2.0.1.tgz", 2675 | "integrity": "sha512-3duEwti880xqi4eAMN8AyR4a0ByT90zoYdLlevfrvU43vb0YZwZVfxOgxWrLXXXpyugL0hNZc9G6BiB5B3nUug==", 2676 | "optional": true 2677 | }, 2678 | "async-retry": { 2679 | "version": "1.3.1", 2680 | "resolved": "https://registry.npmjs.org/async-retry/-/async-retry-1.3.1.tgz", 2681 | "integrity": "sha512-aiieFW/7h3hY0Bq5d+ktDBejxuwR78vRu9hDUdR8rNhSaQ29VzPL4AoIRG7D/c7tdenwOcKvgPM6tIxB3cB6HA==", 2682 | "optional": true, 2683 | "requires": { 2684 | "retry": "0.12.0" 2685 | } 2686 | }, 2687 | "base64-js": { 2688 | "version": "1.5.1", 2689 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 2690 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 2691 | "optional": true 2692 | }, 2693 | "bignumber.js": { 2694 | "version": "9.0.1", 2695 | "resolved": "https://registry.npmjs.org/bignumber.js/-/bignumber.js-9.0.1.tgz", 2696 | "integrity": "sha512-IdZR9mh6ahOBv/hYGiXyVuyCetmGJhtYkqLBpTStdhEGjegpPlUawydyaF3pbIOFynJTpllEs+NP+CS9jKFLjA==", 2697 | "optional": true 2698 | }, 2699 | "body-parser": { 2700 | "version": "1.19.0", 2701 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 2702 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 2703 | "requires": { 2704 | "bytes": "3.1.0", 2705 | "content-type": "~1.0.4", 2706 | "debug": "2.6.9", 2707 | "depd": "~1.1.2", 2708 | "http-errors": "1.7.2", 2709 | "iconv-lite": "0.4.24", 2710 | "on-finished": "~2.3.0", 2711 | "qs": "6.7.0", 2712 | "raw-body": "2.4.0", 2713 | "type-is": "~1.6.17" 2714 | } 2715 | }, 2716 | "buffer-equal-constant-time": { 2717 | "version": "1.0.1", 2718 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 2719 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 2720 | }, 2721 | "bytes": { 2722 | "version": "3.1.0", 2723 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 2724 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 2725 | }, 2726 | "cliui": { 2727 | "version": "7.0.4", 2728 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 2729 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 2730 | "optional": true, 2731 | "requires": { 2732 | "string-width": "^4.2.0", 2733 | "strip-ansi": "^6.0.0", 2734 | "wrap-ansi": "^7.0.0" 2735 | } 2736 | }, 2737 | "color-convert": { 2738 | "version": "2.0.1", 2739 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2740 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2741 | "optional": true, 2742 | "requires": { 2743 | "color-name": "~1.1.4" 2744 | } 2745 | }, 2746 | "color-name": { 2747 | "version": "1.1.4", 2748 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2749 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2750 | "optional": true 2751 | }, 2752 | "compressible": { 2753 | "version": "2.0.18", 2754 | "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz", 2755 | "integrity": "sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==", 2756 | "optional": true, 2757 | "requires": { 2758 | "mime-db": ">= 1.43.0 < 2" 2759 | } 2760 | }, 2761 | "configstore": { 2762 | "version": "5.0.1", 2763 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz", 2764 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==", 2765 | "optional": true, 2766 | "requires": { 2767 | "dot-prop": "^5.2.0", 2768 | "graceful-fs": "^4.1.2", 2769 | "make-dir": "^3.0.0", 2770 | "unique-string": "^2.0.0", 2771 | "write-file-atomic": "^3.0.0", 2772 | "xdg-basedir": "^4.0.0" 2773 | } 2774 | }, 2775 | "content-disposition": { 2776 | "version": "0.5.3", 2777 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 2778 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 2779 | "requires": { 2780 | "safe-buffer": "5.1.2" 2781 | } 2782 | }, 2783 | "content-type": { 2784 | "version": "1.0.4", 2785 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 2786 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 2787 | }, 2788 | "cookie": { 2789 | "version": "0.4.0", 2790 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 2791 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 2792 | }, 2793 | "cookie-signature": { 2794 | "version": "1.0.6", 2795 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 2796 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 2797 | }, 2798 | "cors": { 2799 | "version": "2.8.5", 2800 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 2801 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 2802 | "requires": { 2803 | "object-assign": "^4", 2804 | "vary": "^1" 2805 | } 2806 | }, 2807 | "crypto-random-string": { 2808 | "version": "2.0.0", 2809 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", 2810 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==", 2811 | "optional": true 2812 | }, 2813 | "date-and-time": { 2814 | "version": "1.0.0", 2815 | "resolved": "https://registry.npmjs.org/date-and-time/-/date-and-time-1.0.0.tgz", 2816 | "integrity": "sha512-477D7ypIiqlXBkxhU7YtG9wWZJEQ+RUpujt2quTfgf4+E8g5fNUkB0QIL0bVyP5/TKBg8y55Hfa1R/c4bt3dEw==", 2817 | "optional": true 2818 | }, 2819 | "debug": { 2820 | "version": "2.6.9", 2821 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2822 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2823 | "requires": { 2824 | "ms": "2.0.0" 2825 | } 2826 | }, 2827 | "depd": { 2828 | "version": "1.1.2", 2829 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 2830 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 2831 | }, 2832 | "destroy": { 2833 | "version": "1.0.4", 2834 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 2835 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 2836 | }, 2837 | "dicer": { 2838 | "version": "0.3.0", 2839 | "resolved": "https://registry.npmjs.org/dicer/-/dicer-0.3.0.tgz", 2840 | "integrity": "sha512-MdceRRWqltEG2dZqO769g27N/3PXfcKl04VhYnBlo2YhH7zPi88VebsjTKclaOyiuMaGU72hTfw3VkUitGcVCA==", 2841 | "requires": { 2842 | "streamsearch": "0.1.2" 2843 | } 2844 | }, 2845 | "dot-prop": { 2846 | "version": "5.3.0", 2847 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz", 2848 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==", 2849 | "optional": true, 2850 | "requires": { 2851 | "is-obj": "^2.0.0" 2852 | } 2853 | }, 2854 | "duplexify": { 2855 | "version": "4.1.1", 2856 | "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-4.1.1.tgz", 2857 | "integrity": "sha512-DY3xVEmVHTv1wSzKNbwoU6nVjzI369Y6sPoqfYr0/xlx3IdX2n94xIszTcjPO8W8ZIv0Wb0PXNcjuZyT4wiICA==", 2858 | "optional": true, 2859 | "requires": { 2860 | "end-of-stream": "^1.4.1", 2861 | "inherits": "^2.0.3", 2862 | "readable-stream": "^3.1.1", 2863 | "stream-shift": "^1.0.0" 2864 | } 2865 | }, 2866 | "ecdsa-sig-formatter": { 2867 | "version": "1.0.11", 2868 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 2869 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 2870 | "requires": { 2871 | "safe-buffer": "^5.0.1" 2872 | } 2873 | }, 2874 | "ee-first": { 2875 | "version": "1.1.1", 2876 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 2877 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 2878 | }, 2879 | "emoji-regex": { 2880 | "version": "8.0.0", 2881 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2882 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2883 | "optional": true 2884 | }, 2885 | "encodeurl": { 2886 | "version": "1.0.2", 2887 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 2888 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 2889 | }, 2890 | "end-of-stream": { 2891 | "version": "1.4.4", 2892 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 2893 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 2894 | "optional": true, 2895 | "requires": { 2896 | "once": "^1.4.0" 2897 | } 2898 | }, 2899 | "ent": { 2900 | "version": "2.2.0", 2901 | "resolved": "https://registry.npmjs.org/ent/-/ent-2.2.0.tgz", 2902 | "integrity": "sha1-6WQhkyWiHQX0RGai9obtbOX13R0=", 2903 | "optional": true 2904 | }, 2905 | "escalade": { 2906 | "version": "3.1.1", 2907 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 2908 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 2909 | "optional": true 2910 | }, 2911 | "escape-html": { 2912 | "version": "1.0.3", 2913 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 2914 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 2915 | }, 2916 | "etag": { 2917 | "version": "1.8.1", 2918 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 2919 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 2920 | }, 2921 | "event-target-shim": { 2922 | "version": "5.0.1", 2923 | "resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz", 2924 | "integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==", 2925 | "optional": true 2926 | }, 2927 | "express": { 2928 | "version": "4.17.1", 2929 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 2930 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 2931 | "requires": { 2932 | "accepts": "~1.3.7", 2933 | "array-flatten": "1.1.1", 2934 | "body-parser": "1.19.0", 2935 | "content-disposition": "0.5.3", 2936 | "content-type": "~1.0.4", 2937 | "cookie": "0.4.0", 2938 | "cookie-signature": "1.0.6", 2939 | "debug": "2.6.9", 2940 | "depd": "~1.1.2", 2941 | "encodeurl": "~1.0.2", 2942 | "escape-html": "~1.0.3", 2943 | "etag": "~1.8.1", 2944 | "finalhandler": "~1.1.2", 2945 | "fresh": "0.5.2", 2946 | "merge-descriptors": "1.0.1", 2947 | "methods": "~1.1.2", 2948 | "on-finished": "~2.3.0", 2949 | "parseurl": "~1.3.3", 2950 | "path-to-regexp": "0.1.7", 2951 | "proxy-addr": "~2.0.5", 2952 | "qs": "6.7.0", 2953 | "range-parser": "~1.2.1", 2954 | "safe-buffer": "5.1.2", 2955 | "send": "0.17.1", 2956 | "serve-static": "1.14.1", 2957 | "setprototypeof": "1.1.1", 2958 | "statuses": "~1.5.0", 2959 | "type-is": "~1.6.18", 2960 | "utils-merge": "1.0.1", 2961 | "vary": "~1.1.2" 2962 | } 2963 | }, 2964 | "extend": { 2965 | "version": "3.0.2", 2966 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 2967 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 2968 | "optional": true 2969 | }, 2970 | "fast-deep-equal": { 2971 | "version": "3.1.3", 2972 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2973 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2974 | "optional": true 2975 | }, 2976 | "fast-text-encoding": { 2977 | "version": "1.0.3", 2978 | "resolved": "https://registry.npmjs.org/fast-text-encoding/-/fast-text-encoding-1.0.3.tgz", 2979 | "integrity": "sha512-dtm4QZH9nZtcDt8qJiOH9fcQd1NAgi+K1O2DbE6GG1PPCK/BWfOH3idCTRQ4ImXRUOyopDEgDEnVEE7Y/2Wrig==", 2980 | "optional": true 2981 | }, 2982 | "faye-websocket": { 2983 | "version": "0.11.3", 2984 | "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.3.tgz", 2985 | "integrity": "sha512-D2y4bovYpzziGgbHYtGCMjlJM36vAl/y+xUyn1C+FVx8szd1E+86KwVw6XvYSzOP8iMpm1X0I4xJD+QtUb36OA==", 2986 | "requires": { 2987 | "websocket-driver": ">=0.5.1" 2988 | } 2989 | }, 2990 | "finalhandler": { 2991 | "version": "1.1.2", 2992 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 2993 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 2994 | "requires": { 2995 | "debug": "2.6.9", 2996 | "encodeurl": "~1.0.2", 2997 | "escape-html": "~1.0.3", 2998 | "on-finished": "~2.3.0", 2999 | "parseurl": "~1.3.3", 3000 | "statuses": "~1.5.0", 3001 | "unpipe": "~1.0.0" 3002 | } 3003 | }, 3004 | "firebase-admin": { 3005 | "version": "9.9.0", 3006 | "resolved": "https://registry.npmjs.org/firebase-admin/-/firebase-admin-9.9.0.tgz", 3007 | "integrity": "sha512-04HT7JAAqcJYty95qf15IBD9CXf+vr7S8zNU6Zt1ayC1J05DLaCsUd19/sCNAjZ614KHexAYUtyLgZoJwu2wOQ==", 3008 | "requires": { 3009 | "@firebase/database": "^0.10.0", 3010 | "@firebase/database-types": "^0.7.2", 3011 | "@google-cloud/firestore": "^4.5.0", 3012 | "@google-cloud/storage": "^5.3.0", 3013 | "@types/node": ">=12.12.47", 3014 | "dicer": "^0.3.0", 3015 | "jsonwebtoken": "^8.5.1", 3016 | "jwks-rsa": "^2.0.2", 3017 | "node-forge": "^0.10.0" 3018 | } 3019 | }, 3020 | "firebase-functions": { 3021 | "version": "3.14.1", 3022 | "resolved": "https://registry.npmjs.org/firebase-functions/-/firebase-functions-3.14.1.tgz", 3023 | "integrity": "sha512-hL/qm+i5i1qKYmAFMlQ4mwRngDkP+3YT3F4E4Nd5Hj2QKeawBdZiMGgEt6zqTx08Zq04vHiSnSM0z75UJRSg6Q==", 3024 | "requires": { 3025 | "@types/express": "4.17.3", 3026 | "cors": "^2.8.5", 3027 | "express": "^4.17.1", 3028 | "lodash": "^4.17.14" 3029 | } 3030 | }, 3031 | "firebase-functions-test": { 3032 | "version": "0.2.3", 3033 | "resolved": "https://registry.npmjs.org/firebase-functions-test/-/firebase-functions-test-0.2.3.tgz", 3034 | "integrity": "sha512-zYX0QTm53wCazuej7O0xqbHl90r/v1PTXt/hwa0jo1YF8nDM+iBKnLDlkIoW66MDd0R6aGg4BvKzTTdJpvigUA==", 3035 | "dev": true, 3036 | "requires": { 3037 | "@types/lodash": "^4.14.104", 3038 | "lodash": "^4.17.5" 3039 | } 3040 | }, 3041 | "forwarded": { 3042 | "version": "0.1.2", 3043 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 3044 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 3045 | }, 3046 | "fresh": { 3047 | "version": "0.5.2", 3048 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 3049 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 3050 | }, 3051 | "functional-red-black-tree": { 3052 | "version": "1.0.1", 3053 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 3054 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 3055 | "optional": true 3056 | }, 3057 | "gaxios": { 3058 | "version": "4.3.0", 3059 | "resolved": "https://registry.npmjs.org/gaxios/-/gaxios-4.3.0.tgz", 3060 | "integrity": "sha512-pHplNbslpwCLMyII/lHPWFQbJWOX0B3R1hwBEOvzYi1GmdKZruuEHK4N9V6f7tf1EaPYyF80mui1+344p6SmLg==", 3061 | "optional": true, 3062 | "requires": { 3063 | "abort-controller": "^3.0.0", 3064 | "extend": "^3.0.2", 3065 | "https-proxy-agent": "^5.0.0", 3066 | "is-stream": "^2.0.0", 3067 | "node-fetch": "^2.3.0" 3068 | } 3069 | }, 3070 | "gcp-metadata": { 3071 | "version": "4.2.1", 3072 | "resolved": "https://registry.npmjs.org/gcp-metadata/-/gcp-metadata-4.2.1.tgz", 3073 | "integrity": "sha512-tSk+REe5iq/N+K+SK1XjZJUrFPuDqGZVzCy2vocIHIGmPlTGsa8owXMJwGkrXr73NO0AzhPW4MF2DEHz7P2AVw==", 3074 | "optional": true, 3075 | "requires": { 3076 | "gaxios": "^4.0.0", 3077 | "json-bigint": "^1.0.0" 3078 | } 3079 | }, 3080 | "gcs-resumable-upload": { 3081 | "version": "3.1.4", 3082 | "resolved": "https://registry.npmjs.org/gcs-resumable-upload/-/gcs-resumable-upload-3.1.4.tgz", 3083 | "integrity": "sha512-5dyDfHrrVcIskiw/cPssVD4HRiwoHjhk1Nd6h5W3pQ/qffDvhfy4oNCr1f3ZXFPwTnxkCbibsB+73oOM+NvmJQ==", 3084 | "optional": true, 3085 | "requires": { 3086 | "abort-controller": "^3.0.0", 3087 | "configstore": "^5.0.0", 3088 | "extend": "^3.0.2", 3089 | "gaxios": "^4.0.0", 3090 | "google-auth-library": "^7.0.0", 3091 | "pumpify": "^2.0.0", 3092 | "stream-events": "^1.0.4" 3093 | } 3094 | }, 3095 | "get-caller-file": { 3096 | "version": "2.0.5", 3097 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 3098 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 3099 | "optional": true 3100 | }, 3101 | "get-stream": { 3102 | "version": "6.0.1", 3103 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 3104 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 3105 | "optional": true 3106 | }, 3107 | "google-auth-library": { 3108 | "version": "7.1.0", 3109 | "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-7.1.0.tgz", 3110 | "integrity": "sha512-X+gbkGjnLN3HUZP2W3KBREuA603BXd80ITvL0PeS0QpyDNYz/u0pIZ7aRuGnrSuUc0grk/qxEgtVTFt1ogbP+A==", 3111 | "optional": true, 3112 | "requires": { 3113 | "arrify": "^2.0.0", 3114 | "base64-js": "^1.3.0", 3115 | "ecdsa-sig-formatter": "^1.0.11", 3116 | "fast-text-encoding": "^1.0.0", 3117 | "gaxios": "^4.0.0", 3118 | "gcp-metadata": "^4.2.0", 3119 | "gtoken": "^5.0.4", 3120 | "jws": "^4.0.0", 3121 | "lru-cache": "^6.0.0" 3122 | } 3123 | }, 3124 | "google-gax": { 3125 | "version": "2.14.1", 3126 | "resolved": "https://registry.npmjs.org/google-gax/-/google-gax-2.14.1.tgz", 3127 | "integrity": "sha512-I5RDEN7MEptrCxeHX3ht7nKFGfyjgYX4hQKI9eVMBohMzVbFSwWUndo0CcKXu8es7NhB4gt2XYLm1AHkXhtHpA==", 3128 | "optional": true, 3129 | "requires": { 3130 | "@grpc/grpc-js": "~1.3.0", 3131 | "@grpc/proto-loader": "^0.6.1", 3132 | "@types/long": "^4.0.0", 3133 | "abort-controller": "^3.0.0", 3134 | "duplexify": "^4.0.0", 3135 | "fast-text-encoding": "^1.0.3", 3136 | "google-auth-library": "^7.0.2", 3137 | "is-stream-ended": "^0.1.4", 3138 | "node-fetch": "^2.6.1", 3139 | "object-hash": "^2.1.1", 3140 | "protobufjs": "^6.10.2", 3141 | "retry-request": "^4.0.0" 3142 | } 3143 | }, 3144 | "google-p12-pem": { 3145 | "version": "3.0.3", 3146 | "resolved": "https://registry.npmjs.org/google-p12-pem/-/google-p12-pem-3.0.3.tgz", 3147 | "integrity": "sha512-wS0ek4ZtFx/ACKYF3JhyGe5kzH7pgiQ7J5otlumqR9psmWMYc+U9cErKlCYVYHoUaidXHdZ2xbo34kB+S+24hA==", 3148 | "optional": true, 3149 | "requires": { 3150 | "node-forge": "^0.10.0" 3151 | } 3152 | }, 3153 | "graceful-fs": { 3154 | "version": "4.2.6", 3155 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.6.tgz", 3156 | "integrity": "sha512-nTnJ528pbqxYanhpDYsi4Rd8MAeaBA67+RZ10CM1m3bTAVFEDcd5AuA4a6W5YkGZ1iNXHzZz8T6TBKLeBuNriQ==", 3157 | "optional": true 3158 | }, 3159 | "gtoken": { 3160 | "version": "5.2.1", 3161 | "resolved": "https://registry.npmjs.org/gtoken/-/gtoken-5.2.1.tgz", 3162 | "integrity": "sha512-OY0BfPKe3QnMsY9MzTHTSKn+Vl2l1CcLe6BwDEQj00mbbkl5nyQ/7EUREstg4fQNZ8iYE7br4JJ7TdKeDOPWmw==", 3163 | "optional": true, 3164 | "requires": { 3165 | "gaxios": "^4.0.0", 3166 | "google-p12-pem": "^3.0.3", 3167 | "jws": "^4.0.0" 3168 | } 3169 | }, 3170 | "hash-stream-validation": { 3171 | "version": "0.2.4", 3172 | "resolved": "https://registry.npmjs.org/hash-stream-validation/-/hash-stream-validation-0.2.4.tgz", 3173 | "integrity": "sha512-Gjzu0Xn7IagXVkSu9cSFuK1fqzwtLwFhNhVL8IFJijRNMgUttFbBSIAzKuSIrsFMO1+g1RlsoN49zPIbwPDMGQ==", 3174 | "optional": true 3175 | }, 3176 | "http-errors": { 3177 | "version": "1.7.2", 3178 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 3179 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 3180 | "requires": { 3181 | "depd": "~1.1.2", 3182 | "inherits": "2.0.3", 3183 | "setprototypeof": "1.1.1", 3184 | "statuses": ">= 1.5.0 < 2", 3185 | "toidentifier": "1.0.0" 3186 | }, 3187 | "dependencies": { 3188 | "inherits": { 3189 | "version": "2.0.3", 3190 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 3191 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 3192 | } 3193 | } 3194 | }, 3195 | "http-parser-js": { 3196 | "version": "0.5.3", 3197 | "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.3.tgz", 3198 | "integrity": "sha512-t7hjvef/5HEK7RWTdUzVUhl8zkEu+LlaE0IYzdMuvbSDipxBRpOn4Uhw8ZyECEa808iVT8XCjzo6xmYt4CiLZg==" 3199 | }, 3200 | "http-proxy-agent": { 3201 | "version": "4.0.1", 3202 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 3203 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 3204 | "optional": true, 3205 | "requires": { 3206 | "@tootallnate/once": "1", 3207 | "agent-base": "6", 3208 | "debug": "4" 3209 | }, 3210 | "dependencies": { 3211 | "debug": { 3212 | "version": "4.3.1", 3213 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 3214 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 3215 | "optional": true, 3216 | "requires": { 3217 | "ms": "2.1.2" 3218 | } 3219 | }, 3220 | "ms": { 3221 | "version": "2.1.2", 3222 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3223 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 3224 | "optional": true 3225 | } 3226 | } 3227 | }, 3228 | "https-proxy-agent": { 3229 | "version": "5.0.0", 3230 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 3231 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 3232 | "optional": true, 3233 | "requires": { 3234 | "agent-base": "6", 3235 | "debug": "4" 3236 | }, 3237 | "dependencies": { 3238 | "debug": { 3239 | "version": "4.3.1", 3240 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 3241 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 3242 | "optional": true, 3243 | "requires": { 3244 | "ms": "2.1.2" 3245 | } 3246 | }, 3247 | "ms": { 3248 | "version": "2.1.2", 3249 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3250 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 3251 | "optional": true 3252 | } 3253 | } 3254 | }, 3255 | "iconv-lite": { 3256 | "version": "0.4.24", 3257 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 3258 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 3259 | "requires": { 3260 | "safer-buffer": ">= 2.1.2 < 3" 3261 | } 3262 | }, 3263 | "imurmurhash": { 3264 | "version": "0.1.4", 3265 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 3266 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 3267 | "optional": true 3268 | }, 3269 | "inherits": { 3270 | "version": "2.0.4", 3271 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 3272 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 3273 | "optional": true 3274 | }, 3275 | "ipaddr.js": { 3276 | "version": "1.9.1", 3277 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 3278 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 3279 | }, 3280 | "is-fullwidth-code-point": { 3281 | "version": "3.0.0", 3282 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 3283 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 3284 | "optional": true 3285 | }, 3286 | "is-obj": { 3287 | "version": "2.0.0", 3288 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 3289 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==", 3290 | "optional": true 3291 | }, 3292 | "is-stream": { 3293 | "version": "2.0.0", 3294 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", 3295 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==", 3296 | "optional": true 3297 | }, 3298 | "is-stream-ended": { 3299 | "version": "0.1.4", 3300 | "resolved": "https://registry.npmjs.org/is-stream-ended/-/is-stream-ended-0.1.4.tgz", 3301 | "integrity": "sha512-xj0XPvmr7bQFTvirqnFr50o0hQIh6ZItDqloxt5aJrR4NQsYeSsyFQERYGCAzfindAcnKjINnwEEgLx4IqVzQw==", 3302 | "optional": true 3303 | }, 3304 | "is-typedarray": { 3305 | "version": "1.0.0", 3306 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 3307 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 3308 | "optional": true 3309 | }, 3310 | "jose": { 3311 | "version": "2.0.5", 3312 | "resolved": "https://registry.npmjs.org/jose/-/jose-2.0.5.tgz", 3313 | "integrity": "sha512-BAiDNeDKTMgk4tvD0BbxJ8xHEHBZgpeRZ1zGPPsitSyMgjoMWiLGYAE7H7NpP5h0lPppQajQs871E8NHUrzVPA==", 3314 | "requires": { 3315 | "@panva/asn1.js": "^1.0.0" 3316 | } 3317 | }, 3318 | "json-bigint": { 3319 | "version": "1.0.0", 3320 | "resolved": "https://registry.npmjs.org/json-bigint/-/json-bigint-1.0.0.tgz", 3321 | "integrity": "sha512-SiPv/8VpZuWbvLSMtTDU8hEfrZWg/mH/nV/b4o0CYbSxu1UIQPLdwKOCIyLQX+VIPO5vrLX3i8qtqFyhdPSUSQ==", 3322 | "optional": true, 3323 | "requires": { 3324 | "bignumber.js": "^9.0.0" 3325 | } 3326 | }, 3327 | "jsonwebtoken": { 3328 | "version": "8.5.1", 3329 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", 3330 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", 3331 | "requires": { 3332 | "jws": "^3.2.2", 3333 | "lodash.includes": "^4.3.0", 3334 | "lodash.isboolean": "^3.0.3", 3335 | "lodash.isinteger": "^4.0.4", 3336 | "lodash.isnumber": "^3.0.3", 3337 | "lodash.isplainobject": "^4.0.6", 3338 | "lodash.isstring": "^4.0.1", 3339 | "lodash.once": "^4.0.0", 3340 | "ms": "^2.1.1", 3341 | "semver": "^5.6.0" 3342 | }, 3343 | "dependencies": { 3344 | "jwa": { 3345 | "version": "1.4.1", 3346 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 3347 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 3348 | "requires": { 3349 | "buffer-equal-constant-time": "1.0.1", 3350 | "ecdsa-sig-formatter": "1.0.11", 3351 | "safe-buffer": "^5.0.1" 3352 | } 3353 | }, 3354 | "jws": { 3355 | "version": "3.2.2", 3356 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 3357 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 3358 | "requires": { 3359 | "jwa": "^1.4.1", 3360 | "safe-buffer": "^5.0.1" 3361 | } 3362 | }, 3363 | "ms": { 3364 | "version": "2.1.3", 3365 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 3366 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 3367 | } 3368 | } 3369 | }, 3370 | "jwa": { 3371 | "version": "2.0.0", 3372 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-2.0.0.tgz", 3373 | "integrity": "sha512-jrZ2Qx916EA+fq9cEAeCROWPTfCwi1IVHqT2tapuqLEVVDKFDENFw1oL+MwrTvH6msKxsd1YTDVw6uKEcsrLEA==", 3374 | "optional": true, 3375 | "requires": { 3376 | "buffer-equal-constant-time": "1.0.1", 3377 | "ecdsa-sig-formatter": "1.0.11", 3378 | "safe-buffer": "^5.0.1" 3379 | } 3380 | }, 3381 | "jwks-rsa": { 3382 | "version": "2.0.3", 3383 | "resolved": "https://registry.npmjs.org/jwks-rsa/-/jwks-rsa-2.0.3.tgz", 3384 | "integrity": "sha512-/rkjXRWAp0cS00tunsHResw68P5iTQru8+jHufLNv3JHc4nObFEndfEUSuPugh09N+V9XYxKUqi7QrkmCHSSSg==", 3385 | "requires": { 3386 | "@types/express-jwt": "0.0.42", 3387 | "debug": "^4.1.0", 3388 | "jose": "^2.0.5", 3389 | "limiter": "^1.1.5", 3390 | "lru-memoizer": "^2.1.2" 3391 | }, 3392 | "dependencies": { 3393 | "debug": { 3394 | "version": "4.3.1", 3395 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 3396 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 3397 | "requires": { 3398 | "ms": "2.1.2" 3399 | } 3400 | }, 3401 | "ms": { 3402 | "version": "2.1.2", 3403 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3404 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 3405 | } 3406 | } 3407 | }, 3408 | "jws": { 3409 | "version": "4.0.0", 3410 | "resolved": "https://registry.npmjs.org/jws/-/jws-4.0.0.tgz", 3411 | "integrity": "sha512-KDncfTmOZoOMTFG4mBlG0qUIOlc03fmzH+ru6RgYVZhPkyiy/92Owlt/8UEN+a4TXR1FQetfIpJE8ApdvdVxTg==", 3412 | "optional": true, 3413 | "requires": { 3414 | "jwa": "^2.0.0", 3415 | "safe-buffer": "^5.0.1" 3416 | } 3417 | }, 3418 | "limiter": { 3419 | "version": "1.1.5", 3420 | "resolved": "https://registry.npmjs.org/limiter/-/limiter-1.1.5.tgz", 3421 | "integrity": "sha512-FWWMIEOxz3GwUI4Ts/IvgVy6LPvoMPgjMdQ185nN6psJyBJ4yOpzqm695/h5umdLJg2vW3GR5iG11MAkR2AzJA==" 3422 | }, 3423 | "lodash": { 3424 | "version": "4.17.21", 3425 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 3426 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 3427 | }, 3428 | "lodash.camelcase": { 3429 | "version": "4.3.0", 3430 | "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", 3431 | "integrity": "sha1-soqmKIorn8ZRA1x3EfZathkDMaY=", 3432 | "optional": true 3433 | }, 3434 | "lodash.clonedeep": { 3435 | "version": "4.5.0", 3436 | "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", 3437 | "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=" 3438 | }, 3439 | "lodash.includes": { 3440 | "version": "4.3.0", 3441 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 3442 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 3443 | }, 3444 | "lodash.isboolean": { 3445 | "version": "3.0.3", 3446 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 3447 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 3448 | }, 3449 | "lodash.isinteger": { 3450 | "version": "4.0.4", 3451 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 3452 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 3453 | }, 3454 | "lodash.isnumber": { 3455 | "version": "3.0.3", 3456 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 3457 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 3458 | }, 3459 | "lodash.isplainobject": { 3460 | "version": "4.0.6", 3461 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 3462 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 3463 | }, 3464 | "lodash.isstring": { 3465 | "version": "4.0.1", 3466 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 3467 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 3468 | }, 3469 | "lodash.once": { 3470 | "version": "4.1.1", 3471 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 3472 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 3473 | }, 3474 | "long": { 3475 | "version": "4.0.0", 3476 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 3477 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==", 3478 | "optional": true 3479 | }, 3480 | "lru-cache": { 3481 | "version": "6.0.0", 3482 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 3483 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 3484 | "optional": true, 3485 | "requires": { 3486 | "yallist": "^4.0.0" 3487 | } 3488 | }, 3489 | "lru-memoizer": { 3490 | "version": "2.1.4", 3491 | "resolved": "https://registry.npmjs.org/lru-memoizer/-/lru-memoizer-2.1.4.tgz", 3492 | "integrity": "sha512-IXAq50s4qwrOBrXJklY+KhgZF+5y98PDaNo0gi/v2KQBFLyWr+JyFvijZXkGKjQj/h9c0OwoE+JZbwUXce76hQ==", 3493 | "requires": { 3494 | "lodash.clonedeep": "^4.5.0", 3495 | "lru-cache": "~4.0.0" 3496 | }, 3497 | "dependencies": { 3498 | "lru-cache": { 3499 | "version": "4.0.2", 3500 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.0.2.tgz", 3501 | "integrity": "sha1-HRdnnAac2l0ECZGgnbwsDbN35V4=", 3502 | "requires": { 3503 | "pseudomap": "^1.0.1", 3504 | "yallist": "^2.0.0" 3505 | } 3506 | }, 3507 | "yallist": { 3508 | "version": "2.1.2", 3509 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 3510 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 3511 | } 3512 | } 3513 | }, 3514 | "make-dir": { 3515 | "version": "3.1.0", 3516 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 3517 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 3518 | "optional": true, 3519 | "requires": { 3520 | "semver": "^6.0.0" 3521 | }, 3522 | "dependencies": { 3523 | "semver": { 3524 | "version": "6.3.0", 3525 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 3526 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 3527 | "optional": true 3528 | } 3529 | } 3530 | }, 3531 | "media-typer": { 3532 | "version": "0.3.0", 3533 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 3534 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 3535 | }, 3536 | "merge-descriptors": { 3537 | "version": "1.0.1", 3538 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 3539 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 3540 | }, 3541 | "methods": { 3542 | "version": "1.1.2", 3543 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 3544 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 3545 | }, 3546 | "mime": { 3547 | "version": "2.5.2", 3548 | "resolved": "https://registry.npmjs.org/mime/-/mime-2.5.2.tgz", 3549 | "integrity": "sha512-tqkh47FzKeCPD2PUiPB6pkbMzsCasjxAfC62/Wap5qrUWcb+sFasXUC5I3gYM5iBM8v/Qpn4UK0x+j0iHyFPDg==", 3550 | "optional": true 3551 | }, 3552 | "mime-db": { 3553 | "version": "1.47.0", 3554 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.47.0.tgz", 3555 | "integrity": "sha512-QBmA/G2y+IfeS4oktet3qRZ+P5kPhCKRXxXnQEudYqUaEioAU1/Lq2us3D/t1Jfo4hE9REQPrbB7K5sOczJVIw==" 3556 | }, 3557 | "mime-types": { 3558 | "version": "2.1.30", 3559 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.30.tgz", 3560 | "integrity": "sha512-crmjA4bLtR8m9qLpHvgxSChT+XoSlZi8J4n/aIdn3z92e/U47Z0V/yl+Wh9W046GgFVAmoNR/fmdbZYcSSIUeg==", 3561 | "requires": { 3562 | "mime-db": "1.47.0" 3563 | } 3564 | }, 3565 | "mimic-fn": { 3566 | "version": "2.1.0", 3567 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 3568 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 3569 | "optional": true 3570 | }, 3571 | "ms": { 3572 | "version": "2.0.0", 3573 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 3574 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 3575 | }, 3576 | "negotiator": { 3577 | "version": "0.6.2", 3578 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 3579 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 3580 | }, 3581 | "node-fetch": { 3582 | "version": "2.6.1", 3583 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.1.tgz", 3584 | "integrity": "sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw==", 3585 | "optional": true 3586 | }, 3587 | "node-forge": { 3588 | "version": "0.10.0", 3589 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-0.10.0.tgz", 3590 | "integrity": "sha512-PPmu8eEeG9saEUvI97fm4OYxXVB6bFvyNTyiUOBichBpFG8A1Ljw3bY62+5oOjDEMHRnd0Y7HQ+x7uzxOzC6JA==" 3591 | }, 3592 | "object-assign": { 3593 | "version": "4.1.1", 3594 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 3595 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 3596 | }, 3597 | "object-hash": { 3598 | "version": "2.2.0", 3599 | "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-2.2.0.tgz", 3600 | "integrity": "sha512-gScRMn0bS5fH+IuwyIFgnh9zBdo4DV+6GhygmWM9HyNJSgS0hScp1f5vjtm7oIIOiT9trXrShAkLFSc2IqKNgw==", 3601 | "optional": true 3602 | }, 3603 | "on-finished": { 3604 | "version": "2.3.0", 3605 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 3606 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 3607 | "requires": { 3608 | "ee-first": "1.1.1" 3609 | } 3610 | }, 3611 | "once": { 3612 | "version": "1.4.0", 3613 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3614 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 3615 | "optional": true, 3616 | "requires": { 3617 | "wrappy": "1" 3618 | } 3619 | }, 3620 | "onetime": { 3621 | "version": "5.1.2", 3622 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 3623 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 3624 | "optional": true, 3625 | "requires": { 3626 | "mimic-fn": "^2.1.0" 3627 | } 3628 | }, 3629 | "p-limit": { 3630 | "version": "3.1.0", 3631 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 3632 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 3633 | "optional": true, 3634 | "requires": { 3635 | "yocto-queue": "^0.1.0" 3636 | } 3637 | }, 3638 | "parseurl": { 3639 | "version": "1.3.3", 3640 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 3641 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 3642 | }, 3643 | "path-to-regexp": { 3644 | "version": "0.1.7", 3645 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 3646 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 3647 | }, 3648 | "protobufjs": { 3649 | "version": "6.11.2", 3650 | "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.11.2.tgz", 3651 | "integrity": "sha512-4BQJoPooKJl2G9j3XftkIXjoC9C0Av2NOrWmbLWT1vH32GcSUHjM0Arra6UfTsVyfMAuFzaLucXn1sadxJydAw==", 3652 | "optional": true, 3653 | "requires": { 3654 | "@protobufjs/aspromise": "^1.1.2", 3655 | "@protobufjs/base64": "^1.1.2", 3656 | "@protobufjs/codegen": "^2.0.4", 3657 | "@protobufjs/eventemitter": "^1.1.0", 3658 | "@protobufjs/fetch": "^1.1.0", 3659 | "@protobufjs/float": "^1.0.2", 3660 | "@protobufjs/inquire": "^1.1.0", 3661 | "@protobufjs/path": "^1.1.2", 3662 | "@protobufjs/pool": "^1.1.0", 3663 | "@protobufjs/utf8": "^1.1.0", 3664 | "@types/long": "^4.0.1", 3665 | "@types/node": ">=13.7.0", 3666 | "long": "^4.0.0" 3667 | } 3668 | }, 3669 | "proxy-addr": { 3670 | "version": "2.0.6", 3671 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz", 3672 | "integrity": "sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw==", 3673 | "requires": { 3674 | "forwarded": "~0.1.2", 3675 | "ipaddr.js": "1.9.1" 3676 | } 3677 | }, 3678 | "pseudomap": { 3679 | "version": "1.0.2", 3680 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 3681 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 3682 | }, 3683 | "pump": { 3684 | "version": "3.0.0", 3685 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 3686 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 3687 | "optional": true, 3688 | "requires": { 3689 | "end-of-stream": "^1.1.0", 3690 | "once": "^1.3.1" 3691 | } 3692 | }, 3693 | "pumpify": { 3694 | "version": "2.0.1", 3695 | "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-2.0.1.tgz", 3696 | "integrity": "sha512-m7KOje7jZxrmutanlkS1daj1dS6z6BgslzOXmcSEpIlCxM3VJH7lG5QLeck/6hgF6F4crFf01UtQmNsJfweTAw==", 3697 | "optional": true, 3698 | "requires": { 3699 | "duplexify": "^4.1.1", 3700 | "inherits": "^2.0.3", 3701 | "pump": "^3.0.0" 3702 | } 3703 | }, 3704 | "qs": { 3705 | "version": "6.7.0", 3706 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 3707 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 3708 | }, 3709 | "range-parser": { 3710 | "version": "1.2.1", 3711 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 3712 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 3713 | }, 3714 | "raw-body": { 3715 | "version": "2.4.0", 3716 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 3717 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 3718 | "requires": { 3719 | "bytes": "3.1.0", 3720 | "http-errors": "1.7.2", 3721 | "iconv-lite": "0.4.24", 3722 | "unpipe": "1.0.0" 3723 | } 3724 | }, 3725 | "readable-stream": { 3726 | "version": "3.6.0", 3727 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 3728 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 3729 | "optional": true, 3730 | "requires": { 3731 | "inherits": "^2.0.3", 3732 | "string_decoder": "^1.1.1", 3733 | "util-deprecate": "^1.0.1" 3734 | } 3735 | }, 3736 | "require-directory": { 3737 | "version": "2.1.1", 3738 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 3739 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 3740 | "optional": true 3741 | }, 3742 | "retry": { 3743 | "version": "0.12.0", 3744 | "resolved": "https://registry.npmjs.org/retry/-/retry-0.12.0.tgz", 3745 | "integrity": "sha1-G0KmJmoh8HQh0bC1S33BZ7AcATs=", 3746 | "optional": true 3747 | }, 3748 | "retry-request": { 3749 | "version": "4.1.3", 3750 | "resolved": "https://registry.npmjs.org/retry-request/-/retry-request-4.1.3.tgz", 3751 | "integrity": "sha512-QnRZUpuPNgX0+D1xVxul6DbJ9slvo4Rm6iV/dn63e048MvGbUZiKySVt6Tenp04JqmchxjiLltGerOJys7kJYQ==", 3752 | "optional": true, 3753 | "requires": { 3754 | "debug": "^4.1.1" 3755 | }, 3756 | "dependencies": { 3757 | "debug": { 3758 | "version": "4.3.1", 3759 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 3760 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 3761 | "optional": true, 3762 | "requires": { 3763 | "ms": "2.1.2" 3764 | } 3765 | }, 3766 | "ms": { 3767 | "version": "2.1.2", 3768 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3769 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 3770 | "optional": true 3771 | } 3772 | } 3773 | }, 3774 | "safe-buffer": { 3775 | "version": "5.1.2", 3776 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 3777 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 3778 | }, 3779 | "safer-buffer": { 3780 | "version": "2.1.2", 3781 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 3782 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 3783 | }, 3784 | "semver": { 3785 | "version": "5.7.1", 3786 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 3787 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 3788 | }, 3789 | "send": { 3790 | "version": "0.17.1", 3791 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 3792 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 3793 | "requires": { 3794 | "debug": "2.6.9", 3795 | "depd": "~1.1.2", 3796 | "destroy": "~1.0.4", 3797 | "encodeurl": "~1.0.2", 3798 | "escape-html": "~1.0.3", 3799 | "etag": "~1.8.1", 3800 | "fresh": "0.5.2", 3801 | "http-errors": "~1.7.2", 3802 | "mime": "1.6.0", 3803 | "ms": "2.1.1", 3804 | "on-finished": "~2.3.0", 3805 | "range-parser": "~1.2.1", 3806 | "statuses": "~1.5.0" 3807 | }, 3808 | "dependencies": { 3809 | "mime": { 3810 | "version": "1.6.0", 3811 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 3812 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 3813 | }, 3814 | "ms": { 3815 | "version": "2.1.1", 3816 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 3817 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 3818 | } 3819 | } 3820 | }, 3821 | "serve-static": { 3822 | "version": "1.14.1", 3823 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 3824 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 3825 | "requires": { 3826 | "encodeurl": "~1.0.2", 3827 | "escape-html": "~1.0.3", 3828 | "parseurl": "~1.3.3", 3829 | "send": "0.17.1" 3830 | } 3831 | }, 3832 | "setprototypeof": { 3833 | "version": "1.1.1", 3834 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 3835 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 3836 | }, 3837 | "signal-exit": { 3838 | "version": "3.0.3", 3839 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 3840 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 3841 | "optional": true 3842 | }, 3843 | "snakeize": { 3844 | "version": "0.1.0", 3845 | "resolved": "https://registry.npmjs.org/snakeize/-/snakeize-0.1.0.tgz", 3846 | "integrity": "sha1-EMCI2LWOsHazIpu1oE4jLOEmQi0=", 3847 | "optional": true 3848 | }, 3849 | "statuses": { 3850 | "version": "1.5.0", 3851 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 3852 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 3853 | }, 3854 | "stream-events": { 3855 | "version": "1.0.5", 3856 | "resolved": "https://registry.npmjs.org/stream-events/-/stream-events-1.0.5.tgz", 3857 | "integrity": "sha512-E1GUzBSgvct8Jsb3v2X15pjzN1tYebtbLaMg+eBOUOAxgbLoSbT2NS91ckc5lJD1KfLjId+jXJRgo0qnV5Nerg==", 3858 | "optional": true, 3859 | "requires": { 3860 | "stubs": "^3.0.0" 3861 | } 3862 | }, 3863 | "stream-shift": { 3864 | "version": "1.0.1", 3865 | "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.1.tgz", 3866 | "integrity": "sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ==", 3867 | "optional": true 3868 | }, 3869 | "streamsearch": { 3870 | "version": "0.1.2", 3871 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-0.1.2.tgz", 3872 | "integrity": "sha1-gIudDlb8Jz2Am6VzOOkpkZoanxo=" 3873 | }, 3874 | "string_decoder": { 3875 | "version": "1.3.0", 3876 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 3877 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 3878 | "optional": true, 3879 | "requires": { 3880 | "safe-buffer": "~5.2.0" 3881 | }, 3882 | "dependencies": { 3883 | "safe-buffer": { 3884 | "version": "5.2.1", 3885 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 3886 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 3887 | "optional": true 3888 | } 3889 | } 3890 | }, 3891 | "string-width": { 3892 | "version": "4.2.2", 3893 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 3894 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 3895 | "optional": true, 3896 | "requires": { 3897 | "emoji-regex": "^8.0.0", 3898 | "is-fullwidth-code-point": "^3.0.0", 3899 | "strip-ansi": "^6.0.0" 3900 | } 3901 | }, 3902 | "strip-ansi": { 3903 | "version": "6.0.0", 3904 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 3905 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 3906 | "optional": true, 3907 | "requires": { 3908 | "ansi-regex": "^5.0.0" 3909 | } 3910 | }, 3911 | "stubs": { 3912 | "version": "3.0.0", 3913 | "resolved": "https://registry.npmjs.org/stubs/-/stubs-3.0.0.tgz", 3914 | "integrity": "sha1-6NK6H6nJBXAwPAMLaQD31fiavls=", 3915 | "optional": true 3916 | }, 3917 | "teeny-request": { 3918 | "version": "7.1.0", 3919 | "resolved": "https://registry.npmjs.org/teeny-request/-/teeny-request-7.1.0.tgz", 3920 | "integrity": "sha512-hPfSc05a7Mf3syqVhSkrVMb844sMiP60MrfGMts3ft6V6UlSkEIGQzgwf0dy1KjdE3FV2lJ5s7QCBFcaoQLA6g==", 3921 | "optional": true, 3922 | "requires": { 3923 | "http-proxy-agent": "^4.0.0", 3924 | "https-proxy-agent": "^5.0.0", 3925 | "node-fetch": "^2.6.1", 3926 | "stream-events": "^1.0.5", 3927 | "uuid": "^8.0.0" 3928 | } 3929 | }, 3930 | "toidentifier": { 3931 | "version": "1.0.0", 3932 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 3933 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 3934 | }, 3935 | "tslib": { 3936 | "version": "2.2.0", 3937 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.2.0.tgz", 3938 | "integrity": "sha512-gS9GVHRU+RGn5KQM2rllAlR3dU6m7AcpJKdtH8gFvQiC4Otgk98XnmMU+nZenHt/+VhnBPWwgrJsyrdcw6i23w==" 3939 | }, 3940 | "type-is": { 3941 | "version": "1.6.18", 3942 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 3943 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 3944 | "requires": { 3945 | "media-typer": "0.3.0", 3946 | "mime-types": "~2.1.24" 3947 | } 3948 | }, 3949 | "typedarray-to-buffer": { 3950 | "version": "3.1.5", 3951 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 3952 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 3953 | "optional": true, 3954 | "requires": { 3955 | "is-typedarray": "^1.0.0" 3956 | } 3957 | }, 3958 | "typescript": { 3959 | "version": "3.9.9", 3960 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.9.9.tgz", 3961 | "integrity": "sha512-kdMjTiekY+z/ubJCATUPlRDl39vXYiMV9iyeMuEuXZh2we6zz80uovNN2WlAxmmdE/Z/YQe+EbOEXB5RHEED3w==", 3962 | "dev": true 3963 | }, 3964 | "unique-string": { 3965 | "version": "2.0.0", 3966 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", 3967 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", 3968 | "optional": true, 3969 | "requires": { 3970 | "crypto-random-string": "^2.0.0" 3971 | } 3972 | }, 3973 | "unpipe": { 3974 | "version": "1.0.0", 3975 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 3976 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 3977 | }, 3978 | "util-deprecate": { 3979 | "version": "1.0.2", 3980 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3981 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 3982 | "optional": true 3983 | }, 3984 | "utils-merge": { 3985 | "version": "1.0.1", 3986 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 3987 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 3988 | }, 3989 | "uuid": { 3990 | "version": "8.3.2", 3991 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 3992 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", 3993 | "optional": true 3994 | }, 3995 | "vary": { 3996 | "version": "1.1.2", 3997 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 3998 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 3999 | }, 4000 | "websocket-driver": { 4001 | "version": "0.7.4", 4002 | "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz", 4003 | "integrity": "sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg==", 4004 | "requires": { 4005 | "http-parser-js": ">=0.5.1", 4006 | "safe-buffer": ">=5.1.0", 4007 | "websocket-extensions": ">=0.1.1" 4008 | } 4009 | }, 4010 | "websocket-extensions": { 4011 | "version": "0.1.4", 4012 | "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.4.tgz", 4013 | "integrity": "sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==" 4014 | }, 4015 | "wrap-ansi": { 4016 | "version": "7.0.0", 4017 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 4018 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 4019 | "optional": true, 4020 | "requires": { 4021 | "ansi-styles": "^4.0.0", 4022 | "string-width": "^4.1.0", 4023 | "strip-ansi": "^6.0.0" 4024 | } 4025 | }, 4026 | "wrappy": { 4027 | "version": "1.0.2", 4028 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 4029 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 4030 | "optional": true 4031 | }, 4032 | "write-file-atomic": { 4033 | "version": "3.0.3", 4034 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 4035 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 4036 | "optional": true, 4037 | "requires": { 4038 | "imurmurhash": "^0.1.4", 4039 | "is-typedarray": "^1.0.0", 4040 | "signal-exit": "^3.0.2", 4041 | "typedarray-to-buffer": "^3.1.5" 4042 | } 4043 | }, 4044 | "xdg-basedir": { 4045 | "version": "4.0.0", 4046 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", 4047 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==", 4048 | "optional": true 4049 | }, 4050 | "y18n": { 4051 | "version": "5.0.8", 4052 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 4053 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 4054 | "optional": true 4055 | }, 4056 | "yallist": { 4057 | "version": "4.0.0", 4058 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 4059 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 4060 | "optional": true 4061 | }, 4062 | "yargs": { 4063 | "version": "16.2.0", 4064 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 4065 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 4066 | "optional": true, 4067 | "requires": { 4068 | "cliui": "^7.0.2", 4069 | "escalade": "^3.1.1", 4070 | "get-caller-file": "^2.0.5", 4071 | "require-directory": "^2.1.1", 4072 | "string-width": "^4.2.0", 4073 | "y18n": "^5.0.5", 4074 | "yargs-parser": "^20.2.2" 4075 | } 4076 | }, 4077 | "yargs-parser": { 4078 | "version": "20.2.7", 4079 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.7.tgz", 4080 | "integrity": "sha512-FiNkvbeHzB/syOjIUxFDCnhSfzAL8R5vs40MgLFBorXACCOAEaWu0gRZl14vG8MR9AOJIZbmkjhusqBYZ3HTHw==", 4081 | "optional": true 4082 | }, 4083 | "yocto-queue": { 4084 | "version": "0.1.0", 4085 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 4086 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 4087 | "optional": true 4088 | } 4089 | } 4090 | } 4091 | -------------------------------------------------------------------------------- /functions/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "functions", 3 | "scripts": { 4 | "build": "tsc", 5 | "serve": "npm run build && firebase emulators:start --only functions", 6 | "shell": "npm run build && firebase functions:shell", 7 | "start": "npm run shell", 8 | "deploy": "firebase deploy --only functions", 9 | "logs": "firebase functions:log" 10 | }, 11 | "engines": { 12 | "node": "14" 13 | }, 14 | "main": "lib/index.js", 15 | "dependencies": { 16 | "firebase-admin": "^9.8.0", 17 | "firebase-functions": "^3.14.1" 18 | }, 19 | "devDependencies": { 20 | "firebase-functions-test": "^0.2.0", 21 | "typescript": "^3.8.0" 22 | }, 23 | "private": true 24 | } 25 | -------------------------------------------------------------------------------- /functions/src/index.ts: -------------------------------------------------------------------------------- 1 | import * as functions from "firebase-functions"; 2 | 3 | const admin = require("firebase-admin"); 4 | admin.initializeApp(); 5 | const db = admin.firestore(); 6 | 7 | export const createUserDocument = functions.auth.user().onCreate((user) => { 8 | db.collection("users") 9 | .doc(user.uid) 10 | .set(JSON.parse(JSON.stringify(user))); 11 | }); 12 | -------------------------------------------------------------------------------- /functions/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "noImplicitReturns": true, 5 | "noUnusedLocals": true, 6 | "outDir": "lib", 7 | "sourceMap": true, 8 | "strict": true, 9 | "target": "es2017" 10 | }, 11 | "compileOnSave": true, 12 | "include": [ 13 | "src" 14 | ] 15 | } 16 | -------------------------------------------------------------------------------- /images/hero.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ahern55/next-firebase-typescript/9fa79bf1bc1e945fafc8dbf7f0fa0aa3000440e5/images/hero.png -------------------------------------------------------------------------------- /images/svg/logo.svg: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 13 | 15 | 17 | 23 | 32 | 41 | 50 | 59 | 68 | 77 | 86 | 95 | 96 | 97 | -------------------------------------------------------------------------------- /next-env.d.ts: -------------------------------------------------------------------------------- 1 | /// 2 | /// 3 | 4 | // NOTE: This file should not be edited 5 | // see https://nextjs.org/docs/basic-features/typescript for more information. 6 | -------------------------------------------------------------------------------- /next.config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | webpack(config) { 3 | config.module.rules.push({ 4 | test: /\.svg$/i, 5 | issuer: /\.[jt]sx?$/, 6 | use: ["@svgr/webpack"], 7 | }); 8 | 9 | return config; 10 | }, 11 | }; 12 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "habits", 3 | "version": "0.1.0", 4 | "private": true, 5 | "scripts": { 6 | "dev": "next dev -p 8080", 7 | "build": "next build", 8 | "start": "next start" 9 | }, 10 | "dependencies": { 11 | "@headlessui/react": "^1.5.0", 12 | "@svgr/webpack": "^6.2.1", 13 | "firebase": "^8.6.2", 14 | "firebase-admin": "^10.3.0", 15 | "firebase-functions": "^3.14.1", 16 | "next": "^12.1.5", 17 | "nookies": "^2.5.2", 18 | "react": "17.0.2", 19 | "react-dom": "17.0.2", 20 | "react-firebase-hooks": "^3.0.4", 21 | "react-firebaseui": "^5.0.2" 22 | }, 23 | "devDependencies": { 24 | "@next/eslint-plugin-next": "^12.1.5", 25 | "@types/node": "^15.6.1", 26 | "@types/react": "^17.0.8", 27 | "@typescript-eslint/eslint-plugin": "^5.19.0", 28 | "@typescript-eslint/parser": "^5.19.0", 29 | "autoprefixer": "^10.4.4", 30 | "eslint": "^8.13.0", 31 | "eslint-plugin-react": "^7.29.4", 32 | "postcss": "^8.4.12", 33 | "tailwindcss": "^3.0.24", 34 | "typescript": "^4.3.2" 35 | } 36 | } 37 | -------------------------------------------------------------------------------- /pages/_app.tsx: -------------------------------------------------------------------------------- 1 | import "../styles/globals.css"; 2 | import { AppProps } from "next/app"; 3 | import React from "react"; 4 | import { AuthProvider } from "../firebase/auth/auth"; 5 | 6 | function App({ Component, pageProps }: AppProps) { 7 | return ( 8 | 9 | 10 | 11 | ); 12 | } 13 | 14 | export default App; 15 | -------------------------------------------------------------------------------- /pages/index.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import Dashboard from "../components/dashboard"; 3 | import Splash from "../components/splash"; 4 | import { GetServerSidePropsContext, InferGetServerSidePropsType } from "next"; 5 | import nookies from "nookies"; 6 | import { userIsLoggedIn } from "../firebase/auth/utils"; 7 | 8 | export default function index( 9 | props: InferGetServerSidePropsType 10 | ) { 11 | return ( 12 |
13 | {!props.authenticated && } 14 | {props.authenticated && } 15 |
16 | ); 17 | } 18 | 19 | export async function getServerSideProps(ctx: GetServerSidePropsContext) { 20 | const cookies = nookies.get(ctx); 21 | const authenticated = await userIsLoggedIn(cookies); 22 | return { 23 | props: { authenticated }, 24 | }; 25 | } 26 | -------------------------------------------------------------------------------- /pages/login.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import Auth from "../components/auth"; 3 | import { GetServerSidePropsContext } from "next"; 4 | import nookies from "nookies"; 5 | import { userIsLoggedIn } from "../firebase/auth/utils"; 6 | import LogoSvg from "../images/svg/logo.svg"; 7 | 8 | export default function Login() { 9 | return ( 10 | <> 11 |
12 |
13 | 14 |
My App
15 |
16 | 17 |
18 | 19 | ); 20 | } 21 | 22 | export async function getServerSideProps(ctx: GetServerSidePropsContext) { 23 | const cookies = nookies.get(ctx); 24 | const authenticated = await userIsLoggedIn(cookies); 25 | 26 | if (authenticated) { 27 | ctx.res.writeHead(302, { Location: "/" }); 28 | ctx.res.end(); 29 | } 30 | 31 | return { 32 | props: {}, 33 | }; 34 | } 35 | -------------------------------------------------------------------------------- /pages/messages.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import Shell from "../components/shell"; 3 | import Content from "../components/content/Content"; 4 | import { GetServerSidePropsContext } from "next"; 5 | import nookies from "nookies"; 6 | import { userIsLoggedIn } from "../firebase/auth/utils"; 7 | 8 | export default function Messages() { 9 | return ( 10 | 11 | 12 | <>Messages 13 | 14 | 15 | ); 16 | } 17 | 18 | export async function getServerSideProps(ctx: GetServerSidePropsContext) { 19 | const cookies = nookies.get(ctx); 20 | const authenticated = await userIsLoggedIn(cookies); 21 | 22 | if (!authenticated) { 23 | ctx.res.writeHead(302, { Location: "/login" }); 24 | ctx.res.end(); 25 | } 26 | 27 | return { 28 | props: {}, 29 | }; 30 | } 31 | -------------------------------------------------------------------------------- /pages/settings.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import Shell from "../components/shell"; 3 | import { GetServerSidePropsContext } from "next"; 4 | import nookies from "nookies"; 5 | import { userIsLoggedIn } from "../firebase/auth/utils"; 6 | 7 | export default function Settings() { 8 | return ( 9 | 10 | <> 11 | 12 | ); 13 | } 14 | 15 | export async function getServerSideProps(ctx: GetServerSidePropsContext) { 16 | const cookies = nookies.get(ctx); 17 | const authenticated = await userIsLoggedIn(cookies); 18 | 19 | if (!authenticated) { 20 | ctx.res.writeHead(302, { Location: "/login" }); 21 | ctx.res.end(); 22 | } 23 | 24 | return { 25 | props: {}, 26 | }; 27 | } 28 | -------------------------------------------------------------------------------- /pages/users.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import Shell from "../components/shell"; 3 | import Content from "../components/content/Content"; 4 | import { GetServerSidePropsContext } from "next"; 5 | import nookies from "nookies"; 6 | import { userIsLoggedIn } from "../firebase/auth/utils"; 7 | 8 | export default function Users() { 9 | return ( 10 | 11 | 12 | <>Users 13 | 14 | 15 | ); 16 | } 17 | 18 | export async function getServerSideProps(ctx: GetServerSidePropsContext) { 19 | const cookies = nookies.get(ctx); 20 | const authenticated = await userIsLoggedIn(cookies); 21 | 22 | if (!authenticated) { 23 | ctx.res.writeHead(302, { Location: "/login" }); 24 | ctx.res.end(); 25 | } 26 | 27 | return { 28 | props: {}, 29 | }; 30 | } 31 | -------------------------------------------------------------------------------- /postcss.config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | plugins: { 3 | tailwindcss: {}, 4 | autoprefixer: {}, 5 | }, 6 | } 7 | -------------------------------------------------------------------------------- /public/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ahern55/next-firebase-typescript/9fa79bf1bc1e945fafc8dbf7f0fa0aa3000440e5/public/favicon.ico -------------------------------------------------------------------------------- /sample.env.local: -------------------------------------------------------------------------------- 1 | NEXT_PUBLIC_FIREBASE_API_KEY= 2 | NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN= 3 | NEXT_PUBLIC_FIREBASE_DATABASE_URL= 4 | NEXT_PUBLIC_FIREBASE_PROJECT_ID= 5 | NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET= 6 | NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID= 7 | NEXT_PUBLIC_FIREBASE_APP_ID= 8 | NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID= 9 | 10 | FIREBASE_CLIENT_EMAIL= 11 | FIREBASE_PRIVATE_KEY='"-----BEGIN PRIVATE KEY-----\n...\n-----END PRIVATE KEY-----\n"' -------------------------------------------------------------------------------- /styles/Home.module.css: -------------------------------------------------------------------------------- 1 | .container { 2 | min-height: 100vh; 3 | padding: 0 0.5rem; 4 | display: flex; 5 | flex-direction: column; 6 | justify-content: center; 7 | align-items: center; 8 | height: 100vh; 9 | } 10 | 11 | .main { 12 | padding: 5rem 0; 13 | flex: 1; 14 | display: flex; 15 | flex-direction: column; 16 | justify-content: center; 17 | align-items: center; 18 | } 19 | 20 | .footer { 21 | width: 100%; 22 | height: 100px; 23 | border-top: 1px solid #eaeaea; 24 | display: flex; 25 | justify-content: center; 26 | align-items: center; 27 | } 28 | 29 | .footer a { 30 | display: flex; 31 | justify-content: center; 32 | align-items: center; 33 | flex-grow: 1; 34 | } 35 | 36 | .title a { 37 | color: #0070f3; 38 | text-decoration: none; 39 | } 40 | 41 | .title a:hover, 42 | .title a:focus, 43 | .title a:active { 44 | text-decoration: underline; 45 | } 46 | 47 | .title { 48 | margin: 0; 49 | line-height: 1.15; 50 | font-size: 4rem; 51 | } 52 | 53 | .title, 54 | .description { 55 | text-align: center; 56 | } 57 | 58 | .description { 59 | line-height: 1.5; 60 | font-size: 1.5rem; 61 | } 62 | 63 | .code { 64 | background: #fafafa; 65 | border-radius: 5px; 66 | padding: 0.75rem; 67 | font-size: 1.1rem; 68 | font-family: Menlo, Monaco, Lucida Console, Liberation Mono, DejaVu Sans Mono, 69 | Bitstream Vera Sans Mono, Courier New, monospace; 70 | } 71 | 72 | .grid { 73 | display: flex; 74 | align-items: center; 75 | justify-content: center; 76 | flex-wrap: wrap; 77 | max-width: 800px; 78 | margin-top: 3rem; 79 | } 80 | 81 | .card { 82 | margin: 1rem; 83 | padding: 1.5rem; 84 | text-align: left; 85 | color: inherit; 86 | text-decoration: none; 87 | border: 1px solid #eaeaea; 88 | border-radius: 10px; 89 | transition: color 0.15s ease, border-color 0.15s ease; 90 | width: 45%; 91 | } 92 | 93 | .card:hover, 94 | .card:focus, 95 | .card:active { 96 | color: #0070f3; 97 | border-color: #0070f3; 98 | } 99 | 100 | .card h2 { 101 | margin: 0 0 1rem 0; 102 | font-size: 1.5rem; 103 | } 104 | 105 | .card p { 106 | margin: 0; 107 | font-size: 1.25rem; 108 | line-height: 1.5; 109 | } 110 | 111 | .logo { 112 | height: 1em; 113 | margin-left: 0.5rem; 114 | } 115 | 116 | @media (max-width: 600px) { 117 | .grid { 118 | width: 100%; 119 | flex-direction: column; 120 | } 121 | } 122 | -------------------------------------------------------------------------------- /styles/globals.css: -------------------------------------------------------------------------------- 1 | @tailwind base; 2 | @tailwind components; 3 | @tailwind utilities; 4 | 5 | html, 6 | body { 7 | padding: 0; 8 | margin: 0; 9 | font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, 10 | Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif; 11 | } 12 | 13 | a { 14 | color: inherit; 15 | text-decoration: none; 16 | } 17 | 18 | * { 19 | box-sizing: border-box; 20 | } 21 | -------------------------------------------------------------------------------- /tailwind.config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | content: [ 3 | "./pages/**/*.{js,ts,jsx,tsx}", 4 | "./components/**/*.{js,ts,jsx,tsx}", 5 | ], 6 | theme: { 7 | extend: { 8 | gridTemplateColumns: { 9 | "custom-sidenav-layout": "auto 1fr", 10 | }, 11 | }, 12 | }, 13 | plugins: [], 14 | }; 15 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es5", 4 | "lib": ["dom", "dom.iterable", "esnext"], 5 | "allowJs": true, 6 | "skipLibCheck": true, 7 | "strict": true, 8 | "forceConsistentCasingInFileNames": true, 9 | "noEmit": true, 10 | "esModuleInterop": true, 11 | "module": "esnext", 12 | "moduleResolution": "node", 13 | "resolveJsonModule": true, 14 | "isolatedModules": true, 15 | "jsx": "preserve", 16 | "incremental": true 17 | }, 18 | "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx"], 19 | "exclude": ["node_modules"] 20 | } 21 | -------------------------------------------------------------------------------- /utils/genericUtils.tsx: -------------------------------------------------------------------------------- 1 | import Router from "next/router"; 2 | import firebase from "../firebase/clientApp"; 3 | 4 | export const signOut = async () => { 5 | await firebase.auth().signOut(); 6 | Router.push("/"); 7 | }; 8 | -------------------------------------------------------------------------------- /utils/hooks/useLocalStorage.ts: -------------------------------------------------------------------------------- 1 | import { useState, useEffect } from "react"; 2 | 3 | function getStorageValue(key: string, defaultValue: any) { 4 | if (typeof window !== "undefined") { 5 | const saved = localStorage.getItem(key); 6 | if (!saved) { 7 | return defaultValue; 8 | } 9 | const initial = JSON.parse(saved); 10 | return initial || defaultValue; 11 | } else { 12 | return defaultValue; 13 | } 14 | } 15 | 16 | export default function useLocalStorage(key: string, defaultValue: any) { 17 | const [value, setValue] = useState(() => { 18 | return getStorageValue(key, defaultValue); 19 | }); 20 | 21 | useEffect(() => { 22 | if (typeof window !== "undefined") { 23 | localStorage.setItem(key, JSON.stringify(value)); 24 | } 25 | }, [key, value]); 26 | 27 | return [value, setValue]; 28 | } 29 | --------------------------------------------------------------------------------